156 lines
4.5 KiB
Go
156 lines
4.5 KiB
Go
package models
|
|
|
|
import (
|
|
"database/sql"
|
|
"time"
|
|
)
|
|
|
|
type GuestbookComment struct {
|
|
ID int64
|
|
ShortId uint64
|
|
GuestbookId int64
|
|
ParentId int64
|
|
AuthorName string
|
|
AuthorEmail string
|
|
AuthorSite string
|
|
CommentText string
|
|
PageUrl string
|
|
Created time.Time
|
|
Deleted time.Time
|
|
IsPublished bool
|
|
}
|
|
|
|
type GuestbookCommentModel struct {
|
|
DB *sql.DB
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) Insert(shortId uint64, guestbookId, parentId int64, authorName,
|
|
authorEmail, authorSite, commentText, pageUrl string, isPublished bool) (int64, error) {
|
|
stmt := `INSERT INTO guestbook_comments (ShortId, GuestbookId, ParentId, AuthorName,
|
|
AuthorEmail, AuthorSite, CommentText, PageUrl, Created, IsPublished)
|
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`
|
|
result, err := m.DB.Exec(stmt, shortId, guestbookId, parentId, authorName, authorEmail,
|
|
authorSite, commentText, pageUrl, time.Now().UTC(), isPublished)
|
|
if err != nil {
|
|
return -1, err
|
|
}
|
|
id, err := result.LastInsertId()
|
|
if err != nil {
|
|
return -1, err
|
|
}
|
|
return id, nil
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) Get(shortId uint64) (GuestbookComment, error) {
|
|
stmt := `SELECT Id, ShortId, GuestbookId, ParentId, AuthorName, AuthorEmail, AuthorSite,
|
|
CommentText, PageUrl, Created, IsPublished, Deleted FROM guestbook_comments WHERE ShortId = ?`
|
|
row := m.DB.QueryRow(stmt, shortId)
|
|
var c GuestbookComment
|
|
var t sql.NullTime
|
|
err := row.Scan(&c.ID, &c.ShortId, &c.GuestbookId, &c.ParentId, &c.AuthorName, &c.AuthorEmail, &c.AuthorSite,
|
|
&c.CommentText, &c.PageUrl, &c.Created, &c.IsPublished, &t)
|
|
if err != nil {
|
|
return GuestbookComment{}, err
|
|
}
|
|
if t.Valid {
|
|
c.Deleted = t.Time
|
|
}
|
|
return c, nil
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) GetAll(guestbookId int64) ([]GuestbookComment, error) {
|
|
stmt := `SELECT Id, ShortId, GuestbookId, ParentId, AuthorName, AuthorEmail, AuthorSite,
|
|
CommentText, PageUrl, Created, IsPublished
|
|
FROM guestbook_comments
|
|
WHERE GuestbookId = ? AND IsPublished = TRUE AND DELETED IS NULL
|
|
ORDER BY Created DESC`
|
|
rows, err := m.DB.Query(stmt, guestbookId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var comments []GuestbookComment
|
|
for rows.Next() {
|
|
var c GuestbookComment
|
|
err = rows.Scan(&c.ID, &c.ShortId, &c.GuestbookId, &c.ParentId, &c.AuthorName, &c.AuthorEmail, &c.AuthorSite,
|
|
&c.CommentText, &c.PageUrl, &c.Created, &c.IsPublished)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
comments = append(comments, c)
|
|
}
|
|
if err = rows.Err(); err != nil {
|
|
return nil, err
|
|
}
|
|
return comments, nil
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) GetDeleted(guestbookId int64) ([]GuestbookComment, error) {
|
|
stmt := `SELECT Id, ShortId, GuestbookId, ParentId, AuthorName, AuthorEmail, AuthorSite,
|
|
CommentText, PageUrl, Created, IsPublished, Deleted
|
|
FROM guestbook_comments
|
|
WHERE GuestbookId = ? AND Deleted IS NOT NULL
|
|
ORDER BY Created DESC`
|
|
rows, err := m.DB.Query(stmt, guestbookId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var comments []GuestbookComment
|
|
for rows.Next() {
|
|
var c GuestbookComment
|
|
var t sql.NullTime
|
|
err = rows.Scan(&c.ID, &c.ShortId, &c.GuestbookId, &c.ParentId, &c.AuthorName, &c.AuthorEmail, &c.AuthorSite,
|
|
&c.CommentText, &c.PageUrl, &c.Created, &c.IsPublished, &t)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if t.Valid {
|
|
c.Deleted = t.Time
|
|
}
|
|
comments = append(comments, c)
|
|
}
|
|
if err = rows.Err(); err != nil {
|
|
return nil, err
|
|
}
|
|
return comments, nil
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) GetUnpublished(guestbookId int64) ([]GuestbookComment, error) {
|
|
stmt := `SELECT Id, ShortId, GuestbookId, ParentId, AuthorName, AuthorEmail, AuthorSite,
|
|
CommentText, PageUrl, Created, IsPublished
|
|
FROM guestbook_comments
|
|
WHERE GuestbookId = ? AND IsDeleted IS NULL AND IsPublished = FALSE
|
|
ORDER BY Created DESC`
|
|
rows, err := m.DB.Query(stmt, guestbookId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var comments []GuestbookComment
|
|
for rows.Next() {
|
|
var c GuestbookComment
|
|
err = rows.Scan(&c.ID, &c.ShortId, &c.GuestbookId, &c.ParentId, &c.AuthorName, &c.AuthorEmail, &c.AuthorSite,
|
|
&c.CommentText, &c.PageUrl, &c.Created, &c.IsPublished)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
comments = append(comments, c)
|
|
}
|
|
if err = rows.Err(); err != nil {
|
|
return nil, err
|
|
}
|
|
return comments, nil
|
|
}
|
|
|
|
func (m *GuestbookCommentModel) UpdateComment(comment *GuestbookComment) error {
|
|
stmt := `UPDATE guestbook_comments
|
|
SET CommentText = ?,
|
|
PageUrl = ?,
|
|
IsPublished = ?,
|
|
Deleted = ?
|
|
WHERE Id = ?`
|
|
_, err := m.DB.Exec(stmt, comment.CommentText, comment.PageUrl, comment.IsPublished, comment.Deleted, comment.ID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|