module Ci class ProjectsController < Ci::ApplicationController before_action :authenticate_user!, except: [:build, :badge, :index, :show] before_action :authenticate_public_page!, only: :show before_action :project, only: [:build, :integration, :show, :badge, :edit, :update, :destroy, :toggle_shared_runners, :dumped_yaml] before_action :authorize_access_project!, except: [:build, :badge, :index, :show, :new, :disabled] before_action :authorize_manage_project!, only: [:edit, :integration, :update, :destroy, :toggle_shared_runners, :dumped_yaml] before_action :authenticate_token!, only: [:build] before_action :no_cache, only: [:badge] skip_before_action :check_enable_flag!, only: [:disabled] protect_from_forgery except: :build layout 'ci/project', except: [:index, :disabled] def disabled end def index @projects = Ci::Project.all if current_user @projects = @projects.where(gitlab_id: current_user.authorized_projects.pluck(:id)) end @projects = @projects.search(params[:search]) if params[:search].present? @projects = @projects.includes(:last_commit).order('ci_commits.created_at DESC') @projects = @projects.page(params[:page]).per(40) end def show @ref = params[:ref] @commits = @project.commits.reverse_order @commits = @commits.where(ref: @ref) if @ref @commits = @commits.page(params[:page]).per(20) end def integration end def edit end def update if project.update_attributes(project_params) Ci::EventService.new.change_project_settings(current_user, project) redirect_to :back, notice: 'Project was successfully updated.' else render action: "edit" end end def destroy project.gl_project.gitlab_ci_service.update_attributes(active: false) project.destroy Ci::EventService.new.remove_project(current_user, project) redirect_to ci_projects_url end # Project status badge # Image with build status for sha or ref def badge image = Ci::ImageForBuildService.new.execute(@project, params) send_file image.path, filename: image.name, disposition: 'inline', type:"image/svg+xml" end def toggle_shared_runners project.toggle!(:shared_runners_enabled) redirect_to :back end def dumped_yaml send_data @project.generated_yaml_config, filename: '.gitlab-ci.yml' end protected def project @project ||= Ci::Project.find(params[:id]) end def no_cache response.headers["Cache-Control"] = "no-cache, no-store, max-age=0, must-revalidate" response.headers["Pragma"] = "no-cache" response.headers["Expires"] = "Fri, 01 Jan 1990 00:00:00 GMT" end def project_params params.require(:project).permit(:path, :timeout, :timeout_in_minutes, :default_ref, :always_build, :polling_interval, :public, :ssh_url_to_repo, :allow_git_fetch, :email_recipients, :email_add_pusher, :email_only_broken_builds, :coverage_regex, :shared_runners_enabled, :token, { variables_attributes: [:id, :key, :value, :_destroy] }) end end end