1
0
Fork 0
mirror of https://github.com/mperham/sidekiq.git synced 2022-11-09 13:52:34 -05:00
mperham--sidekiq/lib/sidekiq/extensions/generic_proxy.rb

32 lines
1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require "yaml"
2013-05-04 20:50:24 -07:00
module Sidekiq
module Extensions
SIZE_LIMIT = 8_192
2012-07-20 20:11:33 -07:00
class Proxy < BasicObject
def initialize(performable, target, options = {})
@performable = performable
@target = target
@opts = options
end
def method_missing(name, *args)
# Sidekiq has a limitation in that its message must be JSON.
# JSON can't round trip real Ruby objects so we use YAML to
# serialize the objects to a String. The YAML will be converted
# to JSON and then deserialized on the other side back into a
# Ruby object.
obj = [@target, name, args]
marshalled = ::YAML.dump(obj)
if marshalled.size > SIZE_LIMIT
::Sidekiq.logger.warn { "#{@target}.#{name} job argument is #{marshalled.bytesize} bytes, you should refactor it to reduce the size" }
end
@performable.client_push({"class" => @performable, "args" => [marshalled]}.merge(@opts))
end
end
end
end