2016-08-03 09:24:16 -07: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-10 17:24:48 +01:00
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
2018-03-29 21:32:40 +08:00
api "code.gitea.io/sdk/gitea"
2016-08-03 09:24:16 -07:00
)
2016-11-24 15:04:31 +08:00
// ListIssueLabels list all the labels of an issue
2016-08-03 11:51:22 -07:00
func ListIssueLabels ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08: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 09:24:16 -07: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 04:17:26 -07:00
apiLabels [ i ] = issue . Labels [ i ] . APIFormat ( )
2016-08-03 09:24:16 -07:00
}
ctx . JSON ( 200 , & apiLabels )
}
2016-11-24 15:04:31 +08:00
// AddIssueLabels add labels for an issue
2016-08-03 09:24:16 -07:00
func AddIssueLabels ( ctx * context . APIContext , form api . IssueLabelsOption ) {
2018-05-08 08:05:18 +02:00
// swagger:operation POST /repos/{owner}/{repo}/issues/{index}/labels issue issueAddLabel
2017-11-12 23:02:25 -08:00
// ---
// 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 09:24:16 -07: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 11:51:22 -07:00
labels , err := models . GetLabelsInRepoByIDs ( ctx . Repo . Repository . ID , form . Labels )
if err != nil {
ctx . Error ( 500 , "GetLabelsInRepoByIDs" , err )
2016-08-03 09:24:16 -07:00
return
}
2016-08-14 03:32:24 -07:00
if err = issue . AddLabels ( ctx . User , labels ) ; err != nil {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "AddLabels" , err )
return
2016-08-03 09:24:16 -07:00
}
2016-08-03 11:51:22 -07:00
labels , err = models . GetLabelsByIssueID ( issue . ID )
2016-08-03 09:24:16 -07:00
if err != nil {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "GetLabelsByIssueID" , err )
2016-08-03 09:24:16 -07:00
return
}
2016-08-03 11:51:22 -07:00
apiLabels := make ( [ ] * api . Label , len ( labels ) )
for i := range labels {
2017-06-24 19:52:51 -04:00
apiLabels [ i ] = labels [ i ] . APIFormat ( )
2016-08-03 09:24:16 -07:00
}
ctx . JSON ( 200 , & apiLabels )
}
2016-11-24 15:04:31 +08:00
// DeleteIssueLabel delete a label for an issue
2016-08-03 11:51:22 -07:00
func DeleteIssueLabel ( ctx * context . APIContext ) {
2018-05-08 08:05:18 +02:00
// swagger:operation DELETE /repos/{owner}/{repo}/issues/{index}/labels/{id} issue issueRemoveLabel
2017-11-12 23:02:25 -08:00
// ---
// 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 09:24:16 -07: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 11:51:22 -07:00
label , err := models . GetLabelInRepoByID ( ctx . Repo . Repository . ID , ctx . ParamsInt64 ( ":id" ) )
2016-08-03 09:24:16 -07:00
if err != nil {
2016-08-03 11:51:22 -07:00
if models . IsErrLabelNotExist ( err ) {
ctx . Error ( 422 , "" , err )
2016-08-03 09:24:16 -07:00
} else {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "GetLabelInRepoByID" , err )
2016-08-03 09:24:16 -07:00
}
return
}
2017-01-31 20:31:35 -05:00
if err := models . DeleteIssueLabel ( issue , label , ctx . User ) ; err != nil {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "DeleteIssueLabel" , err )
return
2016-08-03 09:24:16 -07:00
}
2016-08-03 11:51:22 -07:00
ctx . Status ( 204 )
2016-08-03 09:24:16 -07:00
}
2016-11-24 15:04:31 +08:00
// ReplaceIssueLabels replace labels for an issue
2016-08-03 11:51:22 -07:00
func ReplaceIssueLabels ( ctx * context . APIContext , form api . IssueLabelsOption ) {
2018-05-08 08:05:18 +02:00
// swagger:operation PUT /repos/{owner}/{repo}/issues/{index}/labels issue issueReplaceLabels
2017-11-12 23:02:25 -08:00
// ---
// 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 09:24:16 -07: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 11:51:22 -07:00
labels , err := models . GetLabelsInRepoByIDs ( ctx . Repo . Repository . ID , form . Labels )
2016-08-03 09:24:16 -07:00
if err != nil {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "GetLabelsInRepoByIDs" , err )
2016-08-03 09:24:16 -07:00
return
}
2017-01-30 20:46:45 +08:00
if err := issue . ReplaceLabels ( labels , ctx . User ) ; err != nil {
2016-08-03 11:51:22 -07:00
ctx . Error ( 500 , "ReplaceLabels" , err )
2016-08-03 09:24:16 -07:00
return
}
2016-08-03 11:51:22 -07: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-24 19:52:51 -04:00
apiLabels [ i ] = labels [ i ] . APIFormat ( )
2016-08-03 11:51:22 -07:00
}
ctx . JSON ( 200 , & apiLabels )
2016-08-03 09:24:16 -07:00
}
2016-11-24 15:04:31 +08:00
// ClearIssueLabels delete all the labels for an issue
2016-08-03 09:24:16 -07:00
func ClearIssueLabels ( ctx * context . APIContext ) {
2018-05-08 08:05:18 +02:00
// swagger:operation DELETE /repos/{owner}/{repo}/issues/{index}/labels issue issueClearLabels
2017-11-12 23:02:25 -08:00
// ---
// 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 09:24:16 -07: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 03:32:24 -07:00
if err := issue . ClearLabels ( ctx . User ) ; err != nil {
2016-08-03 09:24:16 -07:00
ctx . Error ( 500 , "ClearLabels" , err )
return
}
ctx . Status ( 204 )
}