gitlab-org--gitlab-foss/app/controllers/concerns/project_unauthorized.rb
James Edwards-Jones bedb9a3e6d Avoid passing not_found_or_authorized_proc around
Since this needs to be called on every find_routable!(Project, ...
we can instead move it to a RoutableActions check.
2019-05-15 17:36:50 +07:00

21 lines
669 B
Ruby

# frozen_string_literal: true
module ProjectUnauthorized
module ControllerActions
def self.on_routable_not_found
lambda do |routable|
return unless routable.is_a?(Project)
label = routable.external_authorization_classification_label
rejection_reason = nil
unless ::Gitlab::ExternalAuthorization.access_allowed?(current_user, label)
rejection_reason = ::Gitlab::ExternalAuthorization.rejection_reason(current_user, label)
rejection_reason ||= _('External authorization denied access to this project')
end
access_denied!(rejection_reason) if rejection_reason
end
end
end
end