2019-07-26 23:29:42 +00:00
|
|
|
package routes
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"net/http"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
c "github.com/Azareal/Gosora/common"
|
2019-08-14 10:39:04 +00:00
|
|
|
p "github.com/Azareal/Gosora/common/phrases"
|
2019-07-26 23:29:42 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func Convos(w http.ResponseWriter, r *http.Request, user c.User, header *c.Header) c.RouteError {
|
|
|
|
accountEditHead("convos", w, r, &user, header)
|
2019-08-14 10:39:04 +00:00
|
|
|
header.AddNotice("convo_dev")
|
2019-07-26 23:29:42 +00:00
|
|
|
ccount := c.Convos.GetUserCount(user.ID)
|
|
|
|
page, _ := strconv.Atoi(r.FormValue("page"))
|
|
|
|
offset, page, lastPage := c.PageOffset(ccount, page, c.Config.ItemsPerPage)
|
|
|
|
pageList := c.Paginate(page, lastPage, 5)
|
|
|
|
|
|
|
|
convos, err := c.Convos.GetUser(user.ID, offset)
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, header)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
pi := c.Account{header, "dashboard", "convos", c.ConvoListPage{header, convos, c.Paginator{pageList, page, lastPage}}}
|
|
|
|
return renderTemplate("account", w, r, header, pi)
|
|
|
|
}
|
|
|
|
|
|
|
|
func Convo(w http.ResponseWriter, r *http.Request, user c.User, header *c.Header, scid string) c.RouteError {
|
|
|
|
accountEditHead("convo", w, r, &user, header)
|
2019-08-14 10:39:04 +00:00
|
|
|
header.AddSheet(header.Theme.Name + "/convo.css")
|
|
|
|
header.AddNotice("convo_dev")
|
2019-07-26 23:29:42 +00:00
|
|
|
cid, err := strconv.Atoi(scid)
|
|
|
|
if err != nil {
|
2019-08-14 10:39:04 +00:00
|
|
|
return c.LocalError(p.GetErrorPhrase("id_must_be_integer"), w, r, user)
|
2019-07-26 23:29:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
convo, err := c.Convos.Get(cid)
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, header)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
pcount := convo.PostsCount()
|
|
|
|
if pcount == 0 {
|
|
|
|
return c.NotFound(w, r, header)
|
|
|
|
}
|
|
|
|
|
|
|
|
page, _ := strconv.Atoi(r.FormValue("page"))
|
|
|
|
offset, page, lastPage := c.PageOffset(pcount, page, c.Config.ItemsPerPage)
|
|
|
|
pageList := c.Paginate(page, lastPage, 5)
|
|
|
|
|
2019-08-14 10:39:04 +00:00
|
|
|
posts, err := convo.Posts(offset, c.Config.ItemsPerPage)
|
2019-07-26 23:29:42 +00:00
|
|
|
// TODO: Report a better error for no posts
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, header)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
2019-08-14 10:39:04 +00:00
|
|
|
pitems := make([]c.ConvoViewRow, len(posts))
|
|
|
|
for i, post := range posts {
|
|
|
|
user, err := c.Users.Get(post.CreatedBy)
|
|
|
|
if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
pitems[i] = c.ConvoViewRow{post, user, "", "4"}
|
|
|
|
}
|
|
|
|
canModify := user.ID == convo.CreatedBy || user.IsSuperMod
|
|
|
|
|
|
|
|
pi := c.Account{header, "dashboard", "convo", c.ConvoViewPage{header, convo, pitems, canModify, c.Paginator{pageList, page, lastPage}}}
|
2019-07-26 23:29:42 +00:00
|
|
|
return renderTemplate("account", w, r, header, pi)
|
|
|
|
}
|
|
|
|
|
|
|
|
func ConvosCreate(w http.ResponseWriter, r *http.Request, user c.User, header *c.Header) c.RouteError {
|
|
|
|
accountEditHead("create_convo", w, r, &user, header)
|
2019-08-14 10:39:04 +00:00
|
|
|
header.AddNotice("convo_dev")
|
2019-07-26 23:29:42 +00:00
|
|
|
recpName := ""
|
|
|
|
pi := c.Account{header, "dashboard", "create_convo", c.ConvoCreatePage{header, recpName}}
|
|
|
|
return renderTemplate("account", w, r, header, pi)
|
|
|
|
}
|
|
|
|
|
|
|
|
func ConvosCreateSubmit(w http.ResponseWriter, r *http.Request, user c.User) c.RouteError {
|
|
|
|
_, ferr := c.SimpleUserCheck(w, r, &user)
|
|
|
|
if ferr != nil {
|
|
|
|
return ferr
|
|
|
|
}
|
|
|
|
|
|
|
|
recps := c.SanitiseSingleLine(r.PostFormValue("recp"))
|
|
|
|
body := c.PreparseMessage(r.PostFormValue("body"))
|
|
|
|
rlist := []int{}
|
|
|
|
max := 10 // max number of recipients that can be added at once
|
|
|
|
for i, recp := range strings.Split(recps, ",") {
|
|
|
|
if i >= max {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
u, err := c.Users.GetByName(recp)
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.LocalError("One of the recipients doesn't exist", w, r, user)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
rlist = append(rlist, u.ID)
|
|
|
|
}
|
|
|
|
|
|
|
|
cid, err := c.Convos.Create(body, user.ID, rlist)
|
|
|
|
if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
http.Redirect(w, r, "/user/convo/"+strconv.Itoa(cid), http.StatusSeeOther)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ConvosDeleteSubmit(w http.ResponseWriter, r *http.Request, user c.User, scid string) c.RouteError {
|
|
|
|
_, ferr := c.SimpleUserCheck(w, r, &user)
|
|
|
|
if ferr != nil {
|
|
|
|
return ferr
|
|
|
|
}
|
|
|
|
cid, err := strconv.Atoi(scid)
|
|
|
|
if err != nil {
|
2019-08-14 10:39:04 +00:00
|
|
|
return c.LocalError(p.GetErrorPhrase("id_must_be_integer"), w, r, user)
|
2019-07-26 23:29:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
err = c.Convos.Delete(cid)
|
|
|
|
if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
http.Redirect(w, r, "/user/convos/", http.StatusSeeOther)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ConvosCreateReplySubmit(w http.ResponseWriter, r *http.Request, user c.User) c.RouteError {
|
|
|
|
_, ferr := c.SimpleUserCheck(w, r, &user)
|
|
|
|
if ferr != nil {
|
|
|
|
return ferr
|
|
|
|
}
|
|
|
|
http.Redirect(w, r, "/user/convo/id", http.StatusSeeOther)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-08-14 10:39:04 +00:00
|
|
|
func ConvosDeleteReplySubmit(w http.ResponseWriter, r *http.Request, user c.User, scpid string) c.RouteError {
|
|
|
|
_, ferr := c.SimpleUserCheck(w, r, &user)
|
|
|
|
if ferr != nil {
|
|
|
|
return ferr
|
|
|
|
}
|
|
|
|
cpid, err := strconv.Atoi(scpid)
|
|
|
|
if err != nil {
|
|
|
|
return c.LocalError(p.GetErrorPhrase("id_must_be_integer"), w, r, user)
|
|
|
|
}
|
|
|
|
|
|
|
|
post := &c.ConversationPost{ID: cpid}
|
|
|
|
err = post.Fetch()
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, nil)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
convo, err := c.Convos.Get(post.CID)
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, nil)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
pcount := convo.PostsCount()
|
|
|
|
if pcount == 0 {
|
|
|
|
return c.NotFound(w, r, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
posts, err := convo.Posts(0, c.Config.ItemsPerPage)
|
|
|
|
// TODO: Report a better error for no posts
|
|
|
|
if err == sql.ErrNoRows {
|
|
|
|
return c.NotFound(w, r, nil)
|
|
|
|
} else if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
if post.ID == posts[0].ID {
|
|
|
|
err = c.Convos.Delete(convo.ID)
|
|
|
|
} else {
|
|
|
|
err = post.Delete()
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return c.InternalError(err, w, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
http.Redirect(w, r, "/user/convo/"+strconv.Itoa(post.CID), http.StatusSeeOther)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ConvosEditReplySubmit(w http.ResponseWriter, r *http.Request, user c.User, scpid string) c.RouteError {
|
2019-07-26 23:29:42 +00:00
|
|
|
_, ferr := c.SimpleUserCheck(w, r, &user)
|
|
|
|
if ferr != nil {
|
|
|
|
return ferr
|
|
|
|
}
|
|
|
|
http.Redirect(w, r, "/user/convo/id", http.StatusSeeOther)
|
|
|
|
return nil
|
2019-08-14 10:39:04 +00:00
|
|
|
}
|