debian-mirror-gitlab/app/controllers/projects/pipeline_schedules_controller.rb

116 lines
3.5 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
class Projects::PipelineSchedulesController < Projects::ApplicationController
2017-09-10 17:25:29 +05:30
before_action :schedule, except: [:index, :new, :create]
2018-03-17 18:26:18 +05:30
before_action :play_rate_limit, only: [:play]
before_action :authorize_play_pipeline_schedule!, only: [:play]
2017-08-17 22:00:37 +05:30
before_action :authorize_read_pipeline_schedule!
2017-09-10 17:25:29 +05:30
before_action :authorize_create_pipeline_schedule!, only: [:new, :create]
2018-03-17 18:26:18 +05:30
before_action :authorize_update_pipeline_schedule!, except: [:index, :new, :create, :play]
2017-08-17 22:00:37 +05:30
before_action :authorize_admin_pipeline_schedule!, only: [:destroy]
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def index
@scope = params[:scope]
@all_schedules = PipelineSchedulesFinder.new(@project).execute
@schedules = PipelineSchedulesFinder.new(@project).execute(scope: params[:scope])
.includes(:last_pipeline)
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def new
@schedule = project.pipeline_schedules.new
end
def create
@schedule = Ci::CreatePipelineScheduleService
.new(@project, current_user, schedule_params)
.execute
if @schedule.persisted?
redirect_to pipeline_schedules_path(@project)
else
render :new
end
end
def edit
end
def update
if schedule.update(schedule_params)
2017-09-10 17:25:29 +05:30
redirect_to project_pipeline_schedules_path(@project)
2017-08-17 22:00:37 +05:30
else
render :edit
end
end
2018-03-17 18:26:18 +05:30
def play
job_id = RunPipelineScheduleWorker.perform_async(schedule.id, current_user.id)
if job_id
2019-05-18 00:54:41 +05:30
pipelines_link_start = "<a href=\"#{project_pipelines_path(@project)}\">"
message = _("Successfully scheduled a pipeline to run. Go to the %{pipelines_link_start}Pipelines page%{pipelines_link_end} for details.") % { pipelines_link_start: pipelines_link_start, pipelines_link_end: "</a>" }
flash[:notice] = message.html_safe
2018-03-17 18:26:18 +05:30
else
2019-05-18 00:54:41 +05:30
flash[:alert] = _('Unable to schedule a pipeline to run immediately')
2018-03-17 18:26:18 +05:30
end
redirect_to pipeline_schedules_path(@project)
end
2017-08-17 22:00:37 +05:30
def take_ownership
if schedule.update(owner: current_user)
redirect_to pipeline_schedules_path(@project)
else
2017-09-10 17:25:29 +05:30
redirect_to pipeline_schedules_path(@project), alert: _("Failed to change the owner")
2017-08-17 22:00:37 +05:30
end
end
def destroy
if schedule.destroy
2018-11-18 11:00:15 +05:30
redirect_to pipeline_schedules_path(@project), status: :found
2017-08-17 22:00:37 +05:30
else
2017-09-10 17:25:29 +05:30
redirect_to pipeline_schedules_path(@project),
status: :forbidden,
alert: _("Failed to remove the pipeline schedule")
2017-08-17 22:00:37 +05:30
end
end
private
2018-03-17 18:26:18 +05:30
def play_rate_limit
return unless current_user
limiter = ::Gitlab::ActionRateLimiter.new(action: :play_pipeline_schedule)
return unless limiter.throttled?([current_user, schedule], 1)
2019-05-18 00:54:41 +05:30
flash[:alert] = _('You cannot play this scheduled pipeline at the moment. Please wait a minute.')
2018-03-17 18:26:18 +05:30
redirect_to pipeline_schedules_path(@project)
end
2017-08-17 22:00:37 +05:30
def schedule
@schedule ||= project.pipeline_schedules.find(params[:id])
end
def schedule_params
params.require(:schedule)
2017-09-10 17:25:29 +05:30
.permit(:description, :cron, :cron_timezone, :ref, :active,
2018-05-09 12:01:36 +05:30
variables_attributes: [:id, :key, :secret_value, :_destroy] )
2017-09-10 17:25:29 +05:30
end
2018-03-17 18:26:18 +05:30
def authorize_play_pipeline_schedule!
return access_denied! unless can?(current_user, :play_pipeline_schedule, schedule)
end
2017-09-10 17:25:29 +05:30
def authorize_update_pipeline_schedule!
return access_denied! unless can?(current_user, :update_pipeline_schedule, schedule)
end
def authorize_admin_pipeline_schedule!
return access_denied! unless can?(current_user, :admin_pipeline_schedule, schedule)
2017-08-17 22:00:37 +05:30
end
end