BUGFIX: scheduler was showing up empty in multisite

This commit is contained in:
Sam 2014-02-07 08:37:02 +11:00
parent 5b559d9631
commit f27ffe3223
2 changed files with 29 additions and 11 deletions

View File

@ -1,20 +1,23 @@
# Based off sidetiq https://github.com/tobiassvn/sidetiq/blob/master/lib/sidetiq/web.rb # Based off sidetiq https://github.com/tobiassvn/sidetiq/blob/master/lib/sidetiq/web.rb
module Scheduler module Scheduler
module Web module Web
VIEWS = File.expand_path('views', File.dirname(__FILE__)) VIEWS = File.expand_path('views', File.dirname(__FILE__)) unless defined? VIEWS
def self.registered(app) def self.registered(app)
app.get "/scheduler" do app.get "/scheduler" do
RailsMultisite::ConnectionManagement.with_connection("default") do
@manager = Scheduler::Manager.without_runner @manager = Scheduler::Manager.without_runner
@schedules = Scheduler::Manager.discover_schedules.sort do |a,b| @schedules = Scheduler::Manager.discover_schedules.sort do |a,b|
a.schedule_info.next_run <=> b.schedule_info.next_run a.schedule_info.next_run <=> b.schedule_info.next_run
end end
erb File.read(File.join(VIEWS, 'scheduler.erb')), locals: {view_path: VIEWS} erb File.read(File.join(VIEWS, 'scheduler.erb')), locals: {view_path: VIEWS}
end end
end
app.post "/scheduler/:name/trigger" do app.post "/scheduler/:name/trigger" do
halt 404 unless (name = params[:name]) halt 404 unless (name = params[:name])
RailsMultisite::ConnectionManagement.with_connection("default") do
klass = name.constantize klass = name.constantize
info = klass.schedule_info info = klass.schedule_info
info.next_run = Time.now.to_f info.next_run = Time.now.to_f
@ -22,6 +25,7 @@ module Scheduler
redirect "#{root_path}scheduler" redirect "#{root_path}scheduler"
end end
end
end end
end end

View File

@ -37,6 +37,20 @@ module RailsMultisite
end end
end end
def self.with_connection(db = "default")
old = current_db
connected = ActiveRecord::Base.connection_pool.connected?
establish_connection(:db => db)
rval = yield db
ActiveRecord::Base.connection_handler.clear_active_connections!
establish_connection(:db => old)
ActiveRecord::Base.connection_handler.clear_active_connections! unless connected
rval
end
def self.each_connection def self.each_connection
old = current_db old = current_db
connected = ActiveRecord::Base.connection_pool.connected? connected = ActiveRecord::Base.connection_pool.connected?
@ -59,7 +73,7 @@ module RailsMultisite
end end
def self.current_db def self.current_db
db = ActiveRecord::Base.connection_pool.spec.config[:db_key] || "default" ActiveRecord::Base.connection_pool.spec.config[:db_key] || "default"
end end
def self.config_filename=(config_filename) def self.config_filename=(config_filename)