You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

158 lines
3.4 KiB

package api
import (
"fmt"
"net/http"
"strings"
"github.com/gin-gonic/gin"
"github.com/imdotdev/im.dev/server/internal/interaction"
"github.com/imdotdev/im.dev/server/internal/story"
"github.com/imdotdev/im.dev/server/internal/user"
"github.com/imdotdev/im.dev/server/pkg/common"
"github.com/imdotdev/im.dev/server/pkg/e"
"github.com/imdotdev/im.dev/server/pkg/models"
"github.com/imdotdev/im.dev/server/pkg/utils"
)
func SubmitComment(c *gin.Context) {
comment := &models.Comment{}
c.Bind(&comment)
comment.Md = strings.TrimSpace(comment.Md)
if comment.Md == "" {
c.JSON(http.StatusBadRequest, "评论内容不能为空")
return
}
// check story exist
exist := models.IdExist(comment.TargetID)
if !exist {
c.JSON(http.StatusNotFound, common.RespError(e.NotFound))
return
}
var err *e.Error
if comment.ID == "" { //add comment
user := user.CurrentUser(c)
comment.CreatorID = user.ID
comment.ID = utils.GenID(models.IDTypeComment)
err = story.AddComment(comment)
} else { // update comment
err = story.EditComment(comment)
}
if err != nil {
c.JSON(err.Status, common.RespError(err.Message))
return
}
c.JSON(http.StatusOK, common.RespSuccess(nil))
}
func GetStoryComments(c *gin.Context) {
storyID := c.Param("id")
sorter := c.Query("sorter")
if !models.ValidSearchFilter(sorter) {
c.JSON(http.StatusBadRequest, e.ParamInvalid)
return
}
comments, err := story.GetComments(storyID, sorter)
if err != nil {
c.JSON(err.Status, common.RespError(err.Message))
return
}
user := user.CurrentUser(c)
for _, comment := range comments {
if user != nil {
comment.Liked = interaction.GetLiked(comment.ID, user.ID)
}
replies, err := story.GetComments(comment.ID, sorter)
if err != nil {
continue
}
comment.Replies = replies
for _, reply := range replies {
if user != nil {
reply.Liked = interaction.GetLiked(reply.ID, user.ID)
}
}
}
c.JSON(http.StatusOK, common.RespSuccess(comments))
}
func GetStoryComment(c *gin.Context) {
id := c.Param("id")
comment, err := story.GetComment(id)
if err != nil {
c.JSON(err.Status, common.RespError(err.Message))
return
}
comment.Creator = &models.UserSimple{
ID: comment.CreatorID,
}
comment.Creator.Query()
c.JSON(http.StatusOK, common.RespSuccess(comment))
}
func DeleteStoryComment(c *gin.Context) {
id := c.Param("id")
//only admin and owner can delete comment
comment, err := story.GetComment(id)
if err != nil {
c.JSON(err.Status, common.RespError(err.Message))
return
}
user := user.CurrentUser(c)
canDel := false
if user.Role.IsAdmin() {
canDel = true
} else {
if user.ID == comment.CreatorID {
canDel = true
}
}
if !canDel {
c.JSON(http.StatusForbidden, common.RespError(e.NoPermission))
return
}
err = story.DeleteComment(id)
if err != nil {
c.JSON(err.Status, common.RespError(err.Message))
return
}
c.JSON(http.StatusOK, common.RespSuccess(nil))
}
func GetStoryIDByCommentID(c *gin.Context) {
cid := c.Param("cid")
id, _, err := story.GetStoryIDByCommentID(cid)
if err != nil {
c.JSON(http.StatusInternalServerError, common.RespError(e.Internal))
return
}
creatorID, err1 := story.GetPostCreator(id)
if err1 != nil {
c.JSON(err1.Status, common.RespError(err1.Message))
return
}
creator := &models.UserSimple{ID: creatorID}
creator.Query()
c.JSON(http.StatusOK, common.RespSuccess(fmt.Sprintf("/%s/%s", creator.Username, id)))
}