mirror of
https://github.com/discourse/discourse.git
synced 2024-11-22 08:57:10 -06:00
parent
47e718f5b2
commit
65edbb609c
@ -193,7 +193,7 @@ GEM
|
|||||||
mail (2.6.3)
|
mail (2.6.3)
|
||||||
mime-types (>= 1.16, < 3)
|
mime-types (>= 1.16, < 3)
|
||||||
memory_profiler (0.9.4)
|
memory_profiler (0.9.4)
|
||||||
message_bus (1.0.16)
|
message_bus (1.1.0)
|
||||||
rack (>= 1.1.3)
|
rack (>= 1.1.3)
|
||||||
redis
|
redis
|
||||||
metaclass (0.0.4)
|
metaclass (0.0.4)
|
||||||
@ -315,7 +315,7 @@ GEM
|
|||||||
ffi (>= 1.0.6)
|
ffi (>= 1.0.6)
|
||||||
msgpack (>= 0.4.3)
|
msgpack (>= 0.4.3)
|
||||||
trollop (>= 1.16.2)
|
trollop (>= 1.16.2)
|
||||||
redis (3.2.1)
|
redis (3.2.2)
|
||||||
redis-namespace (1.5.2)
|
redis-namespace (1.5.2)
|
||||||
redis (~> 3.0, >= 3.0.4)
|
redis (~> 3.0, >= 3.0.4)
|
||||||
ref (2.0.0)
|
ref (2.0.0)
|
||||||
|
85
config/initializers/004-message_bus.rb
Normal file
85
config/initializers/004-message_bus.rb
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
MessageBus.site_id_lookup do |env=nil|
|
||||||
|
if env
|
||||||
|
setup_message_bus_env(env)
|
||||||
|
env["__mb"][:site_id]
|
||||||
|
else
|
||||||
|
RailsMultisite::ConnectionManagement.current_db
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def setup_message_bus_env(env)
|
||||||
|
return if env["__mb"]
|
||||||
|
|
||||||
|
host = RailsMultisite::ConnectionManagement.host(env)
|
||||||
|
RailsMultisite::ConnectionManagement.with_hostname(host) do
|
||||||
|
user = CurrentUser.lookup_from_env(env)
|
||||||
|
user_id = user && user.id
|
||||||
|
is_admin = !!(user && user.admin?)
|
||||||
|
group_ids = if is_admin
|
||||||
|
# special rule, admin is allowed access to all groups
|
||||||
|
Group.pluck(:id)
|
||||||
|
elsif user
|
||||||
|
user.groups.pluck('groups.id')
|
||||||
|
end
|
||||||
|
|
||||||
|
hash = {
|
||||||
|
extra_headers:
|
||||||
|
{
|
||||||
|
"Access-Control-Allow-Origin" => Discourse.base_url_no_prefix,
|
||||||
|
"Access-Control-Allow-Methods" => "GET, POST",
|
||||||
|
"Access-Control-Allow-Headers" => "X-SILENCE-LOGGER, X-Shared-Session-Key"
|
||||||
|
},
|
||||||
|
user_id: user_id,
|
||||||
|
group_ids: group_ids,
|
||||||
|
is_admin: is_admin,
|
||||||
|
site_id: RailsMultisite::ConnectionManagement.current_db
|
||||||
|
|
||||||
|
}
|
||||||
|
env["__mb"] = hash
|
||||||
|
end
|
||||||
|
|
||||||
|
nil
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.extra_response_headers_lookup do |env|
|
||||||
|
setup_message_bus_env(env)
|
||||||
|
env["__mb"][:extra_headers]
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.user_id_lookup do |env|
|
||||||
|
setup_message_bus_env(env)
|
||||||
|
env["__mb"][:user_id]
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.group_ids_lookup do |env|
|
||||||
|
setup_message_bus_env(env)
|
||||||
|
env["__mb"][:group_ids]
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.is_admin_lookup do |env|
|
||||||
|
setup_message_bus_env(env)
|
||||||
|
env["__mb"][:is_admin]
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.on_connect do |site_id|
|
||||||
|
RailsMultisite::ConnectionManagement.establish_connection(db: site_id)
|
||||||
|
end
|
||||||
|
|
||||||
|
MessageBus.on_disconnect do |site_id|
|
||||||
|
ActiveRecord::Base.connection_handler.clear_active_connections!
|
||||||
|
end
|
||||||
|
|
||||||
|
# Point at our redis
|
||||||
|
MessageBus.redis_config = GlobalSetting.redis_config
|
||||||
|
|
||||||
|
MessageBus.long_polling_enabled = SiteSetting.enable_long_polling
|
||||||
|
MessageBus.long_polling_interval = SiteSetting.long_polling_interval
|
||||||
|
|
||||||
|
|
||||||
|
MessageBus.cache_assets = !Rails.env.development?
|
||||||
|
MessageBus.enable_diagnostics
|
||||||
|
|
||||||
|
if Rails.env == "test" || $0 =~ /rake$/
|
||||||
|
# disable keepalive in testing
|
||||||
|
MessageBus.keepalive_interval = -1
|
||||||
|
end
|
@ -1,57 +0,0 @@
|
|||||||
MessageBus.site_id_lookup do
|
|
||||||
RailsMultisite::ConnectionManagement.current_db
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.extra_response_headers_lookup do |env|
|
|
||||||
{
|
|
||||||
"Access-Control-Allow-Origin" => Discourse.base_url_no_prefix,
|
|
||||||
"Access-Control-Allow-Methods" => "GET, POST",
|
|
||||||
"Access-Control-Allow-Headers" => "X-SILENCE-LOGGER, X-Shared-Session-Key"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.user_id_lookup do |env|
|
|
||||||
user = CurrentUser.lookup_from_env(env)
|
|
||||||
user.id if user
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.group_ids_lookup do |env|
|
|
||||||
user = CurrentUser.lookup_from_env(env)
|
|
||||||
if user && user.admin?
|
|
||||||
# special rule, admin is allowed access to all groups
|
|
||||||
Group.pluck(:id)
|
|
||||||
elsif user
|
|
||||||
user.groups.pluck('groups.id')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.on_connect do |site_id|
|
|
||||||
RailsMultisite::ConnectionManagement.establish_connection(db: site_id)
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.on_disconnect do |site_id|
|
|
||||||
ActiveRecord::Base.connection_handler.clear_active_connections!
|
|
||||||
end
|
|
||||||
|
|
||||||
# Point at our redis
|
|
||||||
MessageBus.redis_config = GlobalSetting.redis_config
|
|
||||||
|
|
||||||
MessageBus.long_polling_enabled = SiteSetting.enable_long_polling
|
|
||||||
MessageBus.long_polling_interval = SiteSetting.long_polling_interval
|
|
||||||
|
|
||||||
MessageBus.is_admin_lookup do |env|
|
|
||||||
user = CurrentUser.lookup_from_env(env)
|
|
||||||
if user && user.admin
|
|
||||||
true
|
|
||||||
else
|
|
||||||
false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
MessageBus.cache_assets = !Rails.env.development?
|
|
||||||
MessageBus.enable_diagnostics
|
|
||||||
|
|
||||||
if Rails.env == "test" || $0 =~ /rake$/
|
|
||||||
# disable keepalive in testing
|
|
||||||
MessageBus.keepalive_interval = -1
|
|
||||||
end
|
|
@ -12,6 +12,3 @@ class Discourse::ForceHttpsMiddleware
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# this code plays up, skip for now
|
|
||||||
#Rails.configuration.middleware.insert_before MessageBus::Rack::Middleware, Discourse::ForceHttpsMiddleware
|
|
||||||
|
|
13
config/initializers/200-message_bus_request_tracker.rb
Normal file
13
config/initializers/200-message_bus_request_tracker.rb
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# we want MesageBus in the absolute front
|
||||||
|
# this is important cause the vast majority of web requests go to it
|
||||||
|
# this allows us to avoid full middleware crawls each time
|
||||||
|
Rails.configuration.middleware.delete MessageBus::Rack::Middleware
|
||||||
|
Rails.configuration.middleware.unshift MessageBus::Rack::Middleware
|
||||||
|
|
||||||
|
# no reason to track this in development, that is 300+ redis calls saved per
|
||||||
|
# page view (we serve all assets out of thin in development)
|
||||||
|
if Rails.env != 'development' || ENV['TRACK_REQUESTS']
|
||||||
|
require 'middleware/request_tracker'
|
||||||
|
Rails.configuration.middleware.unshift Middleware::RequestTracker
|
||||||
|
end
|
||||||
|
|
@ -1,6 +0,0 @@
|
|||||||
# no reason to track this in development, that is 300+ redis calls saved per
|
|
||||||
# page view (we serve all assets out of thin in development)
|
|
||||||
if Rails.env != 'development' || ENV['TRACK_REQUESTS']
|
|
||||||
require 'middleware/request_tracker'
|
|
||||||
Rails.configuration.middleware.unshift Middleware::RequestTracker
|
|
||||||
end
|
|
@ -1,10 +0,0 @@
|
|||||||
# Be sure to restart your server when you modify this file.
|
|
||||||
|
|
||||||
# Add new inflection rules using the following format
|
|
||||||
# (all these examples are active by default):
|
|
||||||
# ActiveSupport::Inflector.inflections do |inflect|
|
|
||||||
# inflect.plural /^(ox)$/i, '\1en'
|
|
||||||
# inflect.singular /^(ox)en/i, '\1'
|
|
||||||
# inflect.irregular 'person', 'people'
|
|
||||||
# inflect.uncountable %w( fish sheep )
|
|
||||||
# end
|
|
@ -1,5 +0,0 @@
|
|||||||
# Be sure to restart your server when you modify this file.
|
|
||||||
|
|
||||||
# Add new mime types for use in respond_to blocks:
|
|
||||||
# Mime::Type.register "text/richtext", :rtf
|
|
||||||
# Mime::Type.register_alias "text/html", :iphone
|
|
@ -27,7 +27,7 @@ class Demon::Sidekiq < Demon::Base
|
|||||||
cli = Sidekiq::CLI.instance
|
cli = Sidekiq::CLI.instance
|
||||||
cli.parse(["-c", GlobalSetting.sidekiq_workers.to_s])
|
cli.parse(["-c", GlobalSetting.sidekiq_workers.to_s])
|
||||||
|
|
||||||
load Rails.root + "config/initializers/sidekiq.rb"
|
load Rails.root + "config/initializers/100-sidekiq.rb"
|
||||||
cli.run
|
cli.run
|
||||||
rescue => e
|
rescue => e
|
||||||
STDERR.puts e.message
|
STDERR.puts e.message
|
||||||
|
Loading…
Reference in New Issue
Block a user