2013-02-08 16:10:21 -05:00
|
|
|
|
# encoding: utf-8
|
2012-01-22 16:01:46 -08:00
|
|
|
|
require 'sidekiq/version'
|
2012-05-15 19:44:35 -07:00
|
|
|
|
require 'sidekiq/logging'
|
2012-01-22 16:01:46 -08:00
|
|
|
|
require 'sidekiq/client'
|
2012-01-25 13:32:51 -08:00
|
|
|
|
require 'sidekiq/worker'
|
2012-02-18 12:12:05 -08:00
|
|
|
|
require 'sidekiq/redis_connection'
|
2012-10-20 14:03:43 -07:00
|
|
|
|
require 'sidekiq/api'
|
2012-02-17 13:39:36 -08:00
|
|
|
|
|
2013-05-12 14:33:49 -07:00
|
|
|
|
require 'json'
|
2012-05-25 20:21:42 -07:00
|
|
|
|
|
2012-02-17 13:39:36 -08:00
|
|
|
|
module Sidekiq
|
2012-09-09 12:41:23 -07:00
|
|
|
|
NAME = "Sidekiq"
|
2012-09-03 11:34:07 -07:00
|
|
|
|
LICENSE = 'See LICENSE and the LGPL-3.0 for licensing details.'
|
2012-02-18 12:12:05 -08:00
|
|
|
|
|
2012-02-19 13:02:32 -08:00
|
|
|
|
DEFAULTS = {
|
|
|
|
|
:queues => [],
|
|
|
|
|
:concurrency => 25,
|
|
|
|
|
:require => '.',
|
|
|
|
|
:environment => nil,
|
2012-04-06 20:53:03 -07:00
|
|
|
|
:timeout => 8,
|
2013-01-27 14:03:40 -08:00
|
|
|
|
:profile => false,
|
2014-02-24 20:47:44 -08:00
|
|
|
|
:error_handlers => [],
|
2014-03-10 20:46:19 -07:00
|
|
|
|
:lifecycle_events => {
|
2014-03-11 21:11:23 -07:00
|
|
|
|
:startup => [],
|
2014-03-10 20:46:19 -07:00
|
|
|
|
:quiet => [],
|
|
|
|
|
:shutdown => [],
|
|
|
|
|
},
|
2012-02-19 13:02:32 -08:00
|
|
|
|
}
|
|
|
|
|
|
2013-03-19 23:54:55 +01:00
|
|
|
|
def self.❨╯°□°❩╯︵┻━┻
|
2013-02-08 12:42:06 -08:00
|
|
|
|
puts "Calm down, bro"
|
|
|
|
|
end
|
|
|
|
|
|
2012-02-19 13:02:32 -08:00
|
|
|
|
def self.options
|
|
|
|
|
@options ||= DEFAULTS.dup
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def self.options=(opts)
|
|
|
|
|
@options = opts
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
##
|
2012-02-20 09:46:28 -08:00
|
|
|
|
# Configuration for Sidekiq server, use like:
|
2012-02-19 13:02:32 -08:00
|
|
|
|
#
|
2012-02-20 09:46:28 -08:00
|
|
|
|
# Sidekiq.configure_server do |config|
|
2013-04-18 09:11:49 -07:00
|
|
|
|
# config.redis = { :namespace => 'myapp', :size => 25, :url => 'redis://myhost:8877/0' }
|
2012-02-19 13:02:32 -08:00
|
|
|
|
# config.server_middleware do |chain|
|
|
|
|
|
# chain.add MyServerHook
|
|
|
|
|
# end
|
|
|
|
|
# end
|
2012-02-20 09:46:28 -08:00
|
|
|
|
def self.configure_server
|
|
|
|
|
yield self if server?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
##
|
|
|
|
|
# Configuration for Sidekiq client, use like:
|
|
|
|
|
#
|
|
|
|
|
# Sidekiq.configure_client do |config|
|
2013-04-18 09:11:49 -07:00
|
|
|
|
# config.redis = { :namespace => 'myapp', :size => 1, :url => 'redis://myhost:8877/0' }
|
2012-02-20 09:46:28 -08:00
|
|
|
|
# end
|
|
|
|
|
def self.configure_client
|
|
|
|
|
yield self unless server?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def self.server?
|
|
|
|
|
defined?(Sidekiq::CLI)
|
2012-02-19 13:02:32 -08:00
|
|
|
|
end
|
|
|
|
|
|
2012-03-14 09:56:13 -07:00
|
|
|
|
def self.redis(&block)
|
2012-03-28 19:16:54 -07:00
|
|
|
|
raise ArgumentError, "requires a block" if !block
|
2014-03-13 21:06:39 -07:00
|
|
|
|
@redis ||= Sidekiq::RedisConnection.create
|
2012-03-28 19:16:54 -07:00
|
|
|
|
@redis.with(&block)
|
2012-02-17 13:51:46 -08:00
|
|
|
|
end
|
2012-02-18 12:12:05 -08:00
|
|
|
|
|
2012-03-01 13:41:12 -08:00
|
|
|
|
def self.redis=(hash)
|
2014-03-13 21:06:39 -07:00
|
|
|
|
@redis = if hash.is_a?(ConnectionPool)
|
|
|
|
|
hash
|
2012-04-09 08:56:34 -07:00
|
|
|
|
else
|
2014-03-13 21:06:39 -07:00
|
|
|
|
Sidekiq::RedisConnection.create(hash)
|
2012-03-01 13:41:12 -08:00
|
|
|
|
end
|
2012-02-17 13:39:36 -08:00
|
|
|
|
end
|
2012-02-18 12:12:05 -08:00
|
|
|
|
|
2013-10-23 21:58:15 -07:00
|
|
|
|
def self.client_middleware
|
2013-10-23 21:47:57 -07:00
|
|
|
|
@client_chain ||= Middleware::Chain.new
|
2012-02-18 12:12:05 -08:00
|
|
|
|
yield @client_chain if block_given?
|
|
|
|
|
@client_chain
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def self.server_middleware
|
2012-02-19 13:02:32 -08:00
|
|
|
|
@server_chain ||= Processor.default_middleware
|
2012-02-18 12:12:05 -08:00
|
|
|
|
yield @server_chain if block_given?
|
|
|
|
|
@server_chain
|
|
|
|
|
end
|
|
|
|
|
|
2013-09-07 18:54:13 +02:00
|
|
|
|
def self.default_worker_options=(hash)
|
|
|
|
|
@default_worker_options = default_worker_options.merge(hash)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def self.default_worker_options
|
|
|
|
|
@default_worker_options || { 'retry' => true, 'queue' => 'default' }
|
|
|
|
|
end
|
|
|
|
|
|
2012-04-22 19:22:09 -07:00
|
|
|
|
def self.load_json(string)
|
2013-05-12 14:33:49 -07:00
|
|
|
|
JSON.parse(string)
|
2012-04-22 14:02:35 -07:00
|
|
|
|
end
|
|
|
|
|
|
2012-04-22 19:22:09 -07:00
|
|
|
|
def self.dump_json(object)
|
2013-05-12 14:33:49 -07:00
|
|
|
|
JSON.generate(object)
|
2012-04-22 14:02:35 -07:00
|
|
|
|
end
|
|
|
|
|
|
2012-05-15 19:44:35 -07:00
|
|
|
|
def self.logger
|
|
|
|
|
Sidekiq::Logging.logger
|
|
|
|
|
end
|
|
|
|
|
|
2012-06-26 09:01:54 -07:00
|
|
|
|
def self.logger=(log)
|
|
|
|
|
Sidekiq::Logging.logger = log
|
|
|
|
|
end
|
|
|
|
|
|
2012-06-19 18:36:59 -05:00
|
|
|
|
def self.poll_interval=(interval)
|
|
|
|
|
self.options[:poll_interval] = interval
|
|
|
|
|
end
|
|
|
|
|
|
2014-02-24 20:47:44 -08:00
|
|
|
|
def self.error_handlers
|
|
|
|
|
self.options[:error_handlers]
|
|
|
|
|
end
|
|
|
|
|
|
2014-03-10 20:46:19 -07:00
|
|
|
|
def self.on(event, &block)
|
|
|
|
|
raise ArgumentError, "Symbols only please: #{event}" if !event.is_a?(Symbol)
|
|
|
|
|
raise ArgumentError, "Invalid event name: #{event}" if !options[:lifecycle_events].keys.include?(event)
|
|
|
|
|
options[:lifecycle_events][event] << block
|
|
|
|
|
end
|
2014-03-11 21:43:32 -07:00
|
|
|
|
|
|
|
|
|
BANNER = %q{ s
|
|
|
|
|
ss
|
|
|
|
|
sss sss ss
|
|
|
|
|
s sss s ssss sss ____ _ _ _ _
|
|
|
|
|
s sssss ssss / ___|(_) __| | ___| | _(_) __ _
|
|
|
|
|
s sss \___ \| |/ _` |/ _ \ |/ / |/ _` |
|
|
|
|
|
s sssss s ___) | | (_| | __/ <| | (_| |
|
|
|
|
|
ss s s |____/|_|\__,_|\___|_|\_\_|\__, |
|
|
|
|
|
s s s |_|
|
|
|
|
|
s s
|
|
|
|
|
sss
|
|
|
|
|
sss }
|
|
|
|
|
|
2012-02-17 13:39:36 -08:00
|
|
|
|
end
|
2013-04-18 09:11:49 -07:00
|
|
|
|
|
|
|
|
|
require 'sidekiq/extensions/class_methods'
|
|
|
|
|
require 'sidekiq/extensions/action_mailer'
|
|
|
|
|
require 'sidekiq/extensions/active_record'
|
|
|
|
|
require 'sidekiq/rails' if defined?(::Rails::Engine)
|