2013-02-05 13:16:51 -06:00
|
|
|
require_dependency 'current_user'
|
|
|
|
|
|
|
|
class AdminConstraint
|
|
|
|
|
2017-07-27 20:20:09 -05:00
|
|
|
def initialize(options = {})
|
2016-03-16 08:26:07 -05:00
|
|
|
@require_master = options[:require_master]
|
|
|
|
end
|
|
|
|
|
2013-02-05 13:16:51 -06:00
|
|
|
def matches?(request)
|
2016-03-16 08:26:07 -05:00
|
|
|
return false if @require_master && RailsMultisite::ConnectionManagement.current_db != "default"
|
2018-09-04 01:17:05 -05:00
|
|
|
provider = Discourse.current_user_provider.new(request.env)
|
2018-01-25 12:56:08 -06:00
|
|
|
provider.current_user &&
|
|
|
|
provider.current_user.admin? &&
|
|
|
|
custom_admin_check(request)
|
2019-01-20 23:49:08 -06:00
|
|
|
rescue Discourse::InvalidAccess, Discourse::ReadOnly
|
2016-12-05 03:36:45 -06:00
|
|
|
false
|
2013-02-05 13:16:51 -06:00
|
|
|
end
|
|
|
|
|
2018-01-25 12:56:08 -06:00
|
|
|
# Extensibility point: plugins can overwrite this to add additional checks
|
|
|
|
# if they require.
|
|
|
|
def custom_admin_check(request)
|
|
|
|
true
|
|
|
|
end
|
|
|
|
|
2013-03-29 01:29:58 -05:00
|
|
|
end
|