2020-07-28 23:09:34 +05:30
# frozen_string_literal: true
module API
module Ci
2021-01-03 14:25:43 +05:30
class PipelineSchedules < :: API :: Base
2020-07-28 23:09:34 +05:30
include PaginationParams
before { authenticate! }
2021-01-29 00:20:46 +05:30
feature_category :continuous_integration
2022-07-16 23:28:13 +05:30
urgency :low
2021-01-29 00:20:46 +05:30
2020-07-28 23:09:34 +05:30
params do
2023-01-13 00:05:48 +05:30
requires :id , types : [ String , Integer ] , desc : 'The ID or URL-encoded path of the project' ,
documentation : { example : 18 }
2020-07-28 23:09:34 +05:30
end
resource :projects , requirements : :: API :: API :: NAMESPACE_OR_PROJECT_REQUIREMENTS do
desc 'Get all pipeline schedules' do
2023-01-13 00:05:48 +05:30
success code : 200 , model : Entities :: Ci :: PipelineSchedule
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
is_array true
2020-07-28 23:09:34 +05:30
end
params do
use :pagination
optional :scope , type : String , values : %w[ active inactive ] ,
2023-01-13 00:05:48 +05:30
desc : 'The scope of pipeline schedules' ,
documentation : { example : 'active' }
2020-07-28 23:09:34 +05:30
end
# rubocop: disable CodeReuse/ActiveRecord
get ':id/pipeline_schedules' do
authorize! :read_pipeline_schedule , user_project
schedules = :: Ci :: PipelineSchedulesFinder . new ( user_project ) . execute ( scope : params [ :scope ] )
. preload ( [ :owner , :last_pipeline ] )
2020-10-24 23:57:45 +05:30
present paginate ( schedules ) , with : Entities :: Ci :: PipelineSchedule
2020-07-28 23:09:34 +05:30
end
# rubocop: enable CodeReuse/ActiveRecord
desc 'Get a single pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 200 , model : Entities :: Ci :: PipelineScheduleDetails
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
2020-07-28 23:09:34 +05:30
end
get ':id/pipeline_schedules/:pipeline_schedule_id' do
2020-11-05 12:06:23 +05:30
present pipeline_schedule , with : Entities :: Ci :: PipelineScheduleDetails , user : current_user
2020-07-28 23:09:34 +05:30
end
2022-08-27 11:52:29 +05:30
desc 'Get all pipelines triggered from a pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 200 , model : Entities :: Ci :: PipelineBasic
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
is_array true
2022-08-27 11:52:29 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule ID' , documentation : { example : 13 }
2022-08-27 11:52:29 +05:30
end
get ':id/pipeline_schedules/:pipeline_schedule_id/pipelines' do
present paginate ( pipeline_schedule . pipelines ) , with : Entities :: Ci :: PipelineBasic
end
2020-07-28 23:09:34 +05:30
desc 'Create a new pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 201 , model : Entities :: Ci :: PipelineScheduleDetails
failure [
{ code : 400 , message : 'Bad request' } ,
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :description , type : String , desc : 'The description of pipeline schedule' , documentation : { example : 'Test schedule pipeline' }
requires :ref , type : String , desc : 'The branch/tag name will be triggered' , allow_blank : false , documentation : { example : 'develop' }
requires :cron , type : String , desc : 'The cron' , documentation : { example : '* * * * *' }
optional :cron_timezone , type : String , default : 'UTC' , desc : 'The timezone' , documentation : { example : 'Asia/Tokyo' }
optional :active , type : Boolean , default : true , desc : 'The activation of pipeline schedule' , documentation : { example : true }
2020-07-28 23:09:34 +05:30
end
post ':id/pipeline_schedules' do
authorize! :create_pipeline_schedule , user_project
pipeline_schedule = :: Ci :: CreatePipelineScheduleService
. new ( user_project , current_user , declared_params ( include_missing : false ) )
. execute
if pipeline_schedule . persisted?
2020-10-24 23:57:45 +05:30
present pipeline_schedule , with : Entities :: Ci :: PipelineScheduleDetails
2020-07-28 23:09:34 +05:30
else
render_validation_error! ( pipeline_schedule )
end
end
desc 'Edit a pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 200 , model : Entities :: Ci :: PipelineScheduleDetails
failure [
{ code : 400 , message : 'Bad request' } ,
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
optional :description , type : String , desc : 'The description of pipeline schedule' , documentation : { example : 'Test schedule pipeline' }
optional :ref , type : String , desc : 'The branch/tag name will be triggered' , documentation : { example : 'develop' }
optional :cron , type : String , desc : 'The cron' , documentation : { example : '* * * * *' }
optional :cron_timezone , type : String , desc : 'The timezone' , documentation : { example : 'Asia/Tokyo' }
optional :active , type : Boolean , desc : 'The activation of pipeline schedule' , documentation : { example : true }
2020-07-28 23:09:34 +05:30
end
put ':id/pipeline_schedules/:pipeline_schedule_id' do
authorize! :update_pipeline_schedule , pipeline_schedule
if pipeline_schedule . update ( declared_params ( include_missing : false ) )
2020-10-24 23:57:45 +05:30
present pipeline_schedule , with : Entities :: Ci :: PipelineScheduleDetails
2020-07-28 23:09:34 +05:30
else
render_validation_error! ( pipeline_schedule )
end
end
desc 'Take ownership of a pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 201 , model : Entities :: Ci :: PipelineScheduleDetails
failure [
{ code : 400 , message : 'Bad request' } ,
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
2020-07-28 23:09:34 +05:30
end
post ':id/pipeline_schedules/:pipeline_schedule_id/take_ownership' do
2023-05-27 22:25:52 +05:30
authorize! :admin_pipeline_schedule , pipeline_schedule
2020-07-28 23:09:34 +05:30
2023-05-27 22:25:52 +05:30
if pipeline_schedule . owned_by? ( current_user )
status ( :ok ) # Set response code to 200 if schedule is already owned by current user
present pipeline_schedule , with : Entities :: Ci :: PipelineScheduleDetails
elsif pipeline_schedule . own! ( current_user )
2020-10-24 23:57:45 +05:30
present pipeline_schedule , with : Entities :: Ci :: PipelineScheduleDetails
2020-07-28 23:09:34 +05:30
else
render_validation_error! ( pipeline_schedule )
end
end
desc 'Delete a pipeline schedule' do
2023-01-13 00:05:48 +05:30
success code : 204
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' } ,
{ code : 412 , message : 'Precondition Failed' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
2020-07-28 23:09:34 +05:30
end
delete ':id/pipeline_schedules/:pipeline_schedule_id' do
authorize! :admin_pipeline_schedule , pipeline_schedule
destroy_conditionally! ( pipeline_schedule )
end
desc 'Play a scheduled pipeline immediately' do
detail 'This feature was added in GitLab 12.8'
2023-01-13 00:05:48 +05:30
success code : 201
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
2020-07-28 23:09:34 +05:30
end
post ':id/pipeline_schedules/:pipeline_schedule_id/play' do
authorize! :play_pipeline_schedule , pipeline_schedule
job_id = RunPipelineScheduleWorker # rubocop:disable CodeReuse/Worker
. perform_async ( pipeline_schedule . id , current_user . id )
if job_id
created!
else
render_api_error! ( 'Unable to schedule pipeline run immediately' , 500 )
end
end
desc 'Create a new pipeline schedule variable' do
2023-01-13 00:05:48 +05:30
success code : 201 , model : Entities :: Ci :: Variable
failure [
{ code : 400 , message : 'Bad request' } ,
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
requires :key , type : String , desc : 'The key of the variable' , documentation : { example : 'NEW_VARIABLE' }
requires :value , type : String , desc : 'The value of the variable' , documentation : { example : 'new value' }
optional :variable_type , type : String , values : :: Ci :: PipelineScheduleVariable . variable_types . keys , desc : 'The type of variable, must be one of env_var or file. Defaults to env_var' ,
documentation : { default : 'env_var' }
2020-07-28 23:09:34 +05:30
end
post ':id/pipeline_schedules/:pipeline_schedule_id/variables' do
authorize! :update_pipeline_schedule , pipeline_schedule
variable_params = declared_params ( include_missing : false )
variable = pipeline_schedule . variables . create ( variable_params )
if variable . persisted?
2020-10-24 23:57:45 +05:30
present variable , with : Entities :: Ci :: Variable
2020-07-28 23:09:34 +05:30
else
render_validation_error! ( variable )
end
end
desc 'Edit a pipeline schedule variable' do
2023-01-13 00:05:48 +05:30
success code : 200 , model : Entities :: Ci :: Variable
failure [
{ code : 400 , message : 'Bad request' } ,
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
requires :key , type : String , desc : 'The key of the variable' , documentation : { example : 'NEW_VARIABLE' }
optional :value , type : String , desc : 'The value of the variable' , documentation : { example : 'new value' }
optional :variable_type , type : String , values : :: Ci :: PipelineScheduleVariable . variable_types . keys , desc : 'The type of variable, must be one of env_var or file' ,
documentation : { default : 'env_var' }
2020-07-28 23:09:34 +05:30
end
put ':id/pipeline_schedules/:pipeline_schedule_id/variables/:key' do
authorize! :update_pipeline_schedule , pipeline_schedule
if pipeline_schedule_variable . update ( declared_params ( include_missing : false ) )
2020-10-24 23:57:45 +05:30
present pipeline_schedule_variable , with : Entities :: Ci :: Variable
2020-07-28 23:09:34 +05:30
else
render_validation_error! ( pipeline_schedule_variable )
end
end
desc 'Delete a pipeline schedule variable' do
2023-01-13 00:05:48 +05:30
success code : 202 , model : Entities :: Ci :: Variable
failure [
{ code : 401 , message : 'Unauthorized' } ,
{ code : 403 , message : 'Forbidden' } ,
{ code : 404 , message : 'Not found' }
]
2020-07-28 23:09:34 +05:30
end
params do
2023-01-13 00:05:48 +05:30
requires :pipeline_schedule_id , type : Integer , desc : 'The pipeline schedule id' , documentation : { example : 13 }
requires :key , type : String , desc : 'The key of the variable' , documentation : { example : 'NEW_VARIABLE' }
2020-07-28 23:09:34 +05:30
end
delete ':id/pipeline_schedules/:pipeline_schedule_id/variables/:key' do
authorize! :admin_pipeline_schedule , pipeline_schedule
status :accepted
2020-10-24 23:57:45 +05:30
present pipeline_schedule_variable . destroy , with : Entities :: Ci :: Variable
2020-07-28 23:09:34 +05:30
end
end
helpers do
# rubocop: disable CodeReuse/ActiveRecord
def pipeline_schedule
@pipeline_schedule || =
user_project
. pipeline_schedules
. preload ( :owner , :last_pipeline )
. find_by ( id : params . delete ( :pipeline_schedule_id ) ) . tap do | pipeline_schedule |
unless can? ( current_user , :read_pipeline_schedule , pipeline_schedule )
not_found! ( 'Pipeline Schedule' )
end
end
end
# rubocop: enable CodeReuse/ActiveRecord
# rubocop: disable CodeReuse/ActiveRecord
def pipeline_schedule_variable
@pipeline_schedule_variable || =
pipeline_schedule . variables . find_by ( key : params [ :key ] ) . tap do | pipeline_schedule_variable |
unless pipeline_schedule_variable
not_found! ( 'Pipeline Schedule Variable' )
end
end
end
# rubocop: enable CodeReuse/ActiveRecord
end
end
end
end