Newer
Older
class Projects::DeployKeysController < Projects::ApplicationController
include RepositorySettingsRedirect
before_action :authorize_admin_project!
respond_to do |format|
format.html { redirect_to_repository_settings(@project) }
format.json do
render json: Projects::Settings::DeployKeysPresenter.new(@project, current_user: current_user).as_json
end
end
redirect_to_repository_settings(@project)
@key = DeployKey.new(deploy_key_params.merge(user: current_user))
unless @key.valid? && @project.deploy_keys << @key
flash[:alert] = @key.errors.full_messages.join(', ').html_safe
redirect_to_repository_settings(@project)
Projects::EnableDeployKeyService.new(@project, current_user, params).execute
respond_to do |format|
format.html { redirect_to_repository_settings(@project) }
format.json { head :ok }
end
Adam Niedzielski
committed
deploy_key_project = @project.deploy_keys_projects.find_by(deploy_key_id: params[:id])
return render_404 unless deploy_key_project
Adam Niedzielski
committed
deploy_key_project.destroy!
respond_to do |format|
format.html { redirect_to_repository_settings(@project) }
format.json { head :ok }
end
params.require(:deploy_key).permit(:key, :title, :can_push)