2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module API
class Labels < Grape :: API
2017-08-17 22:00:37 +05:30
include PaginationParams
2019-03-02 22:35:43 +05:30
helpers :: API :: Helpers :: LabelHelpers
2017-08-17 22:00:37 +05:30
2014-09-02 18:07:02 +05:30
before { authenticate! }
2017-08-17 22:00:37 +05:30
params do
requires :id , type : String , desc : 'The ID of a project'
end
2019-02-15 15:39:39 +05:30
resource :projects , requirements : API :: NAMESPACE_OR_PROJECT_REQUIREMENTS do
2017-08-17 22:00:37 +05:30
desc 'Get all labels of the project' do
2019-03-02 22:35:43 +05:30
success Entities :: ProjectLabel
2017-08-17 22:00:37 +05:30
end
params do
2019-10-12 21:52:04 +05:30
optional :with_counts , type : Boolean , default : false ,
desc : 'Include issue and merge request counts'
2017-08-17 22:00:37 +05:30
use :pagination
end
2014-09-02 18:07:02 +05:30
get ':id/labels' do
2019-03-02 22:35:43 +05:30
get_labels ( user_project , Entities :: ProjectLabel )
2014-09-02 18:07:02 +05:30
end
2017-08-17 22:00:37 +05:30
desc 'Create a new label' do
2019-03-02 22:35:43 +05:30
success Entities :: ProjectLabel
2017-08-17 22:00:37 +05:30
end
params do
2019-03-02 22:35:43 +05:30
use :label_create_params
2017-08-17 22:00:37 +05:30
optional :priority , type : Integer , desc : 'The priority of the label' , allow_blank : true
end
2014-09-02 18:07:02 +05:30
post ':id/labels' do
2019-03-02 22:35:43 +05:30
create_label ( user_project , Entities :: ProjectLabel )
2014-09-02 18:07:02 +05:30
end
2017-08-17 22:00:37 +05:30
desc 'Update an existing label. At least one optional parameter is required.' do
2019-03-02 22:35:43 +05:30
success Entities :: ProjectLabel
2017-08-17 22:00:37 +05:30
end
params do
2019-12-04 20:38:33 +05:30
optional :label_id , type : Integer , desc : 'The id of the label to be updated'
optional :name , type : String , desc : 'The name of the label to be updated'
2017-08-17 22:00:37 +05:30
optional :new_name , type : String , desc : 'The new name of the label'
optional :color , type : String , desc : " The new color of the label given in 6-digit hex notation with leading ' # ' sign (e.g. # FFAABB) or one of the allowed CSS color names "
optional :description , type : String , desc : 'The new description of label'
optional :priority , type : Integer , desc : 'The priority of the label' , allow_blank : true
2019-12-04 20:38:33 +05:30
exactly_one_of :label_id , :name
2017-08-17 22:00:37 +05:30
at_least_one_of :new_name , :color , :description , :priority
end
2014-09-02 18:07:02 +05:30
put ':id/labels' do
2019-03-02 22:35:43 +05:30
update_label ( user_project , Entities :: ProjectLabel )
end
2017-08-17 22:00:37 +05:30
2019-03-02 22:35:43 +05:30
desc 'Delete an existing label' do
success Entities :: ProjectLabel
end
params do
2019-12-04 20:38:33 +05:30
optional :label_id , type : Integer , desc : 'The id of the label to be deleted'
optional :name , type : String , desc : 'The name of the label to be deleted'
exactly_one_of :label_id , :name
2019-03-02 22:35:43 +05:30
end
delete ':id/labels' do
delete_label ( user_project )
2014-09-02 18:07:02 +05:30
end
2019-12-04 20:38:33 +05:30
desc 'Promote a label to a group label' do
detail 'This feature was added in GitLab 12.3'
success Entities :: GroupLabel
end
params do
requires :name , type : String , desc : 'The name of the label to be promoted'
end
put ':id/labels/promote' do
authorize! :admin_label , user_project
label = find_label ( user_project , params [ :name ] , include_ancestor_groups : false )
begin
group_label = :: Labels :: PromoteService . new ( user_project , current_user ) . execute ( label )
if group_label
present group_label , with : Entities :: GroupLabel , current_user : current_user , parent : user_project . group
else
render_api_error! ( 'Failed to promote project label to group label' , 400 )
end
rescue = > error
render_api_error! ( error . to_s , 400 )
end
end
2014-09-02 18:07:02 +05:30
end
end
end