2018-05-27 22:40:42 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
|
|
|
func commentList(commenterHex string, domain string, path string, includeUnapproved bool) ([]comment, map[string]commenter, error) {
|
|
|
|
if commenterHex == "" || domain == "" || path == "" {
|
|
|
|
return nil, nil, errorMissingField
|
|
|
|
}
|
|
|
|
|
|
|
|
statement := `
|
|
|
|
SELECT commentHex, commenterHex, markdown, html, parentHex, score, state, creationDate
|
|
|
|
FROM comments
|
|
|
|
WHERE
|
|
|
|
comments.domain = $1 AND
|
|
|
|
comments.path = $2
|
|
|
|
`
|
|
|
|
|
|
|
|
if !includeUnapproved {
|
|
|
|
if commenterHex == "anonymous" {
|
|
|
|
statement += `
|
|
|
|
AND state = 'approved'
|
|
|
|
`
|
|
|
|
} else {
|
|
|
|
statement += `
|
|
|
|
AND (state = 'approved' OR commenterHex = $3)
|
|
|
|
`
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
statement += `;`
|
|
|
|
|
|
|
|
var rows *sql.Rows
|
|
|
|
var err error
|
|
|
|
|
|
|
|
if !includeUnapproved && commenterHex != "anonymous" {
|
|
|
|
rows, err = db.Query(statement, domain, path, commenterHex)
|
|
|
|
} else {
|
|
|
|
rows, err = db.Query(statement, domain, path)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
logger.Errorf("cannot get comments: %v", err)
|
|
|
|
return nil, nil, errorInternal
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
commenters := make(map[string]commenter)
|
|
|
|
commenters["anonymous"] = commenter{CommenterHex: "anonymous", Email: "undefined", Name: "Anonymous", Link: "undefined", Photo: "undefined", Provider: "undefined"}
|
|
|
|
|
|
|
|
comments := []comment{}
|
|
|
|
for rows.Next() {
|
|
|
|
c := comment{}
|
|
|
|
if err = rows.Scan(&c.CommentHex, &c.CommenterHex, &c.Markdown, &c.Html, &c.ParentHex, &c.Score, &c.State, &c.CreationDate); err != nil {
|
|
|
|
return nil, nil, errorInternal
|
|
|
|
}
|
|
|
|
|
|
|
|
if commenterHex != "anonymous" {
|
|
|
|
statement = `
|
|
|
|
SELECT direction
|
|
|
|
FROM votes
|
|
|
|
WHERE commentHex=$1 AND commenterHex=$2;
|
|
|
|
`
|
|
|
|
row := db.QueryRow(statement, c.CommentHex, commenterHex)
|
|
|
|
|
2018-06-07 15:39:53 +08:00
|
|
|
if err = row.Scan(&c.Direction); err != nil {
|
2018-05-27 22:40:42 +08:00
|
|
|
// TODO: is the only error here that there is no such entry?
|
2018-06-07 15:39:53 +08:00
|
|
|
c.Direction = 0
|
2018-05-27 22:40:42 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-07 15:40:15 +08:00
|
|
|
if !includeUnapproved {
|
|
|
|
c.State = ""
|
|
|
|
}
|
|
|
|
|
2018-05-27 22:40:42 +08:00
|
|
|
comments = append(comments, c)
|
|
|
|
|
|
|
|
if _, ok := commenters[c.CommenterHex]; !ok {
|
|
|
|
commenters[c.CommenterHex], err = commenterGetByHex(c.CommenterHex)
|
|
|
|
if err != nil {
|
|
|
|
logger.Errorf("cannot retrieve commenter: %v", err)
|
|
|
|
return nil, nil, errorInternal
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return comments, commenters, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func commentListHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
type request struct {
|
2018-06-20 11:29:55 +08:00
|
|
|
CommenterToken *string `json:"CommenterToken"`
|
2018-06-20 11:50:11 +08:00
|
|
|
Domain *string `json:"domain"`
|
|
|
|
Path *string `json:"path"`
|
2018-05-27 22:40:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
var x request
|
2018-07-24 14:58:43 +08:00
|
|
|
if err := bodyUnmarshal(r, &x); err != nil {
|
|
|
|
bodyMarshal(w, response{"success": false, "message": err.Error()})
|
2018-05-27 22:40:42 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-07-24 15:00:45 +08:00
|
|
|
domain := domainStrip(*x.Domain)
|
2018-05-27 22:40:42 +08:00
|
|
|
path := *x.Path
|
|
|
|
|
|
|
|
d, err := domainGet(domain)
|
|
|
|
if err != nil {
|
2018-07-24 14:58:43 +08:00
|
|
|
bodyMarshal(w, response{"success": false, "message": err.Error()})
|
2018-05-27 22:40:42 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-07-05 13:06:52 +08:00
|
|
|
p, err := pageGet(domain, path)
|
|
|
|
if err != nil {
|
|
|
|
bodyMarshal(w, response{"success": false, "message": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-05-27 22:40:42 +08:00
|
|
|
commenterHex := "anonymous"
|
|
|
|
isModerator := false
|
2018-06-20 11:29:55 +08:00
|
|
|
if *x.CommenterToken != "anonymous" {
|
|
|
|
c, err := commenterGetByCommenterToken(*x.CommenterToken)
|
2018-05-27 22:40:42 +08:00
|
|
|
if err != nil {
|
2018-06-20 11:29:55 +08:00
|
|
|
if err == errorNoSuchToken {
|
2018-05-27 22:40:42 +08:00
|
|
|
commenterHex = "anonymous"
|
|
|
|
} else {
|
2018-07-24 14:58:43 +08:00
|
|
|
bodyMarshal(w, response{"success": false, "message": err.Error()})
|
2018-05-27 22:40:42 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
commenterHex = c.CommenterHex
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, mod := range d.Moderators {
|
|
|
|
if mod.Email == c.Email {
|
|
|
|
isModerator = true
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
domainViewRecord(domain, commenterHex)
|
|
|
|
|
|
|
|
comments, commenters, err := commentList(commenterHex, domain, path, isModerator)
|
|
|
|
if err != nil {
|
2018-07-24 14:58:43 +08:00
|
|
|
bodyMarshal(w, response{"success": false, "message": err.Error()})
|
2018-05-27 22:40:42 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-07-24 14:58:43 +08:00
|
|
|
bodyMarshal(w, response{
|
2018-05-27 22:40:42 +08:00
|
|
|
"success": true,
|
|
|
|
"domain": domain,
|
|
|
|
"comments": comments,
|
|
|
|
"commenters": commenters,
|
|
|
|
"requireModeration": d.RequireModeration,
|
|
|
|
"requireIdentification": d.RequireIdentification,
|
|
|
|
"isFrozen": d.State == "frozen",
|
|
|
|
"isModerator": isModerator,
|
2018-07-05 13:06:52 +08:00
|
|
|
"attributes": p,
|
2018-06-11 01:15:56 +08:00
|
|
|
"configuredOauths": configuredOauths,
|
2018-05-27 22:40:42 +08:00
|
|
|
})
|
|
|
|
}
|