class Projects::DeployKeysController < Projects::ApplicationController respond_to :html # Authorize before_action :authorize_admin_project! layout "project_settings" def index @key = DeployKey.new set_index_vars end def new redirect_to namespace_project_deploy_keys_path(@project.namespace, @project) end def create @key = DeployKey.new(deploy_key_params.merge(user: current_user)) set_index_vars if @key.valid? && @project.deploy_keys << @key redirect_to namespace_project_deploy_keys_path(@project.namespace, @project) else render "index" end end def enable Projects::EnableDeployKeyService.new(@project, current_user, params).execute redirect_to namespace_project_deploy_keys_path(@project.namespace, @project) end def disable @project.deploy_keys_projects.find_by(deploy_key_id: params[:id]).destroy redirect_back_or_default(default: { action: 'index' }) end protected def set_index_vars @enabled_keys ||= @project.deploy_keys @available_keys ||= current_user.accessible_deploy_keys - @enabled_keys @available_project_keys ||= current_user.project_deploy_keys - @enabled_keys @available_public_keys ||= DeployKey.are_public - @enabled_keys # Public keys that are already used by another accessible project are already # in @available_project_keys. @available_public_keys -= @available_project_keys end def deploy_key_params params.require(:deploy_key).permit(:key, :title, :can_push) end end