aboutsummaryrefslogtreecommitdiffstats
path: root/activejob/lib
diff options
context:
space:
mode:
Diffstat (limited to 'activejob/lib')
-rw-r--r--activejob/lib/active_job/serializers.rb21
-rw-r--r--activejob/lib/active_job/serializers/class_serializer.rb24
-rw-r--r--activejob/lib/active_job/serializers/duration_serializer.rb42
-rw-r--r--activejob/lib/active_job/serializers/struct_serializer.rb38
-rw-r--r--activejob/lib/active_job/serializers/symbol_serializer.rb28
-rw-r--r--activejob/lib/rails/generators/job/job_generator.rb2
6 files changed, 7 insertions, 148 deletions
diff --git a/activejob/lib/active_job/serializers.rb b/activejob/lib/active_job/serializers.rb
index ec86065149..68ed94896e 100644
--- a/activejob/lib/active_job/serializers.rb
+++ b/activejob/lib/active_job/serializers.rb
@@ -27,15 +27,11 @@ module ActiveJob
autoload :ArraySerializer
autoload :BaseSerializer
- autoload :ClassSerializer
- autoload :DurationSerializer
autoload :GlobalIDSerializer
autoload :HashWithIndifferentAccessSerializer
autoload :HashSerializer
autoload :ObjectSerializer
autoload :StandardTypeSerializer
- autoload :StructSerializer
- autoload :SymbolSerializer
included do
class_attribute :_additional_serializers, instance_accessor: false, instance_predicate: false
@@ -46,14 +42,14 @@ module ActiveJob
module ClassMethods
# Returns list of known serializers
def serializers
- self._additional_serializers + SERIALIZERS
+ self._additional_serializers + ActiveJob::Serializers::SERIALIZERS
end
# Adds a new serializer to a list of known serializers
- def add_serializers(*serializers)
- check_duplicate_serializer_keys!(serializers)
+ def add_serializers(*new_serializers)
+ check_duplicate_serializer_keys!(new_serializers)
- @_additional_serializers = serializers + @_additional_serializers
+ self._additional_serializers = new_serializers + self._additional_serializers
end
# Returns a list of reserved keys, which cannot be used as keys for a hash
@@ -66,7 +62,7 @@ module ActiveJob
def check_duplicate_serializer_keys!(serializers)
keys_to_add = serializers.select { |s| s.respond_to?(:key) }.map(&:key)
- duplicate_keys = reserved_keys & keys_to_add
+ duplicate_keys = reserved_serializers_keys & keys_to_add
raise ArgumentError.new("Can't add serializers because of keys duplication: #{duplicate_keys}") if duplicate_keys.any?
end
@@ -75,21 +71,16 @@ module ActiveJob
# :nodoc:
SERIALIZERS = [
::ActiveJob::Serializers::GlobalIDSerializer,
- ::ActiveJob::Serializers::DurationSerializer,
- ::ActiveJob::Serializers::StructSerializer,
- ::ActiveJob::Serializers::SymbolSerializer,
- ::ActiveJob::Serializers::ClassSerializer,
::ActiveJob::Serializers::StandardTypeSerializer,
::ActiveJob::Serializers::HashWithIndifferentAccessSerializer,
::ActiveJob::Serializers::HashSerializer,
::ActiveJob::Serializers::ArraySerializer
].freeze
- private_constant :SERIALIZERS
class << self
# Returns serialized representative of the passed object.
# Will look up through all known serializers.
- # Raises `SerializationError` if it can't find a proper serializer.
+ # Raises `ActiveJob::SerializationError` if it can't find a proper serializer.
def serialize(argument)
serializer = ::ActiveJob::Base.serializers.detect { |s| s.serialize?(argument) }
raise SerializationError.new("Unsupported argument type: #{argument.class.name}") unless serializer
diff --git a/activejob/lib/active_job/serializers/class_serializer.rb b/activejob/lib/active_job/serializers/class_serializer.rb
deleted file mode 100644
index d36e8c0ebc..0000000000
--- a/activejob/lib/active_job/serializers/class_serializer.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-# frozen_string_literal: true
-
-module ActiveJob
- module Serializers
- # Provides methods to serialize and deserialize `Class` (`ActiveRecord::Base`, `MySpecialService`, ...)
- class ClassSerializer < ObjectSerializer
- class << self
- def serialize(argument_klass)
- { key => "::#{argument_klass.name}" }
- end
-
- def key
- "_aj_class"
- end
-
- private
-
- def klass
- ::Class
- end
- end
- end
- end
-end
diff --git a/activejob/lib/active_job/serializers/duration_serializer.rb b/activejob/lib/active_job/serializers/duration_serializer.rb
deleted file mode 100644
index 72b7b9528a..0000000000
--- a/activejob/lib/active_job/serializers/duration_serializer.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-# frozen_string_literal: true
-
-module ActiveJob
- module Serializers
- # Provides methods to serialize and deserialize `ActiveSupport::Duration` (`1.day`, `2.weeks`, ...)
- class DurationSerializer < ObjectSerializer
- class << self
- def serialize(duration)
- {
- key => duration.value,
- parts_key => ::ActiveJob::Serializers.serialize(duration.parts)
- }
- end
-
- def deserialize(hash)
- value = hash[key]
- parts = ::ActiveJob::Serializers.deserialize(hash[parts_key])
-
- klass.new(value, parts)
- end
-
- def key
- "_aj_activesupport_duration"
- end
-
- private
-
- def klass
- ::ActiveSupport::Duration
- end
-
- def keys
- super.push parts_key
- end
-
- def parts_key
- "parts"
- end
- end
- end
- end
-end
diff --git a/activejob/lib/active_job/serializers/struct_serializer.rb b/activejob/lib/active_job/serializers/struct_serializer.rb
deleted file mode 100644
index f6791611ed..0000000000
--- a/activejob/lib/active_job/serializers/struct_serializer.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-# frozen_string_literal: true
-
-module ActiveJob
- module Serializers
- # Provides methods to serialize and deserialize struct instances
- # (`Struct.new('Rectangle', :width, :height).new(12, 20)`)
- class StructSerializer < ObjectSerializer
- class << self
- def serialize(object)
- super.merge values_key => ::ActiveJob::Serializers.serialize(object.values)
- end
-
- def deserialize(hash)
- values = ::ActiveJob::Serializers.deserialize(hash[values_key])
- super.new(*values)
- end
-
- def key
- "_aj_struct"
- end
-
- private
-
- def klass
- ::Struct
- end
-
- def keys
- super.push values_key
- end
-
- def values_key
- "values"
- end
- end
- end
- end
-end
diff --git a/activejob/lib/active_job/serializers/symbol_serializer.rb b/activejob/lib/active_job/serializers/symbol_serializer.rb
deleted file mode 100644
index f128ae8284..0000000000
--- a/activejob/lib/active_job/serializers/symbol_serializer.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-# frozen_string_literal: true
-
-module ActiveJob
- module Serializers
- # Provides methods to serialize and deserialize `Symbol` (`:foo`, `:bar`, ...)
- class SymbolSerializer < ObjectSerializer
- class << self
- def serialize(symbol)
- { key => symbol.to_s }
- end
-
- def deserialize(hash)
- hash[key].to_sym
- end
-
- def key
- "_aj_symbol"
- end
-
- private
-
- def klass
- ::Symbol
- end
- end
- end
- end
-end
diff --git a/activejob/lib/rails/generators/job/job_generator.rb b/activejob/lib/rails/generators/job/job_generator.rb
index c940cd154c..69b4fe7d26 100644
--- a/activejob/lib/rails/generators/job/job_generator.rb
+++ b/activejob/lib/rails/generators/job/job_generator.rb
@@ -30,7 +30,7 @@ module Rails # :nodoc:
private
def application_job_file_name
@application_job_file_name ||= if mountable_engine?
- "app/jobs/#{namespaced_path}/application_job.rb"
+ "app/jobs/#{namespaced_path}/application_job.rb"
else
"app/jobs/application_job.rb"
end