mirror of
https://github.com/discourse/discourse.git
synced 2025-05-23 07:11:17 +08:00
FEATURE: only allow sidekiq in master site when hosted on multisite
This commit is contained in:
@ -20,7 +20,8 @@ Discourse::Application.routes.draw do
|
|||||||
mount Sidekiq::Web => "/sidekiq"
|
mount Sidekiq::Web => "/sidekiq"
|
||||||
mount Logster::Web => "/logs"
|
mount Logster::Web => "/logs"
|
||||||
else
|
else
|
||||||
mount Sidekiq::Web => "/sidekiq", constraints: AdminConstraint.new
|
# only allow sidekie in master site
|
||||||
|
mount Sidekiq::Web => "/sidekiq", constraints: AdminConstraint.new(require_master: true)
|
||||||
mount Logster::Web => "/logs", constraints: AdminConstraint.new
|
mount Logster::Web => "/logs", constraints: AdminConstraint.new
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -2,7 +2,12 @@ require_dependency 'current_user'
|
|||||||
|
|
||||||
class AdminConstraint
|
class AdminConstraint
|
||||||
|
|
||||||
|
def initialize(options={})
|
||||||
|
@require_master = options[:require_master]
|
||||||
|
end
|
||||||
|
|
||||||
def matches?(request)
|
def matches?(request)
|
||||||
|
return false if @require_master && RailsMultisite::ConnectionManagement.current_db != "default"
|
||||||
provider = Discourse.current_user_provider.new(request.env)
|
provider = Discourse.current_user_provider.new(request.env)
|
||||||
provider.current_user && provider.current_user.admin?
|
provider.current_user && provider.current_user.admin?
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user