mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Whitelist legal job parameter types
This commit is contained in:
parent
60b8af42e9
commit
575a837de1
2 changed files with 18 additions and 7 deletions
|
@ -3,13 +3,17 @@ require 'active_support/core_ext/object/try'
|
||||||
|
|
||||||
module ActiveJob
|
module ActiveJob
|
||||||
class Parameters
|
class Parameters
|
||||||
|
TYPE_WHITELIST = [NilClass, Fixnum, Float, String, TrueClass, FalseClass, Hash, Array]
|
||||||
|
|
||||||
def self.serialize(params)
|
def self.serialize(params)
|
||||||
params.collect { |param| param.try(:global_id) || param }
|
params.collect do |param|
|
||||||
|
raise "Unsupported parameter type: #{param.class.name}" unless param.respond_to?(:global_id) || TYPE_WHITELIST.include?(param.class)
|
||||||
|
param.try(:global_id) || param
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.deserialize(params)
|
def self.deserialize(params)
|
||||||
params.collect { |param| ActiveModel::GlobalLocator.locate(param) || param }
|
params.collect { |param| ActiveModel::GlobalLocator.locate(param) || param }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -6,11 +6,18 @@ class ParameterSerializationTest < ActiveSupport::TestCase
|
||||||
test 'should make no change to regular values' do
|
test 'should make no change to regular values' do
|
||||||
assert_equal [ 1, "something" ], ActiveJob::Parameters.serialize([ 1, "something" ])
|
assert_equal [ 1, "something" ], ActiveJob::Parameters.serialize([ 1, "something" ])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test 'should not allow complex objects' do
|
||||||
|
err = assert_raises RuntimeError do
|
||||||
|
ActiveJob::Parameters.serialize([ 1, self ])
|
||||||
|
end
|
||||||
|
assert_equal "Unsupported parameter type: #{self.class.name}", err.message
|
||||||
|
end
|
||||||
|
|
||||||
test 'should serialize records with global id' do
|
test 'should serialize records with global id' do
|
||||||
assert_equal [ Person.find(5).gid ], ActiveJob::Parameters.serialize([ Person.find(5) ])
|
assert_equal [ Person.find(5).gid ], ActiveJob::Parameters.serialize([ Person.find(5) ])
|
||||||
end
|
end
|
||||||
|
|
||||||
test 'should serialize values and records together' do
|
test 'should serialize values and records together' do
|
||||||
assert_equal [ 3, Person.find(5).gid ], ActiveJob::Parameters.serialize([ 3, Person.find(5) ])
|
assert_equal [ 3, Person.find(5).gid ], ActiveJob::Parameters.serialize([ 3, Person.find(5) ])
|
||||||
end
|
end
|
||||||
|
@ -20,11 +27,11 @@ class ParameterDeserializationTest < ActiveSupport::TestCase
|
||||||
test 'should make no change to regular values' do
|
test 'should make no change to regular values' do
|
||||||
assert_equal [ 1, "something" ], ActiveJob::Parameters.deserialize([ 1, "something" ])
|
assert_equal [ 1, "something" ], ActiveJob::Parameters.deserialize([ 1, "something" ])
|
||||||
end
|
end
|
||||||
|
|
||||||
test 'should deserialize records with global id' do
|
test 'should deserialize records with global id' do
|
||||||
assert_equal [ Person.find(5) ], ActiveJob::Parameters.deserialize([ Person.find(5).gid ])
|
assert_equal [ Person.find(5) ], ActiveJob::Parameters.deserialize([ Person.find(5).gid ])
|
||||||
end
|
end
|
||||||
|
|
||||||
test 'should serialize values and records together' do
|
test 'should serialize values and records together' do
|
||||||
assert_equal [ 3, Person.find(5) ], ActiveJob::Parameters.deserialize([ 3, Person.find(5).gid ])
|
assert_equal [ 3, Person.find(5) ], ActiveJob::Parameters.deserialize([ 3, Person.find(5).gid ])
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue