debian-mirror-gitlab/app/policies/base_policy.rb

21 lines
663 B
Ruby
Raw Normal View History

2017-09-10 17:25:29 +05:30
require_dependency 'declarative_policy'
2016-09-29 09:46:39 +05:30
2017-09-10 17:25:29 +05:30
class BasePolicy < DeclarativePolicy::Base
include Gitlab::CurrentSettings
2016-09-29 09:46:39 +05:30
2017-09-10 17:25:29 +05:30
desc "User is an instance admin"
with_options scope: :user, score: 0
condition(:admin) { @user&.admin? }
2016-09-29 09:46:39 +05:30
2017-09-10 17:25:29 +05:30
with_options scope: :user, score: 0
condition(:external_user) { @user.nil? || @user.external? }
2017-08-17 22:00:37 +05:30
2017-09-10 17:25:29 +05:30
with_options scope: :user, score: 0
condition(:can_create_group) { @user&.can_create_group }
2016-09-29 09:46:39 +05:30
2017-09-10 17:25:29 +05:30
desc "The application is restricted from public visibility"
condition(:restricted_public_level, scope: :global) do
current_application_settings.restricted_visibility_levels.include?(Gitlab::VisibilityLevel::PUBLIC)
2016-09-29 09:46:39 +05:30
end
end