50 lines
1.1 KiB
Ruby
50 lines
1.1 KiB
Ruby
class Ci::BaseController < ApplicationController
|
|
include Ci::DbConnectable
|
|
|
|
before_action :require_login
|
|
before_action :connect_to_ci_database, if: -> { current_user && !current_user.is_a?(AnonymousUser) && current_user.devops_unverified? }
|
|
|
|
def load_repo
|
|
namespace = params[:owner]
|
|
id = params[:repo] || params[:id]
|
|
|
|
@ci_user, @repo = Ci::Repo.find_with_namespace(namespace, id)
|
|
end
|
|
|
|
private
|
|
def authorize_access_project!
|
|
unless @project.manager?(current_user)
|
|
return render_forbidden
|
|
end
|
|
end
|
|
|
|
def authorize_manage_builds!
|
|
unless @project.owner?(current_user)
|
|
return render_forbidden
|
|
end
|
|
end
|
|
|
|
def authenticate_admin!
|
|
return render_forbidden unless current_user.admin?
|
|
end
|
|
|
|
def authorize_owner_project!
|
|
unless @project.owner?(current_user)
|
|
return render_forbidden
|
|
end
|
|
end
|
|
|
|
def find_cloud_account
|
|
@cloud_account ||= current_user.ci_cloud_account
|
|
end
|
|
|
|
def load_ci_user
|
|
begin
|
|
@ci_user = Ci::User.find_by(user_login: params[:owner])
|
|
rescue
|
|
render_not_found
|
|
end
|
|
end
|
|
|
|
end
|