# frozen_string_literal: true module Projects module Settings class RepositoryController < Projects::ApplicationController layout 'project_settings' before_action :authorize_admin_project! before_action :define_variables, only: [:create_deploy_token] feature_category :source_code_management, [:show, :cleanup, :update] feature_category :continuous_delivery, [:create_deploy_token] urgency :low, [:show, :create_deploy_token] def show push_frontend_feature_flag(:branch_rules, @project) render_show end def cleanup bfg_object_map = params.require(:project).require(:bfg_object_map) result = Projects::CleanupService.enqueue(project, current_user, bfg_object_map) if result[:status] == :success flash[:notice] = _('Repository cleanup has started. You will receive an email once the cleanup operation is complete.') else flash[:alert] = result.fetch(:message, _('Failed to upload object map file')) end redirect_to project_settings_repository_path(project) end def create_deploy_token result = Projects::DeployTokens::CreateService.new(@project, current_user, deploy_token_params).execute if result[:status] == :success @created_deploy_token = result[:deploy_token] respond_to do |format| format.json do # IMPORTANT: It's a security risk to expose the token value more than just once here! json = API::Entities::DeployTokenWithToken.represent(@created_deploy_token).as_json render json: json, status: result[:http_status] end format.html do flash.now[:notice] = s_('DeployTokens|Your new project deploy token has been created.') render :show end end else @new_deploy_token = result[:deploy_token] respond_to do |format| format.json { render json: { message: result[:message] }, status: result[:http_status] } format.html do flash.now[:alert] = result[:message] render :show end end end end def update result = ::Projects::UpdateService.new(@project, current_user, project_params).execute if result[:status] == :success flash[:notice] = _("Project settings were successfully updated.") else flash[:alert] = result[:message] @project.reset end redirect_to project_settings_repository_path(project) end private def render_show define_variables render 'show' end def define_variables @deploy_keys = DeployKeysPresenter.new(@project, current_user: current_user) define_deploy_token_variables define_protected_refs remote_mirror end # rubocop: disable CodeReuse/ActiveRecord def define_protected_refs @protected_branches = fetch_protected_branches(@project) @protected_tags = @project.protected_tags.order(:name).page(params[:page]) @protected_branch = @project.protected_branches.new @protected_tag = @project.protected_tags.new @protected_tags_count = @protected_tags.reduce(0) { |sum, tag| sum + tag.matching(@project.repository.tag_names).size } load_gon_index end # rubocop: enable CodeReuse/ActiveRecord def fetch_protected_branches(project) project.protected_branches.sorted_by_name.page(params[:page]) end def remote_mirror @remote_mirror = project.remote_mirrors.first_or_initialize end def deploy_token_params params.require(:deploy_token).permit(:name, :expires_at, :read_repository, :read_registry, :write_registry, :read_package_registry, :write_package_registry, :username) end def project_params params.require(:project).permit(project_params_attributes) end def project_params_attributes [ :issue_branch_template, :default_branch, :autoclose_referenced_issues ] end def access_levels_options { create_access_levels: levels_for_dropdown, push_access_levels: levels_for_dropdown, merge_access_levels: levels_for_dropdown } end def levels_for_dropdown roles = ProtectedRefAccess::HUMAN_ACCESS_LEVELS.map do |id, text| { id: id, text: text, before_divider: true } end { roles: roles } end def protectable_tags_for_dropdown { open_tags: ProtectableDropdown.new(@project, :tags).hash } end def protectable_branches_for_dropdown { open_branches: ProtectableDropdown.new(@project, :branches).hash } end def define_deploy_token_variables @deploy_tokens = @project.deploy_tokens.active @new_deploy_token ||= DeployToken.new end def load_gon_index gon.push(protectable_tags_for_dropdown) gon.push(protectable_branches_for_dropdown) gon.push(access_levels_options) gon.push(current_project_id: project.id) if project end end end end Projects::Settings::RepositoryController.prepend_mod_with('Projects::Settings::RepositoryController')