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.go53
1 files changed, 23 insertions, 30 deletions
diff --git a/routes/api/v1/repo/issue.go b/routes/api/v1/repo/issue.go
index 47268175..a3cc02ee 100644
--- a/routes/api/v1/repo/issue.go
+++ b/routes/api/v1/repo/issue.go
@@ -6,6 +6,7 @@ package repo
import (
"fmt"
+ "net/http"
"strings"
api "github.com/gogs/go-gogs-client"
@@ -19,13 +20,13 @@ import (
func listIssues(c *context.APIContext, opts *models.IssuesOptions) {
issues, err := models.Issues(opts)
if err != nil {
- c.Error(500, "Issues", err)
+ c.ServerError("Issues", err)
return
}
count, err := models.IssuesCount(opts)
if err != nil {
- c.Error(500, "IssuesCount", err)
+ c.ServerError("IssuesCount", err)
return
}
@@ -33,14 +34,14 @@ func listIssues(c *context.APIContext, opts *models.IssuesOptions) {
apiIssues := make([]*api.Issue, len(issues))
for i := range issues {
if err = issues[i].LoadAttributes(); err != nil {
- c.Error(500, "LoadAttributes", err)
+ c.ServerError("LoadAttributes", err)
return
}
apiIssues[i] = issues[i].APIFormat()
}
c.SetLinkHeader(int(count), setting.UI.IssuePagingNum)
- c.JSON(200, &apiIssues)
+ c.JSONSuccess(&apiIssues)
}
func ListUserIssues(c *context.APIContext) {
@@ -66,14 +67,10 @@ func ListIssues(c *context.APIContext) {
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)
- }
+ c.NotFoundOrServerError("GetIssueByIndex", errors.IsIssueNotExist, err)
return
}
- c.JSON(200, issue.APIFormat())
+ c.JSONSuccess(issue.APIFormat())
}
func CreateIssue(c *context.APIContext, form api.CreateIssueOption) {
@@ -90,9 +87,9 @@ func CreateIssue(c *context.APIContext, form api.CreateIssueOption) {
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))
+ c.Error(http.StatusUnprocessableEntity, "", fmt.Sprintf("assignee does not exist: [name: %s]", form.Assignee))
} else {
- c.Error(500, "GetUserByName", err)
+ c.ServerError("GetUserByName", err)
}
return
}
@@ -104,13 +101,13 @@ func CreateIssue(c *context.APIContext, form api.CreateIssueOption) {
}
if err := models.NewIssue(c.Repo.Repository, issue, form.Labels, nil); err != nil {
- c.Error(500, "NewIssue", err)
+ c.ServerError("NewIssue", err)
return
}
if form.Closed {
if err := issue.ChangeStatus(c.User, c.Repo.Repository, true); err != nil {
- c.Error(500, "ChangeStatus", err)
+ c.ServerError("ChangeStatus", err)
return
}
}
@@ -119,25 +116,21 @@ func CreateIssue(c *context.APIContext, form api.CreateIssueOption) {
var err error
issue, err = models.GetIssueByID(issue.ID)
if err != nil {
- c.Error(500, "GetIssueByID", err)
+ c.ServerError("GetIssueByID", err)
return
}
- c.JSON(201, issue.APIFormat())
+ c.JSON(http.StatusCreated, 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)
- }
+ c.NotFoundOrServerError("GetIssueByIndex", errors.IsIssueNotExist, err)
return
}
if !issue.IsPoster(c.User.ID) && !c.Repo.IsWriter() {
- c.Status(403)
+ c.Status(http.StatusForbidden)
return
}
@@ -156,9 +149,9 @@ func EditIssue(c *context.APIContext, form api.EditIssueOption) {
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))
+ c.Error(http.StatusUnprocessableEntity, "", fmt.Sprintf("assignee does not exist: [name: %s]", *form.Assignee))
} else {
- c.Error(500, "GetUserByName", err)
+ c.ServerError("GetUserByName", err)
}
return
}
@@ -166,7 +159,7 @@ func EditIssue(c *context.APIContext, form api.EditIssueOption) {
}
if err = models.UpdateIssueUserByAssignee(issue); err != nil {
- c.Error(500, "UpdateIssueUserByAssignee", err)
+ c.ServerError("UpdateIssueUserByAssignee", err)
return
}
}
@@ -175,18 +168,18 @@ func EditIssue(c *context.APIContext, form api.EditIssueOption) {
oldMilestoneID := issue.MilestoneID
issue.MilestoneID = *form.Milestone
if err = models.ChangeMilestoneAssign(c.User, issue, oldMilestoneID); err != nil {
- c.Error(500, "ChangeMilestoneAssign", err)
+ c.ServerError("ChangeMilestoneAssign", err)
return
}
}
if err = models.UpdateIssue(issue); err != nil {
- c.Error(500, "UpdateIssue", err)
+ c.ServerError("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)
+ c.ServerError("ChangeStatus", err)
return
}
}
@@ -194,8 +187,8 @@ func EditIssue(c *context.APIContext, form api.EditIssueOption) {
// Refetch from database to assign some automatic values
issue, err = models.GetIssueByID(issue.ID)
if err != nil {
- c.Error(500, "GetIssueByID", err)
+ c.ServerError("GetIssueByID", err)
return
}
- c.JSON(201, issue.APIFormat())
+ c.JSON(http.StatusCreated, issue.APIFormat())
}