diff options
author | Unknwon <u@gogs.io> | 2017-06-11 00:34:14 -0400 |
---|---|---|
committer | Unknwon <u@gogs.io> | 2017-06-11 00:34:14 -0400 |
commit | 4400d2fdd933204044aeb18ce7d8613c53aa87c0 (patch) | |
tree | 841e91d5294c49b7335170fbc4b9ff79e882f91a /routes/api/v1/repo/issue_comment.go | |
parent | 6197a7639a88f7fb0fee8927e1d501504ae770ff (diff) |
Refactoring: rename package routers -> routes
Diffstat (limited to 'routes/api/v1/repo/issue_comment.go')
-rw-r--r-- | routes/api/v1/repo/issue_comment.go | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/routes/api/v1/repo/issue_comment.go b/routes/api/v1/repo/issue_comment.go new file mode 100644 index 00000000..4a057d76 --- /dev/null +++ b/routes/api/v1/repo/issue_comment.go @@ -0,0 +1,128 @@ +// 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 ( + "time" + + api "github.com/gogits/go-gogs-client" + + "github.com/gogits/gogs/models" + "github.com/gogits/gogs/pkg/context" +) + +func ListIssueComments(c *context.APIContext) { + var since time.Time + if len(c.Query("since")) > 0 { + since, _ = time.Parse(time.RFC3339, c.Query("since")) + } + + // comments,err:=models.GetCommentsByIssueIDSince(, since) + issue, err := models.GetRawIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index")) + if err != nil { + c.Error(500, "GetRawIssueByIndex", err) + return + } + + comments, err := models.GetCommentsByIssueIDSince(issue.ID, since.Unix()) + if err != nil { + c.Error(500, "GetCommentsByIssueIDSince", err) + return + } + + apiComments := make([]*api.Comment, len(comments)) + for i := range comments { + apiComments[i] = comments[i].APIFormat() + } + c.JSON(200, &apiComments) +} + +func ListRepoIssueComments(c *context.APIContext) { + var since time.Time + if len(c.Query("since")) > 0 { + since, _ = time.Parse(time.RFC3339, c.Query("since")) + } + + comments, err := models.GetCommentsByRepoIDSince(c.Repo.Repository.ID, since.Unix()) + if err != nil { + c.Error(500, "GetCommentsByRepoIDSince", err) + return + } + + apiComments := make([]*api.Comment, len(comments)) + for i := range comments { + apiComments[i] = comments[i].APIFormat() + } + c.JSON(200, &apiComments) +} + +func CreateIssueComment(c *context.APIContext, form api.CreateIssueCommentOption) { + issue, err := models.GetIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index")) + if err != nil { + c.Error(500, "GetIssueByIndex", err) + return + } + + comment, err := models.CreateIssueComment(c.User, c.Repo.Repository, issue, form.Body, nil) + if err != nil { + c.Error(500, "CreateIssueComment", err) + return + } + + c.JSON(201, comment.APIFormat()) +} + +func EditIssueComment(c *context.APIContext, form api.EditIssueCommentOption) { + comment, err := models.GetCommentByID(c.ParamsInt64(":id")) + if err != nil { + if models.IsErrCommentNotExist(err) { + c.Error(404, "GetCommentByID", err) + } else { + c.Error(500, "GetCommentByID", err) + } + return + } + + if c.User.ID != comment.PosterID && !c.Repo.IsAdmin() { + c.Status(403) + return + } else if comment.Type != models.COMMENT_TYPE_COMMENT { + c.Status(204) + return + } + + oldContent := comment.Content + comment.Content = form.Body + if err := models.UpdateComment(c.User, comment, oldContent); err != nil { + c.Error(500, "UpdateComment", err) + return + } + c.JSON(200, comment.APIFormat()) +} + +func DeleteIssueComment(c *context.APIContext) { + comment, err := models.GetCommentByID(c.ParamsInt64(":id")) + if err != nil { + if models.IsErrCommentNotExist(err) { + c.Error(404, "GetCommentByID", err) + } else { + c.Error(500, "GetCommentByID", err) + } + return + } + + if c.User.ID != comment.PosterID && !c.Repo.IsAdmin() { + c.Status(403) + return + } else if comment.Type != models.COMMENT_TYPE_COMMENT { + c.Status(204) + return + } + + if err = models.DeleteCommentByID(c.User, comment.ID); err != nil { + c.Error(500, "DeleteCommentByID", err) + return + } + c.Status(204) +} |