activesupport 7.0.4 → 7.1.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +1076 -230
- data/MIT-LICENSE +1 -1
- data/README.rdoc +6 -6
- data/lib/active_support/actionable_error.rb +3 -1
- data/lib/active_support/array_inquirer.rb +2 -0
- data/lib/active_support/backtrace_cleaner.rb +30 -5
- data/lib/active_support/benchmarkable.rb +1 -0
- data/lib/active_support/broadcast_logger.rb +251 -0
- data/lib/active_support/builder.rb +1 -1
- data/lib/active_support/cache/coder.rb +153 -0
- data/lib/active_support/cache/entry.rb +134 -0
- data/lib/active_support/cache/file_store.rb +37 -10
- data/lib/active_support/cache/mem_cache_store.rb +100 -76
- data/lib/active_support/cache/memory_store.rb +78 -24
- data/lib/active_support/cache/null_store.rb +6 -0
- data/lib/active_support/cache/redis_cache_store.rb +153 -141
- data/lib/active_support/cache/serializer_with_fallback.rb +175 -0
- data/lib/active_support/cache/strategy/local_cache.rb +29 -14
- data/lib/active_support/cache.rb +333 -253
- data/lib/active_support/callbacks.rb +44 -21
- data/lib/active_support/code_generator.rb +15 -10
- data/lib/active_support/concern.rb +4 -2
- data/lib/active_support/concurrency/load_interlock_aware_monitor.rb +42 -3
- data/lib/active_support/concurrency/null_lock.rb +13 -0
- data/lib/active_support/configurable.rb +10 -0
- data/lib/active_support/core_ext/array/conversions.rb +2 -1
- data/lib/active_support/core_ext/array.rb +0 -1
- data/lib/active_support/core_ext/class/subclasses.rb +13 -10
- data/lib/active_support/core_ext/date/calculations.rb +15 -0
- data/lib/active_support/core_ext/date/conversions.rb +2 -1
- data/lib/active_support/core_ext/date.rb +0 -1
- data/lib/active_support/core_ext/date_and_time/calculations.rb +10 -0
- data/lib/active_support/core_ext/date_time/calculations.rb +4 -0
- data/lib/active_support/core_ext/date_time/conversions.rb +6 -2
- data/lib/active_support/core_ext/date_time.rb +0 -1
- data/lib/active_support/core_ext/digest/uuid.rb +1 -10
- data/lib/active_support/core_ext/enumerable.rb +8 -75
- data/lib/active_support/core_ext/erb/util.rb +196 -0
- data/lib/active_support/core_ext/hash/conversions.rb +1 -1
- data/lib/active_support/core_ext/hash/deep_merge.rb +22 -14
- data/lib/active_support/core_ext/hash/deep_transform_values.rb +3 -3
- data/lib/active_support/core_ext/hash/keys.rb +3 -3
- data/lib/active_support/core_ext/integer/inflections.rb +12 -12
- data/lib/active_support/core_ext/module/attribute_accessors.rb +6 -0
- data/lib/active_support/core_ext/module/attribute_accessors_per_thread.rb +34 -16
- data/lib/active_support/core_ext/module/concerning.rb +6 -6
- data/lib/active_support/core_ext/module/delegation.rb +81 -37
- data/lib/active_support/core_ext/module/deprecation.rb +15 -12
- data/lib/active_support/core_ext/module/introspection.rb +0 -1
- data/lib/active_support/core_ext/numeric/bytes.rb +9 -0
- data/lib/active_support/core_ext/numeric/conversions.rb +2 -0
- data/lib/active_support/core_ext/numeric.rb +0 -1
- data/lib/active_support/core_ext/object/deep_dup.rb +16 -0
- data/lib/active_support/core_ext/object/duplicable.rb +25 -16
- data/lib/active_support/core_ext/object/inclusion.rb +13 -5
- data/lib/active_support/core_ext/object/instance_variables.rb +22 -12
- data/lib/active_support/core_ext/object/json.rb +16 -6
- data/lib/active_support/core_ext/object/to_query.rb +0 -2
- data/lib/active_support/core_ext/object/with.rb +44 -0
- data/lib/active_support/core_ext/object/with_options.rb +9 -9
- data/lib/active_support/core_ext/object.rb +1 -0
- data/lib/active_support/core_ext/pathname/blank.rb +16 -0
- data/lib/active_support/core_ext/pathname/existence.rb +2 -0
- data/lib/active_support/core_ext/pathname.rb +1 -0
- data/lib/active_support/core_ext/range/conversions.rb +28 -7
- data/lib/active_support/core_ext/range/overlap.rb +40 -0
- data/lib/active_support/core_ext/range.rb +1 -2
- data/lib/active_support/core_ext/securerandom.rb +24 -12
- data/lib/active_support/core_ext/string/filters.rb +20 -14
- data/lib/active_support/core_ext/string/indent.rb +1 -1
- data/lib/active_support/core_ext/string/inflections.rb +16 -9
- data/lib/active_support/core_ext/string/output_safety.rb +42 -174
- data/lib/active_support/core_ext/thread/backtrace/location.rb +12 -0
- data/lib/active_support/core_ext/time/calculations.rb +22 -2
- data/lib/active_support/core_ext/time/conversions.rb +2 -2
- data/lib/active_support/core_ext/time/zones.rb +7 -8
- data/lib/active_support/core_ext/time.rb +0 -1
- data/lib/active_support/current_attributes.rb +15 -6
- data/lib/active_support/deep_mergeable.rb +53 -0
- data/lib/active_support/dependencies/autoload.rb +17 -12
- data/lib/active_support/deprecation/behaviors.rb +65 -42
- data/lib/active_support/deprecation/constant_accessor.rb +5 -4
- data/lib/active_support/deprecation/deprecators.rb +104 -0
- data/lib/active_support/deprecation/disallowed.rb +6 -8
- data/lib/active_support/deprecation/instance_delegator.rb +31 -4
- data/lib/active_support/deprecation/method_wrappers.rb +6 -23
- data/lib/active_support/deprecation/proxy_wrappers.rb +37 -22
- data/lib/active_support/deprecation/reporting.rb +43 -26
- data/lib/active_support/deprecation.rb +32 -5
- data/lib/active_support/deprecator.rb +7 -0
- data/lib/active_support/descendants_tracker.rb +104 -132
- data/lib/active_support/duration/iso8601_serializer.rb +0 -2
- data/lib/active_support/duration.rb +2 -1
- data/lib/active_support/encrypted_configuration.rb +63 -11
- data/lib/active_support/encrypted_file.rb +16 -12
- data/lib/active_support/environment_inquirer.rb +22 -2
- data/lib/active_support/error_reporter/test_helper.rb +15 -0
- data/lib/active_support/error_reporter.rb +121 -35
- data/lib/active_support/evented_file_update_checker.rb +17 -2
- data/lib/active_support/execution_wrapper.rb +4 -4
- data/lib/active_support/file_update_checker.rb +4 -2
- data/lib/active_support/fork_tracker.rb +10 -2
- data/lib/active_support/gem_version.rb +4 -4
- data/lib/active_support/gzip.rb +2 -0
- data/lib/active_support/hash_with_indifferent_access.rb +35 -17
- data/lib/active_support/html_safe_translation.rb +16 -6
- data/lib/active_support/i18n.rb +1 -1
- data/lib/active_support/i18n_railtie.rb +20 -13
- data/lib/active_support/inflector/inflections.rb +2 -0
- data/lib/active_support/inflector/methods.rb +28 -18
- data/lib/active_support/inflector/transliterate.rb +3 -1
- data/lib/active_support/isolated_execution_state.rb +26 -22
- data/lib/active_support/json/decoding.rb +2 -1
- data/lib/active_support/json/encoding.rb +25 -43
- data/lib/active_support/key_generator.rb +9 -1
- data/lib/active_support/lazy_load_hooks.rb +7 -5
- data/lib/active_support/locale/en.yml +2 -0
- data/lib/active_support/log_subscriber.rb +85 -33
- data/lib/active_support/logger.rb +9 -60
- data/lib/active_support/logger_thread_safe_level.rb +10 -24
- data/lib/active_support/message_encryptor.rb +197 -53
- data/lib/active_support/message_encryptors.rb +141 -0
- data/lib/active_support/message_pack/cache_serializer.rb +23 -0
- data/lib/active_support/message_pack/extensions.rb +292 -0
- data/lib/active_support/message_pack/serializer.rb +63 -0
- data/lib/active_support/message_pack.rb +50 -0
- data/lib/active_support/message_verifier.rb +212 -93
- data/lib/active_support/message_verifiers.rb +135 -0
- data/lib/active_support/messages/codec.rb +65 -0
- data/lib/active_support/messages/metadata.rb +111 -45
- data/lib/active_support/messages/rotation_coordinator.rb +93 -0
- data/lib/active_support/messages/rotator.rb +34 -32
- data/lib/active_support/messages/serializer_with_fallback.rb +158 -0
- data/lib/active_support/multibyte/chars.rb +2 -0
- data/lib/active_support/multibyte/unicode.rb +9 -37
- data/lib/active_support/notifications/fanout.rb +245 -81
- data/lib/active_support/notifications/instrumenter.rb +87 -22
- data/lib/active_support/notifications.rb +3 -3
- data/lib/active_support/number_helper/number_converter.rb +14 -5
- data/lib/active_support/number_helper/number_to_currency_converter.rb +6 -6
- data/lib/active_support/number_helper/number_to_human_size_converter.rb +3 -3
- data/lib/active_support/number_helper/number_to_phone_converter.rb +1 -0
- data/lib/active_support/number_helper.rb +379 -317
- data/lib/active_support/ordered_hash.rb +3 -3
- data/lib/active_support/ordered_options.rb +14 -0
- data/lib/active_support/parameter_filter.rb +103 -84
- data/lib/active_support/proxy_object.rb +2 -0
- data/lib/active_support/railtie.rb +33 -21
- data/lib/active_support/reloader.rb +12 -4
- data/lib/active_support/rescuable.rb +2 -0
- data/lib/active_support/secure_compare_rotator.rb +16 -9
- data/lib/active_support/string_inquirer.rb +3 -1
- data/lib/active_support/subscriber.rb +9 -27
- data/lib/active_support/syntax_error_proxy.rb +60 -0
- data/lib/active_support/tagged_logging.rb +64 -24
- data/lib/active_support/test_case.rb +153 -6
- data/lib/active_support/testing/assertions.rb +26 -10
- data/lib/active_support/testing/autorun.rb +0 -2
- data/lib/active_support/testing/constant_stubbing.rb +32 -0
- data/lib/active_support/testing/deprecation.rb +25 -25
- data/lib/active_support/testing/error_reporter_assertions.rb +107 -0
- data/lib/active_support/testing/isolation.rb +29 -28
- data/lib/active_support/testing/method_call_assertions.rb +21 -8
- data/lib/active_support/testing/parallelize_executor.rb +8 -3
- data/lib/active_support/testing/setup_and_teardown.rb +2 -0
- data/lib/active_support/testing/stream.rb +1 -1
- data/lib/active_support/testing/strict_warnings.rb +39 -0
- data/lib/active_support/testing/time_helpers.rb +37 -15
- data/lib/active_support/time_with_zone.rb +8 -37
- data/lib/active_support/values/time_zone.rb +18 -7
- data/lib/active_support/version.rb +1 -1
- data/lib/active_support/xml_mini/jdom.rb +3 -10
- data/lib/active_support/xml_mini/nokogiri.rb +1 -1
- data/lib/active_support/xml_mini/nokogirisax.rb +1 -1
- data/lib/active_support/xml_mini/rexml.rb +1 -1
- data/lib/active_support/xml_mini.rb +2 -2
- data/lib/active_support.rb +14 -3
- metadata +148 -19
- data/lib/active_support/core_ext/array/deprecated_conversions.rb +0 -25
- data/lib/active_support/core_ext/date/deprecated_conversions.rb +0 -26
- data/lib/active_support/core_ext/date_time/deprecated_conversions.rb +0 -22
- data/lib/active_support/core_ext/numeric/deprecated_conversions.rb +0 -60
- data/lib/active_support/core_ext/range/deprecated_conversions.rb +0 -26
- data/lib/active_support/core_ext/range/include_time_with_zone.rb +0 -7
- data/lib/active_support/core_ext/range/overlaps.rb +0 -10
- data/lib/active_support/core_ext/time/deprecated_conversions.rb +0 -22
- data/lib/active_support/core_ext/uri.rb +0 -5
- data/lib/active_support/per_thread_registry.rb +0 -65
@@ -0,0 +1,175 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "zlib"
|
4
|
+
require "active_support/core_ext/kernel/reporting"
|
5
|
+
|
6
|
+
module ActiveSupport
|
7
|
+
module Cache
|
8
|
+
module SerializerWithFallback # :nodoc:
|
9
|
+
def self.[](format)
|
10
|
+
if format.to_s.include?("message_pack") && !defined?(ActiveSupport::MessagePack)
|
11
|
+
require "active_support/message_pack"
|
12
|
+
end
|
13
|
+
|
14
|
+
SERIALIZERS.fetch(format)
|
15
|
+
end
|
16
|
+
|
17
|
+
def load(dumped)
|
18
|
+
if dumped.is_a?(String)
|
19
|
+
case
|
20
|
+
when MessagePackWithFallback.dumped?(dumped)
|
21
|
+
MessagePackWithFallback._load(dumped)
|
22
|
+
when Marshal71WithFallback.dumped?(dumped)
|
23
|
+
Marshal71WithFallback._load(dumped)
|
24
|
+
when Marshal70WithFallback.dumped?(dumped)
|
25
|
+
Marshal70WithFallback._load(dumped)
|
26
|
+
else
|
27
|
+
Cache::Store.logger&.warn("Unrecognized payload prefix #{dumped.byteslice(0).inspect}; deserializing as nil")
|
28
|
+
nil
|
29
|
+
end
|
30
|
+
elsif PassthroughWithFallback.dumped?(dumped)
|
31
|
+
PassthroughWithFallback._load(dumped)
|
32
|
+
else
|
33
|
+
Cache::Store.logger&.warn("Unrecognized payload class #{dumped.class}; deserializing as nil")
|
34
|
+
nil
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
private
|
39
|
+
def marshal_load(payload)
|
40
|
+
Marshal.load(payload)
|
41
|
+
rescue ArgumentError => error
|
42
|
+
raise Cache::DeserializationError, error.message
|
43
|
+
end
|
44
|
+
|
45
|
+
module PassthroughWithFallback
|
46
|
+
include SerializerWithFallback
|
47
|
+
extend self
|
48
|
+
|
49
|
+
def dump(entry)
|
50
|
+
entry
|
51
|
+
end
|
52
|
+
|
53
|
+
def dump_compressed(entry, threshold)
|
54
|
+
entry.compressed(threshold)
|
55
|
+
end
|
56
|
+
|
57
|
+
def _load(entry)
|
58
|
+
entry
|
59
|
+
end
|
60
|
+
|
61
|
+
def dumped?(dumped)
|
62
|
+
dumped.is_a?(Cache::Entry)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
module Marshal61WithFallback
|
67
|
+
include SerializerWithFallback
|
68
|
+
extend self
|
69
|
+
|
70
|
+
MARSHAL_SIGNATURE = "\x04\x08".b.freeze
|
71
|
+
|
72
|
+
def dump(entry)
|
73
|
+
Marshal.dump(entry)
|
74
|
+
end
|
75
|
+
|
76
|
+
def dump_compressed(entry, threshold)
|
77
|
+
Marshal.dump(entry.compressed(threshold))
|
78
|
+
end
|
79
|
+
|
80
|
+
alias_method :_load, :marshal_load
|
81
|
+
public :_load
|
82
|
+
|
83
|
+
def dumped?(dumped)
|
84
|
+
dumped.start_with?(MARSHAL_SIGNATURE)
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
module Marshal70WithFallback
|
89
|
+
include SerializerWithFallback
|
90
|
+
extend self
|
91
|
+
|
92
|
+
MARK_UNCOMPRESSED = "\x00".b.freeze
|
93
|
+
MARK_COMPRESSED = "\x01".b.freeze
|
94
|
+
|
95
|
+
def dump(entry)
|
96
|
+
MARK_UNCOMPRESSED + Marshal.dump(entry.pack)
|
97
|
+
end
|
98
|
+
|
99
|
+
def dump_compressed(entry, threshold)
|
100
|
+
dumped = Marshal.dump(entry.pack)
|
101
|
+
|
102
|
+
if dumped.bytesize >= threshold
|
103
|
+
compressed = Zlib::Deflate.deflate(dumped)
|
104
|
+
return MARK_COMPRESSED + compressed if compressed.bytesize < dumped.bytesize
|
105
|
+
end
|
106
|
+
|
107
|
+
MARK_UNCOMPRESSED + dumped
|
108
|
+
end
|
109
|
+
|
110
|
+
def _load(marked)
|
111
|
+
dumped = marked.byteslice(1..-1)
|
112
|
+
dumped = Zlib::Inflate.inflate(dumped) if marked.start_with?(MARK_COMPRESSED)
|
113
|
+
Cache::Entry.unpack(marshal_load(dumped))
|
114
|
+
end
|
115
|
+
|
116
|
+
def dumped?(dumped)
|
117
|
+
dumped.start_with?(MARK_UNCOMPRESSED, MARK_COMPRESSED)
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
module Marshal71WithFallback
|
122
|
+
include SerializerWithFallback
|
123
|
+
extend self
|
124
|
+
|
125
|
+
MARSHAL_SIGNATURE = "\x04\x08".b.freeze
|
126
|
+
|
127
|
+
def dump(value)
|
128
|
+
Marshal.dump(value)
|
129
|
+
end
|
130
|
+
|
131
|
+
def _load(dumped)
|
132
|
+
marshal_load(dumped)
|
133
|
+
end
|
134
|
+
|
135
|
+
def dumped?(dumped)
|
136
|
+
dumped.start_with?(MARSHAL_SIGNATURE)
|
137
|
+
end
|
138
|
+
end
|
139
|
+
|
140
|
+
module MessagePackWithFallback
|
141
|
+
include SerializerWithFallback
|
142
|
+
extend self
|
143
|
+
|
144
|
+
def dump(value)
|
145
|
+
ActiveSupport::MessagePack::CacheSerializer.dump(value)
|
146
|
+
end
|
147
|
+
|
148
|
+
def _load(dumped)
|
149
|
+
ActiveSupport::MessagePack::CacheSerializer.load(dumped)
|
150
|
+
end
|
151
|
+
|
152
|
+
def dumped?(dumped)
|
153
|
+
available? && ActiveSupport::MessagePack.signature?(dumped)
|
154
|
+
end
|
155
|
+
|
156
|
+
private
|
157
|
+
def available?
|
158
|
+
return @available if defined?(@available)
|
159
|
+
silence_warnings { require "active_support/message_pack" }
|
160
|
+
@available = true
|
161
|
+
rescue LoadError
|
162
|
+
@available = false
|
163
|
+
end
|
164
|
+
end
|
165
|
+
|
166
|
+
SERIALIZERS = {
|
167
|
+
passthrough: PassthroughWithFallback,
|
168
|
+
marshal_6_1: Marshal61WithFallback,
|
169
|
+
marshal_7_0: Marshal70WithFallback,
|
170
|
+
marshal_7_1: Marshal71WithFallback,
|
171
|
+
message_pack: MessagePackWithFallback,
|
172
|
+
}
|
173
|
+
end
|
174
|
+
end
|
175
|
+
end
|
@@ -5,6 +5,8 @@ require "active_support/core_ext/string/inflections"
|
|
5
5
|
module ActiveSupport
|
6
6
|
module Cache
|
7
7
|
module Strategy
|
8
|
+
# = Local \Cache \Strategy
|
9
|
+
#
|
8
10
|
# Caches that implement LocalCache will be backed by an in-memory cache for the
|
9
11
|
# duration of a block. Repeated calls to the cache for the same key will hit the
|
10
12
|
# in-memory cache for faster access.
|
@@ -26,6 +28,8 @@ module ActiveSupport
|
|
26
28
|
end
|
27
29
|
end
|
28
30
|
|
31
|
+
# = Local \Cache \Store
|
32
|
+
#
|
29
33
|
# Simple memory backed cache. This cache is not thread safe and is intended only
|
30
34
|
# for serving as a temporary memory cache for a single thread.
|
31
35
|
class LocalStore
|
@@ -72,35 +76,43 @@ module ActiveSupport
|
|
72
76
|
local_cache_key)
|
73
77
|
end
|
74
78
|
|
75
|
-
def clear(
|
79
|
+
def clear(options = nil) # :nodoc:
|
76
80
|
return super unless cache = local_cache
|
77
81
|
cache.clear(options)
|
78
82
|
super
|
79
83
|
end
|
80
84
|
|
81
|
-
def cleanup(
|
85
|
+
def cleanup(options = nil) # :nodoc:
|
82
86
|
return super unless cache = local_cache
|
83
|
-
cache.clear
|
87
|
+
cache.clear(options)
|
84
88
|
super
|
85
89
|
end
|
86
90
|
|
87
91
|
def delete_matched(matcher, options = nil) # :nodoc:
|
88
92
|
return super unless cache = local_cache
|
89
|
-
cache.clear
|
93
|
+
cache.clear(options)
|
90
94
|
super
|
91
95
|
end
|
92
96
|
|
93
|
-
def increment(name, amount = 1,
|
97
|
+
def increment(name, amount = 1, options = nil) # :nodoc:
|
94
98
|
return super unless local_cache
|
95
99
|
value = bypass_local_cache { super }
|
96
|
-
|
100
|
+
if options
|
101
|
+
write_cache_value(name, value, raw: true, **options)
|
102
|
+
else
|
103
|
+
write_cache_value(name, value, raw: true)
|
104
|
+
end
|
97
105
|
value
|
98
106
|
end
|
99
107
|
|
100
|
-
def decrement(name, amount = 1,
|
108
|
+
def decrement(name, amount = 1, options = nil) # :nodoc:
|
101
109
|
return super unless local_cache
|
102
110
|
value = bypass_local_cache { super }
|
103
|
-
|
111
|
+
if options
|
112
|
+
write_cache_value(name, value, raw: true, **options)
|
113
|
+
else
|
114
|
+
write_cache_value(name, value, raw: true)
|
115
|
+
end
|
104
116
|
value
|
105
117
|
end
|
106
118
|
|
@@ -119,17 +131,20 @@ module ActiveSupport
|
|
119
131
|
end
|
120
132
|
end
|
121
133
|
|
122
|
-
def read_multi_entries(
|
134
|
+
def read_multi_entries(names, **options)
|
123
135
|
return super unless local_cache
|
124
136
|
|
125
|
-
|
137
|
+
keys_to_names = names.index_by { |name| normalize_key(name, options) }
|
138
|
+
|
139
|
+
local_entries = local_cache.read_multi_entries(keys_to_names.keys)
|
140
|
+
local_entries.transform_keys! { |key| keys_to_names[key] }
|
126
141
|
local_entries.transform_values! do |payload|
|
127
|
-
deserialize_entry(payload)
|
142
|
+
deserialize_entry(payload, **options)&.value
|
128
143
|
end
|
129
|
-
|
144
|
+
missed_names = names - local_entries.keys
|
130
145
|
|
131
|
-
if
|
132
|
-
local_entries.merge!(super(
|
146
|
+
if missed_names.any?
|
147
|
+
local_entries.merge!(super(missed_names, **options))
|
133
148
|
else
|
134
149
|
local_entries
|
135
150
|
end
|