aboutsummaryrefslogtreecommitdiff
path: root/routes/api/v1/repo/issue.go
diff options
context:
space:
mode:
Diffstat (limited to 'routes/api/v1/repo/issue.go')
-rw-r--r--routes/api/v1/repo/issue.go201
1 files changed, 201 insertions, 0 deletions
diff --git a/routes/api/v1/repo/issue.go b/routes/api/v1/repo/issue.go
new file mode 100644
index 00000000..d6ae7b4d
--- /dev/null
+++ b/routes/api/v1/repo/issue.go
@@ -0,0 +1,201 @@
+// Copyright 2016 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 (
+ "fmt"
+ "strings"
+
+ api "github.com/gogits/go-gogs-client"
+
+ "github.com/gogits/gogs/models"
+ "github.com/gogits/gogs/models/errors"
+ "github.com/gogits/gogs/pkg/context"
+ "github.com/gogits/gogs/pkg/setting"
+)
+
+func listIssues(c *context.APIContext, opts *models.IssuesOptions) {
+ issues, err := models.Issues(opts)
+ if err != nil {
+ c.Error(500, "Issues", err)
+ return
+ }
+
+ count, err := models.IssuesCount(opts)
+ if err != nil {
+ c.Error(500, "IssuesCount", err)
+ return
+ }
+
+ // FIXME: use IssueList to improve performance.
+ apiIssues := make([]*api.Issue, len(issues))
+ for i := range issues {
+ if err = issues[i].LoadAttributes(); err != nil {
+ c.Error(500, "LoadAttributes", err)
+ return
+ }
+ apiIssues[i] = issues[i].APIFormat()
+ }
+
+ c.SetLinkHeader(int(count), setting.UI.IssuePagingNum)
+ c.JSON(200, &apiIssues)
+}
+
+func ListUserIssues(c *context.APIContext) {
+ opts := models.IssuesOptions{
+ AssigneeID: c.User.ID,
+ Page: c.QueryInt("page"),
+ IsClosed: api.StateType(c.Query("state")) == api.STATE_CLOSED,
+ }
+
+ listIssues(c, &opts)
+}
+
+func ListIssues(c *context.APIContext) {
+ opts := models.IssuesOptions{
+ RepoID: c.Repo.Repository.ID,
+ Page: c.QueryInt("page"),
+ IsClosed: api.StateType(c.Query("state")) == api.STATE_CLOSED,
+ }
+
+ listIssues(c, &opts)
+}
+
+func GetIssue(c *context.APIContext) {
+ issue, err := models.GetIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index"))
+ if err != nil {
+ if errors.IsIssueNotExist(err) {
+ c.Status(404)
+ } else {
+ c.Error(500, "GetIssueByIndex", err)
+ }
+ return
+ }
+ c.JSON(200, issue.APIFormat())
+}
+
+func CreateIssue(c *context.APIContext, form api.CreateIssueOption) {
+ issue := &models.Issue{
+ RepoID: c.Repo.Repository.ID,
+ Title: form.Title,
+ PosterID: c.User.ID,
+ Poster: c.User,
+ Content: form.Body,
+ }
+
+ if c.Repo.IsWriter() {
+ if len(form.Assignee) > 0 {
+ assignee, err := models.GetUserByName(form.Assignee)
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", fmt.Sprintf("Assignee does not exist: [name: %s]", form.Assignee))
+ } else {
+ c.Error(500, "GetUserByName", err)
+ }
+ return
+ }
+ issue.AssigneeID = assignee.ID
+ }
+ issue.MilestoneID = form.Milestone
+ } else {
+ form.Labels = nil
+ }
+
+ if err := models.NewIssue(c.Repo.Repository, issue, form.Labels, nil); err != nil {
+ c.Error(500, "NewIssue", err)
+ return
+ }
+
+ if form.Closed {
+ if err := issue.ChangeStatus(c.User, c.Repo.Repository, true); err != nil {
+ c.Error(500, "ChangeStatus", err)
+ return
+ }
+ }
+
+ // Refetch from database to assign some automatic values
+ var err error
+ issue, err = models.GetIssueByID(issue.ID)
+ if err != nil {
+ c.Error(500, "GetIssueByID", err)
+ return
+ }
+ c.JSON(201, issue.APIFormat())
+}
+
+func EditIssue(c *context.APIContext, form api.EditIssueOption) {
+ issue, err := models.GetIssueByIndex(c.Repo.Repository.ID, c.ParamsInt64(":index"))
+ if err != nil {
+ if errors.IsIssueNotExist(err) {
+ c.Status(404)
+ } else {
+ c.Error(500, "GetIssueByIndex", err)
+ }
+ return
+ }
+
+ if !issue.IsPoster(c.User.ID) && !c.Repo.IsWriter() {
+ c.Status(403)
+ return
+ }
+
+ if len(form.Title) > 0 {
+ issue.Title = form.Title
+ }
+ if form.Body != nil {
+ issue.Content = *form.Body
+ }
+
+ if c.Repo.IsWriter() && form.Assignee != nil &&
+ (issue.Assignee == nil || issue.Assignee.LowerName != strings.ToLower(*form.Assignee)) {
+ if len(*form.Assignee) == 0 {
+ issue.AssigneeID = 0
+ } else {
+ assignee, err := models.GetUserByName(*form.Assignee)
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", fmt.Sprintf("assignee does not exist: [name: %s]", *form.Assignee))
+ } else {
+ c.Error(500, "GetUserByName", err)
+ }
+ return
+ }
+ issue.AssigneeID = assignee.ID
+ }
+
+ if err = models.UpdateIssueUserByAssignee(issue); err != nil {
+ c.Error(500, "UpdateIssueUserByAssignee", err)
+ return
+ }
+ }
+ if c.Repo.IsWriter() && form.Milestone != nil &&
+ issue.MilestoneID != *form.Milestone {
+ oldMilestoneID := issue.MilestoneID
+ issue.MilestoneID = *form.Milestone
+ if err = models.ChangeMilestoneAssign(c.User, issue, oldMilestoneID); err != nil {
+ c.Error(500, "ChangeMilestoneAssign", err)
+ return
+ }
+ }
+
+ if err = models.UpdateIssue(issue); err != nil {
+ c.Error(500, "UpdateIssue", err)
+ return
+ }
+ if form.State != nil {
+ if err = issue.ChangeStatus(c.User, c.Repo.Repository, api.STATE_CLOSED == api.StateType(*form.State)); err != nil {
+ c.Error(500, "ChangeStatus", err)
+ return
+ }
+ }
+
+ // Refetch from database to assign some automatic values
+ issue, err = models.GetIssueByID(issue.ID)
+ if err != nil {
+ c.Error(500, "GetIssueByID", err)
+ return
+ }
+ c.JSON(201, issue.APIFormat())
+}