module ActiveJob::Arguments
def deserialize(arguments)
def deserialize(arguments) arguments.map { |argument| deserialize_argument(argument) } rescue => e raise DeserializationError.new(e) end
def deserialize_argument(argument)
def deserialize_argument(argument) case argument when String GlobalID::Locator.locate(argument) || argument when *TYPE_WHITELIST argument when Array argument.map { |arg| deserialize_argument(arg) } when Hash if serialized_global_id?(argument) deserialize_global_id argument else deserialize_hash argument end else raise ArgumentError, "Can only deserialize primitive arguments: #{argument.inspect}" end end
def deserialize_global_id(hash)
def deserialize_global_id(hash) GlobalID::Locator.locate hash[GLOBALID_KEY] end
def deserialize_hash(serialized_hash)
def deserialize_hash(serialized_hash) serialized_hash.each_with_object({}.with_indifferent_access) do |(key, value), hash| hash[key] = deserialize_argument(value) end end
def serialize(arguments)
def serialize(arguments) arguments.map { |argument| serialize_argument(argument) } end
def serialize_argument(argument)
def serialize_argument(argument) case argument when *TYPE_WHITELIST argument when GlobalID::Identification { GLOBALID_KEY => argument.to_global_id.to_s } when Array argument.map { |arg| serialize_argument(arg) } when Hash argument.each_with_object({}) do |(key, value), hash| hash[serialize_hash_key(key)] = serialize_argument(value) end else raise SerializationError.new("Unsupported argument type: #{argument.class.name}") end end
def serialize_hash_key(key)
def serialize_hash_key(key) case key when *RESERVED_KEYS raise SerializationError.new("Can't serialize a Hash with reserved key #{key.inspect}") when String, Symbol key.to_s else raise SerializationError.new("Only string and symbol hash keys may be serialized as job arguments, but #{key.inspect} is a #{key.class}") end end
def serialized_global_id?(hash)
def serialized_global_id?(hash) hash.size == 1 and hash.include?(GLOBALID_KEY) end