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