118 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class Projects::PipelineSchedulesController < Projects::ApplicationController
 | |
|   before_action :schedule, except: [:index, :new, :create]
 | |
| 
 | |
|   before_action :play_rate_limit, only: [:play]
 | |
|   before_action :authorize_play_pipeline_schedule!, only: [:play]
 | |
|   before_action :authorize_read_pipeline_schedule!
 | |
|   before_action :authorize_create_pipeline_schedule!, only: [:new, :create]
 | |
|   before_action :authorize_update_pipeline_schedule!, except: [:index, :new, :create, :play]
 | |
|   before_action :authorize_admin_pipeline_schedule!, only: [:destroy]
 | |
| 
 | |
|   # rubocop: disable CodeReuse/ActiveRecord
 | |
|   def index
 | |
|     @scope = params[:scope]
 | |
|     @all_schedules = PipelineSchedulesFinder.new(@project).execute
 | |
|     @schedules = PipelineSchedulesFinder.new(@project).execute(scope: params[:scope])
 | |
|       .includes(:last_pipeline)
 | |
|   end
 | |
|   # rubocop: enable CodeReuse/ActiveRecord
 | |
| 
 | |
|   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)
 | |
|       redirect_to project_pipeline_schedules_path(@project)
 | |
|     else
 | |
|       render :edit
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def play
 | |
|     job_id = RunPipelineScheduleWorker.perform_async(schedule.id, current_user.id) # rubocop:disable CodeReuse/Worker
 | |
| 
 | |
|     if job_id
 | |
|       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
 | |
|     else
 | |
|       flash[:alert] = _('Unable to schedule a pipeline to run immediately')
 | |
|     end
 | |
| 
 | |
|     redirect_to pipeline_schedules_path(@project)
 | |
|   end
 | |
| 
 | |
|   def take_ownership
 | |
|     if schedule.update(owner: current_user)
 | |
|       redirect_to pipeline_schedules_path(@project)
 | |
|     else
 | |
|       redirect_to pipeline_schedules_path(@project), alert: _("Failed to change the owner")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def destroy
 | |
|     if schedule.destroy
 | |
|       redirect_to pipeline_schedules_path(@project), status: :found
 | |
|     else
 | |
|       redirect_to pipeline_schedules_path(@project),
 | |
|                   status: :forbidden,
 | |
|                   alert: _("Failed to remove the pipeline schedule")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def play_rate_limit
 | |
|     return unless current_user
 | |
| 
 | |
|     if rate_limiter.throttled?(:play_pipeline_schedule, scope: [current_user, schedule])
 | |
|       flash[:alert] = _('You cannot play this scheduled pipeline at the moment. Please wait a minute.')
 | |
|       redirect_to pipeline_schedules_path(@project)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def rate_limiter
 | |
|     ::Gitlab::ApplicationRateLimiter
 | |
|   end
 | |
| 
 | |
|   def schedule
 | |
|     @schedule ||= project.pipeline_schedules.find(params[:id])
 | |
|   end
 | |
| 
 | |
|   def schedule_params
 | |
|     params.require(:schedule)
 | |
|       .permit(:description, :cron, :cron_timezone, :ref, :active,
 | |
|         variables_attributes: [:id, :variable_type, :key, :secret_value, :_destroy] )
 | |
|   end
 | |
| 
 | |
|   def authorize_play_pipeline_schedule!
 | |
|     return access_denied! unless can?(current_user, :play_pipeline_schedule, schedule)
 | |
|   end
 | |
| 
 | |
|   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)
 | |
|   end
 | |
| end
 |