From 01c8df01ec0608f1f25b2f1444adabb98fa5ee8a Mon Sep 17 00:00:00 2001 From: Unknwon Date: Thu, 24 Oct 2019 01:51:46 -0700 Subject: internal: move packages under this directory (#5836) * Rename pkg -> internal * Rename routes -> route * Move route -> internal/route * Rename models -> db * Move db -> internal/db * Fix route2 -> route * Move cmd -> internal/cmd * Bump version --- internal/route/api/v1/repo/issue_comment.go | 131 ++++++++++++++++++++++++++++ 1 file changed, 131 insertions(+) create mode 100644 internal/route/api/v1/repo/issue_comment.go (limited to 'internal/route/api/v1/repo/issue_comment.go') diff --git a/internal/route/api/v1/repo/issue_comment.go b/internal/route/api/v1/repo/issue_comment.go new file mode 100644 index 00000000..4f86e13b --- /dev/null +++ b/internal/route/api/v1/repo/issue_comment.go @@ -0,0 +1,131 @@ +// Copyright 2015 The Gogs Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. +package repo + +import ( + "net/http" + "time" + + api "github.com/gogs/go-gogs-client" + + "gogs.io/gogs/internal/context" + "gogs.io/gogs/internal/db" +) + +func ListIssueComments(c *context.APIContext) { + var since time.Time + if len(c.Query("since")) > 0 { + var err error + since, err = time.Parse(time.RFC3339, c.Query("since")) + if err != nil { + c.Error(http.StatusUnprocessableEntity, "", err) + return + } + } + + // comments,err:=db.GetCommentsByIssueIDSince(, since) + issue, err := db.GetRawIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index")) + if err != nil { + c.ServerError("GetRawIssueByIndex", err) + return + } + + comments, err := db.GetCommentsByIssueIDSince(issue.ID, since.Unix()) + if err != nil { + c.ServerError("GetCommentsByIssueIDSince", err) + return + } + + apiComments := make([]*api.Comment, len(comments)) + for i := range comments { + apiComments[i] = comments[i].APIFormat() + } + c.JSONSuccess(&apiComments) +} + +func ListRepoIssueComments(c *context.APIContext) { + var since time.Time + if len(c.Query("since")) > 0 { + var err error + since, err = time.Parse(time.RFC3339, c.Query("since")) + if err != nil { + c.Error(http.StatusUnprocessableEntity, "", err) + return + } + } + + comments, err := db.GetCommentsByRepoIDSince(c.Repo.Repository.ID, since.Unix()) + if err != nil { + c.ServerError("GetCommentsByRepoIDSince", err) + return + } + + apiComments := make([]*api.Comment, len(comments)) + for i := range comments { + apiComments[i] = comments[i].APIFormat() + } + c.JSONSuccess(&apiComments) +} + +func CreateIssueComment(c *context.APIContext, form api.CreateIssueCommentOption) { + issue, err := db.GetIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index")) + if err != nil { + c.ServerError("GetIssueByIndex", err) + return + } + + comment, err := db.CreateIssueComment(c.User, c.Repo.Repository, issue, form.Body, nil) + if err != nil { + c.ServerError("CreateIssueComment", err) + return + } + + c.JSON(http.StatusCreated, comment.APIFormat()) +} + +func EditIssueComment(c *context.APIContext, form api.EditIssueCommentOption) { + comment, err := db.GetCommentByID(c.ParamsInt64(":id")) + if err != nil { + c.NotFoundOrServerError("GetCommentByID", db.IsErrCommentNotExist, err) + return + } + + if c.User.ID != comment.PosterID && !c.Repo.IsAdmin() { + c.Status(http.StatusForbidden) + return + } else if comment.Type != db.COMMENT_TYPE_COMMENT { + c.NoContent() + return + } + + oldContent := comment.Content + comment.Content = form.Body + if err := db.UpdateComment(c.User, comment, oldContent); err != nil { + c.ServerError("UpdateComment", err) + return + } + c.JSONSuccess(comment.APIFormat()) +} + +func DeleteIssueComment(c *context.APIContext) { + comment, err := db.GetCommentByID(c.ParamsInt64(":id")) + if err != nil { + c.NotFoundOrServerError("GetCommentByID", db.IsErrCommentNotExist, err) + return + } + + if c.User.ID != comment.PosterID && !c.Repo.IsAdmin() { + c.Status(http.StatusForbidden) + return + } else if comment.Type != db.COMMENT_TYPE_COMMENT { + c.NoContent() + return + } + + if err = db.DeleteCommentByID(c.User, comment.ID); err != nil { + c.ServerError("DeleteCommentByID", err) + return + } + c.NoContent() +} -- cgit v1.2.3