2016-08-03 19:24:16 +03:00
// 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 (
2016-11-11 12:39:44 +03:00
api "code.gitea.io/sdk/gitea"
2016-08-03 19:24:16 +03:00
2016-11-10 19:24:48 +03:00
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
2016-08-03 19:24:16 +03:00
)
2016-11-24 10:04:31 +03:00
// ListIssueLabels list all the labels of an issue
2016-08-03 21:51:22 +03:00
func ListIssueLabels ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation GET /repos/{owner}/{repo}/issues/{index}/labels issue issueGetLabels
// ---
// summary: Get an issue's labels
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo
// type: string
// required: true
// - name: index
// in: path
// description: index of the issue
// type: integer
// required: true
// responses:
// "200":
// "$ref": "#/responses/LabelList"
// "404":
// "$ref": "#/responses/notFound"
2016-08-03 19:24:16 +03:00
issue , err := models . GetIssueByIndex ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":index" ) )
if err != nil {
if models . IsErrIssueNotExist ( err ) {
ctx . Status ( 404 )
} else {
ctx . Error ( 500 , "GetIssueByIndex" , err )
}
return
}
apiLabels := make ( [ ] * api . Label , len ( issue . Labels ) )
for i := range issue . Labels {
2016-08-14 14:17:26 +03:00
apiLabels [ i ] = issue . Labels [ i ] . APIFormat ( )
2016-08-03 19:24:16 +03:00
}
ctx . JSON ( 200 , & apiLabels )
}
2016-11-24 10:04:31 +03:00
// AddIssueLabels add labels for an issue
2016-08-03 19:24:16 +03:00
func AddIssueLabels ( ctx * context . APIContext , form api . IssueLabelsOption ) {
2017-11-13 10:02:25 +03:00
// swagger:operation POST /repos/{owner}/{repo}/issue/{index}/labels issue issueAddLabel
// ---
// summary: Add a label to an issue
// consumes:
// - application/json
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo
// type: string
// required: true
// - name: index
// in: path
// description: index of the issue
// type: integer
// required: true
// - name: body
// in: body
// schema:
// "$ref": "#/definitions/IssueLabelsOption"
// responses:
// "200":
// "$ref": "#/responses/LabelList"
2016-08-03 19:24:16 +03:00
if ! ctx . Repo . IsWriter ( ) {
ctx . Status ( 403 )
return
}
issue , err := models . GetIssueByIndex ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":index" ) )
if err != nil {
if models . IsErrIssueNotExist ( err ) {
ctx . Status ( 404 )
} else {
ctx . Error ( 500 , "GetIssueByIndex" , err )
}
return
}
2016-08-03 21:51:22 +03:00
labels , err := models . GetLabelsInRepoByIDs ( ctx . Repo . Repository . ID , form . Labels )
if err != nil {
ctx . Error ( 500 , "GetLabelsInRepoByIDs" , err )
2016-08-03 19:24:16 +03:00
return
}
2016-08-14 13:32:24 +03:00
if err = issue . AddLabels ( ctx . User , labels ) ; err != nil {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "AddLabels" , err )
return
2016-08-03 19:24:16 +03:00
}
2016-08-03 21:51:22 +03:00
labels , err = models . GetLabelsByIssueID ( issue . ID )
2016-08-03 19:24:16 +03:00
if err != nil {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "GetLabelsByIssueID" , err )
2016-08-03 19:24:16 +03:00
return
}
2016-08-03 21:51:22 +03:00
apiLabels := make ( [ ] * api . Label , len ( labels ) )
for i := range labels {
2017-06-25 02:52:51 +03:00
apiLabels [ i ] = labels [ i ] . APIFormat ( )
2016-08-03 19:24:16 +03:00
}
ctx . JSON ( 200 , & apiLabels )
}
2016-11-24 10:04:31 +03:00
// DeleteIssueLabel delete a label for an issue
2016-08-03 21:51:22 +03:00
func DeleteIssueLabel ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation DELETE /repos/{owner}/{repo}/issue/{index}/labels/{id} issue issueRemoveLabel
// ---
// summary: Remove a label from an issue
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo
// type: string
// required: true
// - name: index
// in: path
// description: index of the issue
// type: integer
// required: true
// - name: id
// in: path
// description: id of the label to remove
// type: integer
// required: true
// responses:
// "204":
// "$ref": "#/responses/empty"
2016-08-03 19:24:16 +03:00
if ! ctx . Repo . IsWriter ( ) {
ctx . Status ( 403 )
return
}
issue , err := models . GetIssueByIndex ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":index" ) )
if err != nil {
if models . IsErrIssueNotExist ( err ) {
ctx . Status ( 404 )
} else {
ctx . Error ( 500 , "GetIssueByIndex" , err )
}
return
}
2016-08-03 21:51:22 +03:00
label , err := models . GetLabelInRepoByID ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":id" ) )
2016-08-03 19:24:16 +03:00
if err != nil {
2016-08-03 21:51:22 +03:00
if models . IsErrLabelNotExist ( err ) {
ctx . Error ( 422 , "" , err )
2016-08-03 19:24:16 +03:00
} else {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "GetLabelInRepoByID" , err )
2016-08-03 19:24:16 +03:00
}
return
}
2017-02-01 04:31:35 +03:00
if err := models . DeleteIssueLabel ( issue , label , ctx . User ) ; err != nil {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "DeleteIssueLabel" , err )
return
2016-08-03 19:24:16 +03:00
}
2016-08-03 21:51:22 +03:00
ctx . Status ( 204 )
2016-08-03 19:24:16 +03:00
}
2016-11-24 10:04:31 +03:00
// ReplaceIssueLabels replace labels for an issue
2016-08-03 21:51:22 +03:00
func ReplaceIssueLabels ( ctx * context . APIContext , form api . IssueLabelsOption ) {
2017-11-13 10:02:25 +03:00
// swagger:operation PUT /repos/{owner}/{repo}/issue/{index}/labels issue issueReplaceLabels
// ---
// summary: Replace an issue's labels
// consumes:
// - application/json
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo
// type: string
// required: true
// - name: index
// in: path
// description: index of the issue
// type: integer
// required: true
// - name: body
// in: body
// schema:
// "$ref": "#/definitions/IssueLabelsOption"
// responses:
// "200":
// "$ref": "#/responses/LabelList"
2016-08-03 19:24:16 +03:00
if ! ctx . Repo . IsWriter ( ) {
ctx . Status ( 403 )
return
}
issue , err := models . GetIssueByIndex ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":index" ) )
if err != nil {
if models . IsErrIssueNotExist ( err ) {
ctx . Status ( 404 )
} else {
ctx . Error ( 500 , "GetIssueByIndex" , err )
}
return
}
2016-08-03 21:51:22 +03:00
labels , err := models . GetLabelsInRepoByIDs ( ctx . Repo . Repository . ID , form . Labels )
2016-08-03 19:24:16 +03:00
if err != nil {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "GetLabelsInRepoByIDs" , err )
2016-08-03 19:24:16 +03:00
return
}
2017-01-30 15:46:45 +03:00
if err := issue . ReplaceLabels ( labels , ctx . User ) ; err != nil {
2016-08-03 21:51:22 +03:00
ctx . Error ( 500 , "ReplaceLabels" , err )
2016-08-03 19:24:16 +03:00
return
}
2016-08-03 21:51:22 +03:00
labels , err = models . GetLabelsByIssueID ( issue . ID )
if err != nil {
ctx . Error ( 500 , "GetLabelsByIssueID" , err )
return
}
apiLabels := make ( [ ] * api . Label , len ( labels ) )
for i := range labels {
2017-06-25 02:52:51 +03:00
apiLabels [ i ] = labels [ i ] . APIFormat ( )
2016-08-03 21:51:22 +03:00
}
ctx . JSON ( 200 , & apiLabels )
2016-08-03 19:24:16 +03:00
}
2016-11-24 10:04:31 +03:00
// ClearIssueLabels delete all the labels for an issue
2016-08-03 19:24:16 +03:00
func ClearIssueLabels ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation DELETE /repos/{owner}/{repo}/issue/{index}/labels issue issueClearLabels
// ---
// summary: Remove all labels from an issue
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo
// type: string
// required: true
// - name: index
// in: path
// description: index of the issue
// type: integer
// required: true
// responses:
// "204":
// "$ref": "#/responses/empty"
2016-08-03 19:24:16 +03:00
if ! ctx . Repo . IsWriter ( ) {
ctx . Status ( 403 )
return
}
issue , err := models . GetIssueByIndex ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":index" ) )
if err != nil {
if models . IsErrIssueNotExist ( err ) {
ctx . Status ( 404 )
} else {
ctx . Error ( 500 , "GetIssueByIndex" , err )
}
return
}
2016-08-14 13:32:24 +03:00
if err := issue . ClearLabels ( ctx . User ) ; err != nil {
2016-08-03 19:24:16 +03:00
ctx . Error ( 500 , "ClearLabels" , err )
return
}
ctx . Status ( 204 )
}