mongoid 8.0.3 → 8.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +3 -3
- data/README.md +3 -3
- data/lib/config/locales/en.yml +46 -14
- data/lib/mongoid/association/accessors.rb +2 -2
- data/lib/mongoid/association/builders.rb +1 -1
- data/lib/mongoid/association/embedded/batchable.rb +2 -2
- data/lib/mongoid/association/embedded/embedded_in/buildable.rb +2 -2
- data/lib/mongoid/association/embedded/embedded_in/proxy.rb +2 -1
- data/lib/mongoid/association/embedded/embeds_many/buildable.rb +3 -2
- data/lib/mongoid/association/embedded/embeds_many/proxy.rb +23 -21
- data/lib/mongoid/association/embedded/embeds_one/buildable.rb +1 -1
- data/lib/mongoid/association/embedded/embeds_one/proxy.rb +1 -1
- data/lib/mongoid/association/nested/one.rb +40 -2
- data/lib/mongoid/association/proxy.rb +1 -1
- data/lib/mongoid/association/referenced/counter_cache.rb +2 -2
- data/lib/mongoid/association/referenced/has_and_belongs_to_many/proxy.rb +5 -1
- data/lib/mongoid/association/referenced/has_many/enumerable.rb +2 -2
- data/lib/mongoid/association/referenced/has_many/proxy.rb +7 -3
- data/lib/mongoid/association/reflections.rb +2 -2
- data/lib/mongoid/attributes/dynamic.rb +1 -1
- data/lib/mongoid/attributes/nested.rb +2 -2
- data/lib/mongoid/attributes/projector.rb +1 -1
- data/lib/mongoid/attributes/readonly.rb +1 -1
- data/lib/mongoid/attributes.rb +8 -2
- data/lib/mongoid/changeable.rb +104 -4
- data/lib/mongoid/clients/storage_options.rb +2 -5
- data/lib/mongoid/clients/validators/storage.rb +1 -13
- data/lib/mongoid/collection_configurable.rb +58 -0
- data/lib/mongoid/composable.rb +2 -0
- data/lib/mongoid/config/defaults.rb +60 -0
- data/lib/mongoid/config/validators/async_query_executor.rb +24 -0
- data/lib/mongoid/config/validators.rb +1 -0
- data/lib/mongoid/config.rb +101 -0
- data/lib/mongoid/contextual/atomic.rb +1 -1
- data/lib/mongoid/contextual/memory.rb +233 -33
- data/lib/mongoid/contextual/mongo/documents_loader.rb +177 -0
- data/lib/mongoid/contextual/mongo.rb +373 -113
- data/lib/mongoid/contextual/none.rb +162 -7
- data/lib/mongoid/contextual.rb +12 -0
- data/lib/mongoid/criteria/findable.rb +2 -2
- data/lib/mongoid/criteria/includable.rb +4 -3
- data/lib/mongoid/criteria/queryable/extensions/array.rb +1 -1
- data/lib/mongoid/criteria/queryable/extensions/hash.rb +1 -1
- data/lib/mongoid/criteria/queryable/extensions/numeric.rb +0 -8
- data/lib/mongoid/criteria/queryable/extensions/string.rb +1 -11
- data/lib/mongoid/criteria/queryable/extensions/symbol.rb +0 -10
- data/lib/mongoid/criteria/queryable/key.rb +1 -1
- data/lib/mongoid/criteria/queryable/mergeable.rb +1 -1
- data/lib/mongoid/criteria/queryable/optional.rb +8 -8
- data/lib/mongoid/criteria/queryable/selectable.rb +43 -12
- data/lib/mongoid/criteria/translator.rb +45 -0
- data/lib/mongoid/criteria.rb +7 -5
- data/lib/mongoid/deprecable.rb +1 -1
- data/lib/mongoid/document.rb +50 -13
- data/lib/mongoid/errors/create_collection_failure.rb +33 -0
- data/lib/mongoid/errors/drop_collection_failure.rb +27 -0
- data/lib/mongoid/errors/immutable_attribute.rb +26 -0
- data/lib/mongoid/errors/invalid_async_query_executor.rb +25 -0
- data/lib/mongoid/errors/invalid_global_executor_concurrency.rb +22 -0
- data/lib/mongoid/errors/invalid_storage_parent.rb +2 -0
- data/lib/mongoid/errors.rb +4 -1
- data/lib/mongoid/extensions/object.rb +2 -2
- data/lib/mongoid/extensions/time.rb +2 -0
- data/lib/mongoid/factory.rb +21 -8
- data/lib/mongoid/fields/localized.rb +10 -0
- data/lib/mongoid/fields/standard.rb +10 -0
- data/lib/mongoid/fields.rb +69 -13
- data/lib/mongoid/findable.rb +27 -3
- data/lib/mongoid/interceptable.rb +7 -6
- data/lib/mongoid/matcher/eq_impl.rb +1 -1
- data/lib/mongoid/matcher/type.rb +1 -1
- data/lib/mongoid/matcher.rb +21 -6
- data/lib/mongoid/persistable/creatable.rb +1 -0
- data/lib/mongoid/persistable/deletable.rb +1 -1
- data/lib/mongoid/persistable/savable.rb +13 -1
- data/lib/mongoid/persistable/unsettable.rb +2 -2
- data/lib/mongoid/persistable/updatable.rb +51 -1
- data/lib/mongoid/persistable/upsertable.rb +20 -1
- data/lib/mongoid/persistable.rb +3 -0
- data/lib/mongoid/query_cache.rb +5 -1
- data/lib/mongoid/railties/database.rake +7 -2
- data/lib/mongoid/shardable.rb +35 -11
- data/lib/mongoid/stateful.rb +22 -1
- data/lib/mongoid/tasks/database.rake +12 -0
- data/lib/mongoid/tasks/database.rb +20 -0
- data/lib/mongoid/threaded.rb +30 -0
- data/lib/mongoid/traversable.rb +1 -1
- data/lib/mongoid/utils.rb +22 -0
- data/lib/mongoid/validatable/macros.rb +5 -5
- data/lib/mongoid/validatable.rb +4 -1
- data/lib/mongoid/version.rb +1 -1
- data/lib/mongoid/warnings.rb +17 -1
- data/lib/mongoid.rb +16 -3
- data/spec/integration/app_spec.rb +2 -2
- data/spec/integration/callbacks_models.rb +37 -0
- data/spec/integration/callbacks_spec.rb +134 -0
- data/spec/integration/discriminator_key_spec.rb +4 -5
- data/spec/integration/i18n_fallbacks_spec.rb +3 -2
- data/spec/mongoid/association/embedded/embedded_in/proxy_spec.rb +27 -0
- data/spec/mongoid/association/embedded/embeds_many/proxy_spec.rb +57 -57
- data/spec/mongoid/association/embedded/embeds_many_models.rb +1 -0
- data/spec/mongoid/association/embedded/embeds_one/proxy_spec.rb +15 -2
- data/spec/mongoid/association/referenced/belongs_to_spec.rb +2 -18
- data/spec/mongoid/association/referenced/has_and_belongs_to_many/proxy_spec.rb +148 -224
- data/spec/mongoid/association/referenced/has_many/proxy_spec.rb +111 -164
- data/spec/mongoid/association/syncable_spec.rb +1 -1
- data/spec/mongoid/attributes_spec.rb +5 -8
- data/spec/mongoid/changeable_spec.rb +299 -24
- data/spec/mongoid/clients_spec.rb +122 -13
- data/spec/mongoid/collection_configurable_spec.rb +158 -0
- data/spec/mongoid/config/defaults_spec.rb +160 -0
- data/spec/mongoid/config_spec.rb +154 -18
- data/spec/mongoid/contextual/memory_spec.rb +332 -76
- data/spec/mongoid/contextual/mongo/documents_loader_spec.rb +187 -0
- data/spec/mongoid/contextual/mongo_spec.rb +995 -36
- data/spec/mongoid/contextual/none_spec.rb +49 -2
- data/spec/mongoid/copyable_spec.rb +3 -11
- data/spec/mongoid/criteria/queryable/extensions/string_spec.rb +4 -69
- data/spec/mongoid/criteria/queryable/extensions/symbol_spec.rb +0 -59
- data/spec/mongoid/criteria/queryable/optional_spec.rb +15 -0
- data/spec/mongoid/criteria/queryable/options_spec.rb +1 -1
- data/spec/mongoid/criteria/queryable/selectable_logical_spec.rb +419 -0
- data/spec/mongoid/criteria/queryable/selectable_spec.rb +1 -1
- data/spec/mongoid/criteria/queryable/selector_spec.rb +1 -1
- data/spec/mongoid/criteria/translator_spec.rb +132 -0
- data/spec/mongoid/criteria_projection_spec.rb +1 -4
- data/spec/mongoid/criteria_spec.rb +5 -9
- data/spec/mongoid/errors/readonly_document_spec.rb +2 -2
- data/spec/mongoid/extensions/time_spec.rb +8 -43
- data/spec/mongoid/extensions/time_with_zone_spec.rb +7 -52
- data/spec/mongoid/fields/localized_spec.rb +46 -28
- data/spec/mongoid/fields_spec.rb +136 -34
- data/spec/mongoid/findable_spec.rb +391 -34
- data/spec/mongoid/indexable_spec.rb +16 -10
- data/spec/mongoid/interceptable_spec.rb +15 -3
- data/spec/mongoid/persistable/deletable_spec.rb +26 -6
- data/spec/mongoid/persistable/destroyable_spec.rb +26 -6
- data/spec/mongoid/persistable/incrementable_spec.rb +37 -0
- data/spec/mongoid/persistable/logical_spec.rb +37 -0
- data/spec/mongoid/persistable/poppable_spec.rb +36 -0
- data/spec/mongoid/persistable/pullable_spec.rb +72 -0
- data/spec/mongoid/persistable/pushable_spec.rb +72 -0
- data/spec/mongoid/persistable/renamable_spec.rb +36 -0
- data/spec/mongoid/persistable/savable_spec.rb +96 -0
- data/spec/mongoid/persistable/settable_spec.rb +37 -0
- data/spec/mongoid/persistable/unsettable_spec.rb +36 -0
- data/spec/mongoid/persistable/updatable_spec.rb +20 -28
- data/spec/mongoid/persistable/upsertable_spec.rb +80 -6
- data/spec/mongoid/persistence_context_spec.rb +7 -57
- data/spec/mongoid/query_cache_spec.rb +56 -61
- data/spec/mongoid/reloadable_spec.rb +24 -4
- data/spec/mongoid/scopable_spec.rb +70 -0
- data/spec/mongoid/serializable_spec.rb +9 -30
- data/spec/mongoid/shardable_models.rb +14 -0
- data/spec/mongoid/shardable_spec.rb +153 -61
- data/spec/mongoid/stateful_spec.rb +122 -8
- data/spec/mongoid/tasks/database_rake_spec.rb +74 -0
- data/spec/mongoid/tasks/database_spec.rb +127 -0
- data/spec/mongoid/timestamps_spec.rb +9 -11
- data/spec/mongoid/touchable_spec.rb +277 -5
- data/spec/mongoid/touchable_spec_models.rb +3 -1
- data/spec/mongoid/traversable_spec.rb +9 -24
- data/spec/mongoid/validatable/uniqueness_spec.rb +2 -3
- data/spec/mongoid_spec.rb +35 -9
- data/spec/shared/lib/mrss/docker_runner.rb +7 -0
- data/spec/shared/lib/mrss/event_subscriber.rb +15 -5
- data/spec/shared/lib/mrss/lite_constraints.rb +10 -2
- data/spec/shared/lib/mrss/server_version_registry.rb +16 -23
- data/spec/shared/lib/mrss/utils.rb +28 -6
- data/spec/shared/share/Dockerfile.erb +36 -40
- data/spec/shared/shlib/server.sh +32 -8
- data/spec/shared/shlib/set_env.sh +4 -4
- data/spec/spec_helper.rb +5 -0
- data/spec/support/immutable_ids.rb +118 -0
- data/spec/support/macros.rb +47 -15
- data/spec/support/models/artist.rb +0 -1
- data/spec/support/models/band.rb +1 -0
- data/spec/support/models/book.rb +1 -0
- data/spec/support/models/building.rb +2 -0
- data/spec/support/models/cover.rb +10 -0
- data/spec/support/models/product.rb +1 -0
- data.tar.gz.sig +0 -0
- metadata +700 -656
- metadata.gz.sig +0 -0
- data/spec/mongoid/criteria/queryable/extensions/bignum_spec.rb +0 -60
- data/spec/mongoid/criteria/queryable/extensions/fixnum_spec.rb +0 -60
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 1f5f0b81e26dba41d786804bd1213f2c05c4594ca9e05d0f62417fc15da6532e
|
4
|
+
data.tar.gz: c44f03a981d2fc648822718522e2ee7e8db6fa3fec01764eb09d77a4183a3559
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bafd2e708f204e23b0e277df74f897d19a83f059eb34bff3b636231f6e76a83176a45ea1b49586bff52c44bc3a526bd0d988cec3441bc469514035ad0acc7272
|
7
|
+
data.tar.gz: 59e6b77e3e03d94cb82fd2aad20c3951cbcc9f0872138ae76f6837986aad641cce339d5d51b8122047b5732266883708f847a7bd23c0ed2fe7bf8e19e834e045
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data/CHANGELOG.md
CHANGED
@@ -63,7 +63,7 @@ For instructions on upgrading to newer versions, visit
|
|
63
63
|
|
64
64
|
* Mongoid now uses the official Mongo Ruby Driver 2.x instead of Moped.
|
65
65
|
|
66
|
-
* Most driver specific configuration options have changed, please see [here](
|
66
|
+
* Most driver specific configuration options have changed, please see [here](https://www.mongodb.com/docs/ecosystem/tutorial/ruby-driver-tutorial/#ruby-options) for the new options.
|
67
67
|
|
68
68
|
* All references to `session` are now replaced with `client`. This includes the mongoid.yml configuration, `store_in` options, and all exceptions and modules with `Session` in the name.
|
69
69
|
|
@@ -872,8 +872,8 @@ child elements.
|
|
872
872
|
handling of validations. (Gerad Suyderhoud)
|
873
873
|
|
874
874
|
* \#2443 `expire_after_seconds` is now a valid index option
|
875
|
-
(
|
876
|
-
|
875
|
+
(https://www.mongodb.com/docs/manual/core/indexes/#ttl-indexes,
|
876
|
+
https://www.mongodb.com/docs/manual/tutorial/expire-data/).
|
877
877
|
|
878
878
|
class Event
|
879
879
|
include Mongoid::Document
|
data/README.md
CHANGED
@@ -8,11 +8,11 @@ Mongoid is an ODM (Object-Document Mapper) framework for MongoDB in Ruby.
|
|
8
8
|
Documentation
|
9
9
|
-------------
|
10
10
|
|
11
|
-
Mongoid has [extensive user documentation](https://
|
12
|
-
[API documentation](https://
|
11
|
+
Mongoid has [extensive user documentation](https://www.mongodb.com/docs/mongoid/current/).
|
12
|
+
[API documentation](https://www.mongodb.com/docs/mongoid/current/api/) is also available.
|
13
13
|
|
14
14
|
Mongoid is built on top of the MongoDB Ruby driver which has
|
15
|
-
[its own user documentation](https://
|
15
|
+
[its own user documentation](https://www.mongodb.com/docs/ruby-driver/current/).
|
16
16
|
|
17
17
|
Compatibility
|
18
18
|
-------------
|
data/lib/config/locales/en.yml
CHANGED
@@ -31,6 +31,17 @@ en:
|
|
31
31
|
since the document did not actually get saved."
|
32
32
|
resolution: "Double check all before callbacks to make sure they are
|
33
33
|
not unintentionally returning false."
|
34
|
+
create_collection_failure:
|
35
|
+
message: "Cannot create collection %{collection_name}
|
36
|
+
with options %{collection_options}. The following error was raised:
|
37
|
+
%{error}."
|
38
|
+
summary: "The server rejected createCollection command with given collection
|
39
|
+
options. This may happen when some of the options are invalid, or not
|
40
|
+
supported by your version of the server."
|
41
|
+
resolution: "Double check that collection options for the collection
|
42
|
+
%{collection_name} are valid. Consult with Ruby driver documentation
|
43
|
+
and MongoDB documentation if the desired options are supported by
|
44
|
+
your version of the server."
|
34
45
|
criteria_argument_required:
|
35
46
|
message: "Calling Criteria methods with nil arguments is not allowed."
|
36
47
|
summary: "Arguments to Criteria methods cannot be nil, and most
|
@@ -86,11 +97,24 @@ en:
|
|
86
97
|
resolution: "Search for an id/shard key that is in the database or set
|
87
98
|
the Mongoid.raise_not_found_error configuration option to false,
|
88
99
|
which will cause nil to be returned instead of raising this error."
|
100
|
+
drop_collection_failure:
|
101
|
+
message: "Cannot drop collection %{collection_name}."
|
102
|
+
summary: "Mongoid tried to drop collection %{collection_name}, but the
|
103
|
+
collection still exists in the database."
|
104
|
+
resolution: "Try to drop the collection manually using Ruby driver or
|
105
|
+
mongo shell."
|
89
106
|
empty_config_file:
|
90
107
|
message: "Empty configuration file: %{path}."
|
91
108
|
summary: "Your mongoid.yml configuration file appears to be empty."
|
92
109
|
resolution: "Ensure your configuration file contains the correct contents.
|
93
|
-
Refer to: https://
|
110
|
+
Refer to: https://www.mongodb.com/docs/mongoid/current/reference/configuration/"
|
111
|
+
immutable_attribute:
|
112
|
+
message: "Attempted to change the immutable attribute '%{name}' with
|
113
|
+
the value: %{value}."
|
114
|
+
summary: "Immutable attributes can only have values set when the
|
115
|
+
document is a new record."
|
116
|
+
resolution: "Do not attempt to update the value of '%{name}' after
|
117
|
+
the document is persisted."
|
94
118
|
invalid_collection:
|
95
119
|
message: "Access to the collection for %{klass} is not allowed."
|
96
120
|
summary: "%{klass}.collection was called, and %{klass} is an embedded
|
@@ -105,12 +129,20 @@ en:
|
|
105
129
|
A collation option is only supported if the query is executed on a MongoDB server
|
106
130
|
with version >= 3.4."
|
107
131
|
resolution: "Remove the collation option from the query."
|
132
|
+
invalid_async_query_executor:
|
133
|
+
message: "Invalid async_query_executor option: %{executor}."
|
134
|
+
summary: "A invalid async query executor was specified.
|
135
|
+
The valid options are: %{options}."
|
136
|
+
resolution: "Pick an allowed option or fix the typo. If you were
|
137
|
+
expecting the option to be there, please consult the following page
|
138
|
+
with respect to Mongoid's configuration:\n\n
|
139
|
+
\_\_https://www.mongodb.com/docs/mongoid/current/reference/configuration/#mongoid-configuration-options"
|
108
140
|
invalid_config_file:
|
109
141
|
message: "Invalid configuration file: %{path}."
|
110
142
|
summary: "Your mongoid.yml configuration file does not contain the
|
111
143
|
correct file structure."
|
112
144
|
resolution: "Ensure your configuration file contains the correct contents.
|
113
|
-
Refer to: https://
|
145
|
+
Refer to: https://www.mongodb.com/docs/mongoid/current/reference/configuration/"
|
114
146
|
invalid_config_option:
|
115
147
|
message: "Invalid configuration option: %{name}."
|
116
148
|
summary: "A invalid configuration option was provided in your
|
@@ -197,14 +229,21 @@ en:
|
|
197
229
|
\_\_\_\_field :%{name}, %{option}: true\n
|
198
230
|
\_\_end\n\n
|
199
231
|
Refer to:
|
200
|
-
https://
|
232
|
+
https://www.mongodb.com/docs/mongoid/current/reference/fields/#custom-field-options"
|
201
233
|
invalid_field_type:
|
202
234
|
message: "Invalid field type %{type_inspection} for field '%{field}' on model '%{klass}'."
|
203
235
|
summary: "Model '%{klass}' defines a field '%{field}' with an unknown type value
|
204
236
|
%{type_inspection}."
|
205
237
|
resolution: "Please provide a valid type value for the field.
|
206
238
|
Refer to:
|
207
|
-
https://
|
239
|
+
https://www.mongodb.com/docs/mongoid/current/reference/fields/#using-symbols-or-strings-instead-of-classes"
|
240
|
+
invalid_global_executor_concurrency:
|
241
|
+
message: "Invalid global_executor_concurrency option."
|
242
|
+
summary: "You set global_executor_concurrency while async_query_executor
|
243
|
+
option is not set to :global_thread_pool. The global_executor_concurrency is
|
244
|
+
allowed only for the global thread pool executor."
|
245
|
+
resolution: "Set global_executor_concurrency option to :global_thread_pool
|
246
|
+
or remove global_executor_concurrency option."
|
208
247
|
invalid_includes:
|
209
248
|
message: "Invalid includes directive: %{klass}.includes(%{args})"
|
210
249
|
summary: "Eager loading in Mongoid only supports providing arguments
|
@@ -315,7 +354,7 @@ en:
|
|
315
354
|
invalid_storage_options:
|
316
355
|
message: "Invalid options passed to %{klass}.store_in: %{options}."
|
317
356
|
summary: "The :store_in macro takes only a hash of parameters with
|
318
|
-
the keys :database, :collection, or :client."
|
357
|
+
the keys :database, :collection, :collection_options, or :client."
|
319
358
|
resolution: "Change the options passed to store_in to match the
|
320
359
|
documented API, and ensure all keys in the options hash are
|
321
360
|
symbols.\n\n
|
@@ -324,12 +363,6 @@ en:
|
|
324
363
|
\_\_\_\_include Mongoid::Document\n
|
325
364
|
\_\_\_\_store_in collection: 'artists', database: 'music'\n
|
326
365
|
\_\_end\n\n"
|
327
|
-
invalid_storage_parent:
|
328
|
-
message: "Invalid store_in call on class %{klass}."
|
329
|
-
summary: "The :store_in macro can only be called on a base Mongoid Document"
|
330
|
-
resolution: "Remove the store_in call on class %{klass}, as it will use its
|
331
|
-
parent store configuration. Or remove the hierarchy extension for this
|
332
|
-
class."
|
333
366
|
invalid_time:
|
334
367
|
message: "'%{value}' is not a valid Time."
|
335
368
|
summary: "Mongoid tries to serialize the values for Date, DateTime, and
|
@@ -545,9 +578,8 @@ en:
|
|
545
578
|
resolution: "Don't define '%{name}' as readonly, or do not attempt
|
546
579
|
to update its value after the document is persisted."
|
547
580
|
readonly_document:
|
548
|
-
message: "Attempted to persist
|
549
|
-
summary: "Documents
|
550
|
-
cannot be persisted."
|
581
|
+
message: "Attempted to persist a readonly document of class '%{klass}'."
|
582
|
+
summary: "Documents that are marked readonly cannot be persisted."
|
551
583
|
resolution: "Don't attempt to persist documents that are flagged as
|
552
584
|
readonly."
|
553
585
|
scope_overwrite:
|
@@ -206,7 +206,7 @@ module Mongoid
|
|
206
206
|
|
207
207
|
# Positional projection is specified as "foo.$". In this case the
|
208
208
|
# document that the $ is referring to should be retrieved with all
|
209
|
-
# fields. See https://
|
209
|
+
# fields. See https://www.mongodb.com/docs/manual/reference/operator/projection/positional/
|
210
210
|
# and https://jira.mongodb.org/browse/MONGOID-4769.
|
211
211
|
if filtered.keys == %w($)
|
212
212
|
filtered = nil
|
@@ -251,7 +251,7 @@ module Mongoid
|
|
251
251
|
# @example Parse the args.
|
252
252
|
# doc.parse_args(:name => "Joe")
|
253
253
|
#
|
254
|
-
# @param [
|
254
|
+
# @param [ Hash... ] *args The arguments.
|
255
255
|
#
|
256
256
|
# @return [ Array<Hash> ] The attributes and options.
|
257
257
|
def parse_args(*args)
|
@@ -97,7 +97,7 @@ module Mongoid
|
|
97
97
|
# @example Batch replace the documents.
|
98
98
|
# batchable.batch_replace([ doc_one, doc_two ])
|
99
99
|
#
|
100
|
-
# @param [ Array<Document> ] docs The docs to replace with.
|
100
|
+
# @param [ Array<Document> | Array<Hash> ] docs The docs to replace with.
|
101
101
|
#
|
102
102
|
# @return [ Array<Hash> ] The inserts.
|
103
103
|
def batch_replace(docs)
|
@@ -235,7 +235,7 @@ module Mongoid
|
|
235
235
|
# @example Normalize the docs.
|
236
236
|
# batchable.normalize_docs(docs)
|
237
237
|
#
|
238
|
-
# @param [ Array<
|
238
|
+
# @param [ Array<Document> | Array<Hash> ] docs The docs to normalize.
|
239
239
|
#
|
240
240
|
# @return [ Array<Document> ] The docs.
|
241
241
|
def normalize_docs(docs)
|
@@ -15,8 +15,8 @@ module Mongoid
|
|
15
15
|
# @example Build the document.
|
16
16
|
# Builder.new(meta, attrs).build
|
17
17
|
#
|
18
|
-
# @param [
|
19
|
-
# @param [
|
18
|
+
# @param [ Document ] base The object.
|
19
|
+
# @param [ Document | Hash ] object The parent hash or document.
|
20
20
|
# @param [ String ] type Not used in this context.
|
21
21
|
# @param [ Hash ] selected_fields Fields which were retrieved via
|
22
22
|
# #only. If selected_fields are specified, fields not listed in it
|
@@ -30,7 +30,7 @@ module Mongoid
|
|
30
30
|
# @example Substitute the new document.
|
31
31
|
# person.name.substitute(new_name)
|
32
32
|
#
|
33
|
-
# @param [ Document ] replacement A document to replace the target.
|
33
|
+
# @param [ Document | Hash ] replacement A document to replace the target.
|
34
34
|
#
|
35
35
|
# @return [ Document | nil ] The association or nil.
|
36
36
|
def substitute(replacement)
|
@@ -40,6 +40,7 @@ module Mongoid
|
|
40
40
|
return nil
|
41
41
|
end
|
42
42
|
_base.new_record = true
|
43
|
+
replacement = Factory.build(klass, replacement) if replacement.is_a?(::Hash)
|
43
44
|
self._target = replacement
|
44
45
|
bind_one
|
45
46
|
self
|
@@ -17,8 +17,9 @@ module Mongoid
|
|
17
17
|
# @example Build the documents.
|
18
18
|
# Builder.new(meta, attrs).build
|
19
19
|
#
|
20
|
-
# @param [
|
21
|
-
# @param [
|
20
|
+
# @param [ Document ] base The base object.
|
21
|
+
# @param [ Array<Document> | Array<Hash> ] object The object to use
|
22
|
+
# to build the association.
|
22
23
|
# @param [ String ] type Not used in this context.
|
23
24
|
# @param [ Hash ] selected_fields Fields which were retrieved via
|
24
25
|
# #only. If selected_fields are specified, fields not listed in it
|
@@ -19,7 +19,7 @@ module Mongoid
|
|
19
19
|
# @example Push a document.
|
20
20
|
# person.addresses.push(address)
|
21
21
|
#
|
22
|
-
# @param [ Document
|
22
|
+
# @param [ Document... ] *args Any number of documents.
|
23
23
|
def <<(*args)
|
24
24
|
docs = args.flatten
|
25
25
|
return concat(docs) if docs.size > 1
|
@@ -117,7 +117,7 @@ module Mongoid
|
|
117
117
|
# @example Use #persisted? inside block to count persisted documents.
|
118
118
|
# person.addresses.count { |a| a.persisted? && a.country == "FR" }
|
119
119
|
#
|
120
|
-
# @param [ Object
|
120
|
+
# @param [ Object... ] *args Args to delegate to the target.
|
121
121
|
#
|
122
122
|
# @return [ Integer ] The total number of persisted embedded docs, as
|
123
123
|
# flagged by the #persisted? method.
|
@@ -154,6 +154,23 @@ module Mongoid
|
|
154
154
|
end
|
155
155
|
end
|
156
156
|
|
157
|
+
# Mongoid::Extensions::Array defines Array#delete_one, so we need
|
158
|
+
# to make sure that method behaves reasonably on proxies, too.
|
159
|
+
alias delete_one delete
|
160
|
+
|
161
|
+
# Removes a single document from the collection *in memory only*.
|
162
|
+
# It will *not* persist the change.
|
163
|
+
#
|
164
|
+
# @param [ Document ] document The document to delete.
|
165
|
+
#
|
166
|
+
# @api private
|
167
|
+
def _remove(document)
|
168
|
+
_target.delete_one(document)
|
169
|
+
_unscoped.delete_one(document)
|
170
|
+
update_attributes_hash
|
171
|
+
reindex
|
172
|
+
end
|
173
|
+
|
157
174
|
# Delete all the documents in the association without running callbacks.
|
158
175
|
#
|
159
176
|
# @example Delete all documents from the association.
|
@@ -235,7 +252,7 @@ module Mongoid
|
|
235
252
|
# @example Finds the first matching document using a block.
|
236
253
|
# person.addresses.find { |addr| addr.state == 'CA' }
|
237
254
|
#
|
238
|
-
# @param [
|
255
|
+
# @param [ Object... ] *args Various arguments.
|
239
256
|
# @param [ Proc ] block Optional block to pass.
|
240
257
|
#
|
241
258
|
# @return [ Document | Array<Document> | nil ] A document or matching documents.
|
@@ -331,7 +348,7 @@ module Mongoid
|
|
331
348
|
# @example Substitute the association's target.
|
332
349
|
# person.addresses.substitute([ address ])
|
333
350
|
#
|
334
|
-
# @param [ Array<Document> ] docs The replacement docs.
|
351
|
+
# @param [ Array<Document> | Array<Hash> ] docs The replacement docs.
|
335
352
|
#
|
336
353
|
# @return [ Many ] The proxied association.
|
337
354
|
def substitute(docs)
|
@@ -397,21 +414,6 @@ module Mongoid
|
|
397
414
|
_association.criteria(_base, _target)
|
398
415
|
end
|
399
416
|
|
400
|
-
# Deletes one document from the target and unscoped.
|
401
|
-
#
|
402
|
-
# @api private
|
403
|
-
#
|
404
|
-
# @example Delete one document.
|
405
|
-
# relation.delete_one(doc)
|
406
|
-
#
|
407
|
-
# @param [ Document ] document The document to delete.
|
408
|
-
def delete_one(document)
|
409
|
-
_target.delete_one(document)
|
410
|
-
_unscoped.delete_one(document)
|
411
|
-
update_attributes_hash
|
412
|
-
reindex
|
413
|
-
end
|
414
|
-
|
415
417
|
# Integrate the document into the association. will set its metadata and
|
416
418
|
# attempt to bind the inverse.
|
417
419
|
#
|
@@ -430,10 +432,10 @@ module Mongoid
|
|
430
432
|
# If the method exists on the array, use the default proxy behavior.
|
431
433
|
#
|
432
434
|
# @param [ Symbol | String ] name The name of the method.
|
433
|
-
# @param [
|
435
|
+
# @param [ Object... ] *args The method args.
|
434
436
|
# @param [ Proc ] block Optional block to pass.
|
435
437
|
#
|
436
|
-
# @return [ Criteria
|
438
|
+
# @return [ Criteria | Object ] A Criteria or return value from the target.
|
437
439
|
ruby2_keywords def method_missing(name, *args, &block)
|
438
440
|
return super if _target.respond_to?(name)
|
439
441
|
klass.send(:with_scope, criteria) do
|
@@ -17,7 +17,7 @@ module Mongoid
|
|
17
17
|
# Builder.new(meta, attrs).build
|
18
18
|
#
|
19
19
|
# @param [ Document ] base The document this association hangs off of.
|
20
|
-
# @param [ Document ] object The related document.
|
20
|
+
# @param [ Document | Hash ] object The related document.
|
21
21
|
# @param [ String ] _type Not used in this context.
|
22
22
|
# @param [ Hash ] selected_fields Fields which were retrieved via
|
23
23
|
# #only. If selected_fields are specified, fields not listed in it
|
@@ -43,7 +43,7 @@ module Mongoid
|
|
43
43
|
# @example Substitute the new document.
|
44
44
|
# person.name.substitute(new_name)
|
45
45
|
#
|
46
|
-
# @param [ Document ] replacement A document to replace the target.
|
46
|
+
# @param [ Document | Hash ] replacement A document to replace the target.
|
47
47
|
#
|
48
48
|
# @return [ Document | nil ] The association or nil.
|
49
49
|
def substitute(replacement)
|
@@ -32,6 +32,8 @@ module Mongoid
|
|
32
32
|
parent.send(association.setter, Factory.build(@class_name, attributes))
|
33
33
|
elsif delete?
|
34
34
|
parent.send(association.setter, nil)
|
35
|
+
else
|
36
|
+
check_for_id_violation!
|
35
37
|
end
|
36
38
|
end
|
37
39
|
|
@@ -54,6 +56,17 @@ module Mongoid
|
|
54
56
|
|
55
57
|
private
|
56
58
|
|
59
|
+
# Extracts and converts the id to the expected type.
|
60
|
+
#
|
61
|
+
# @return [ BSON::ObjectId | String | Object | nil ] The converted id,
|
62
|
+
# or nil if no id is present in the attributes hash.
|
63
|
+
def extracted_id
|
64
|
+
@extracted_id ||= begin
|
65
|
+
id = association.klass.extract_id_field(attributes)
|
66
|
+
convert_id(existing.class, id)
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
57
70
|
# Is the id in the attributes acceptable for allowing an update to
|
58
71
|
# the existing association?
|
59
72
|
#
|
@@ -64,8 +77,7 @@ module Mongoid
|
|
64
77
|
#
|
65
78
|
# @return [ true | false ] If the id part of the logic will allow an update.
|
66
79
|
def acceptable_id?
|
67
|
-
id =
|
68
|
-
id = convert_id(existing.class, id)
|
80
|
+
id = extracted_id
|
69
81
|
existing._id == id || id.nil? || (existing._id != id && update_only?)
|
70
82
|
end
|
71
83
|
|
@@ -110,6 +122,32 @@ module Mongoid
|
|
110
122
|
def update?
|
111
123
|
existing && !destroyable? && acceptable_id?
|
112
124
|
end
|
125
|
+
|
126
|
+
# Checks to see if the _id attribute (which is supposed to be
|
127
|
+
# immutable) is being asked to change. If so, raise an exception.
|
128
|
+
#
|
129
|
+
# If Mongoid::Config.immutable_ids is false, this will do nothing,
|
130
|
+
# and the update operation will fail silently.
|
131
|
+
#
|
132
|
+
# @raise [ Errors::ImmutableAttribute ] if _id has changed, and
|
133
|
+
# the document has been persisted.
|
134
|
+
def check_for_id_violation!
|
135
|
+
# look for the basic criteria of an update (see #update?)
|
136
|
+
return unless existing&.persisted? && !destroyable?
|
137
|
+
|
138
|
+
# if the id is either absent, or if it equals the existing record's
|
139
|
+
# id, there is no immutability violation.
|
140
|
+
id = extracted_id
|
141
|
+
return if existing._id == id || id.nil?
|
142
|
+
|
143
|
+
# otherwise, an attempt has been made to set the _id of an existing,
|
144
|
+
# persisted document.
|
145
|
+
if Mongoid::Config.immutable_ids
|
146
|
+
raise Errors::ImmutableAttribute.new(:_id, id)
|
147
|
+
else
|
148
|
+
Mongoid::Warnings.warn_mutable_ids
|
149
|
+
end
|
150
|
+
end
|
113
151
|
end
|
114
152
|
end
|
115
153
|
end
|
@@ -118,7 +118,7 @@ module Mongoid
|
|
118
118
|
# to the target of the proxy. This can be overridden in special cases.
|
119
119
|
#
|
120
120
|
# @param [ String | Symbol ] name The name of the method.
|
121
|
-
# @param [
|
121
|
+
# @param [ Object... ] *args The arguments passed to the method.
|
122
122
|
ruby2_keywords def method_missing(name, *args, &block)
|
123
123
|
_target.send(name, *args, &block)
|
124
124
|
end
|
@@ -13,7 +13,7 @@ module Mongoid
|
|
13
13
|
# @example Reset the given counter cache
|
14
14
|
# post.reset_counters(:comments)
|
15
15
|
#
|
16
|
-
# @param [ Symbol
|
16
|
+
# @param [ Symbol... ] *counters One or more counter caches to reset.
|
17
17
|
def reset_counters(*counters)
|
18
18
|
self.class.with(persistence_context) do |_class|
|
19
19
|
_class.reset_counters(self, *counters)
|
@@ -30,7 +30,7 @@ module Mongoid
|
|
30
30
|
# Post.reset_counters('50e0edd97c71c17ea9000001', :comments)
|
31
31
|
#
|
32
32
|
# @param [ String ] id The id of the object that will be reset.
|
33
|
-
# @param [ Symbol
|
33
|
+
# @param [ Symbol... ] *counters One or more counter caches to reset.
|
34
34
|
def reset_counters(id, *counters)
|
35
35
|
document = id.is_a?(Document) ? id : find(id)
|
36
36
|
counters.each do |name|
|
@@ -21,7 +21,7 @@ module Mongoid
|
|
21
21
|
# @example Concat with other documents.
|
22
22
|
# person.posts.concat([ post_one, post_two ])
|
23
23
|
#
|
24
|
-
# @param [ Document
|
24
|
+
# @param [ Document... ] *args Any number of documents.
|
25
25
|
#
|
26
26
|
# @return [ Array<Document> ] The loaded docs.
|
27
27
|
def <<(*args)
|
@@ -137,6 +137,10 @@ module Mongoid
|
|
137
137
|
doc
|
138
138
|
end
|
139
139
|
|
140
|
+
# Mongoid::Extensions::Array defines Array#delete_one, so we need
|
141
|
+
# to make sure that method behaves reasonably on proxies, too.
|
142
|
+
alias delete_one delete
|
143
|
+
|
140
144
|
# Removes all associations between the base document and the target
|
141
145
|
# documents by deleting the foreign keys and the references, orphaning
|
142
146
|
# the target documents in the process.
|
@@ -215,13 +215,13 @@ module Mongoid
|
|
215
215
|
# completely depending on whether it is iterated to completion.
|
216
216
|
#
|
217
217
|
# This method can take a parameter and a block. The behavior with
|
218
|
-
# either the
|
218
|
+
# either the parameter or the block is delegated to the standard
|
219
219
|
# library Enumerable module.
|
220
220
|
#
|
221
221
|
# Note that when Enumerable's any? method is invoked with both
|
222
222
|
# a block and a pattern, it only uses the pattern.
|
223
223
|
#
|
224
|
-
# @param [ Object ]
|
224
|
+
# @param [ Object... ] *args The condition that documents
|
225
225
|
# must satisfy. See Enumerable documentation for details.
|
226
226
|
#
|
227
227
|
# @return [ true | false ] If the association has any documents.
|
@@ -25,7 +25,7 @@ module Mongoid
|
|
25
25
|
# @example Concat with other documents.
|
26
26
|
# person.posts.concat([ post_one, post_two ])
|
27
27
|
#
|
28
|
-
# @param [ Document
|
28
|
+
# @param [ Document... ] *args Any number of documents.
|
29
29
|
#
|
30
30
|
# @return [ Array<Document> ] The loaded docs.
|
31
31
|
def <<(*args)
|
@@ -105,6 +105,10 @@ module Mongoid
|
|
105
105
|
end
|
106
106
|
end
|
107
107
|
|
108
|
+
# Mongoid::Extensions::Array defines Array#delete_one, so we need
|
109
|
+
# to make sure that method behaves reasonably on proxies, too.
|
110
|
+
alias delete_one delete
|
111
|
+
|
108
112
|
# Deletes all related documents from the database given the supplied
|
109
113
|
# conditions.
|
110
114
|
#
|
@@ -199,7 +203,7 @@ module Mongoid
|
|
199
203
|
# @note This will keep matching documents in memory for iteration
|
200
204
|
# later.
|
201
205
|
#
|
202
|
-
# @param [ Object | Array<Object> ] *args The ids.
|
206
|
+
# @param [ [ Object | Array<Object> ]... ] *args The ids.
|
203
207
|
# @param [ Proc ] block Optional block to pass.
|
204
208
|
#
|
205
209
|
# @return [ Document | Array<Document> | nil ] A document or matching documents.
|
@@ -414,7 +418,7 @@ module Mongoid
|
|
414
418
|
# If the method exists on the array, use the default proxy behavior.
|
415
419
|
#
|
416
420
|
# @param [ Symbol | String ] name The name of the method.
|
417
|
-
# @param [
|
421
|
+
# @param [ Object... ] *args The method args
|
418
422
|
# @param [ Proc ] block Optional block to pass.
|
419
423
|
#
|
420
424
|
# @return [ Criteria | Object ] A Criteria or return value from the target.
|
@@ -25,7 +25,7 @@ module Mongoid
|
|
25
25
|
# @example Find multiple association metadata by macro.
|
26
26
|
# person.reflect_on_all_associations(:embeds_many)
|
27
27
|
#
|
28
|
-
# @param [
|
28
|
+
# @param [ Symbol... ] *macros The association macros.
|
29
29
|
#
|
30
30
|
# @return [ Array<Association> ] The matching association metadata.
|
31
31
|
def reflect_on_all_association(*macros)
|
@@ -51,7 +51,7 @@ module Mongoid
|
|
51
51
|
# @example Find multiple association metadata by macro.
|
52
52
|
# Person.reflect_on_all_associations(:embeds_many)
|
53
53
|
#
|
54
|
-
# @param [
|
54
|
+
# @param [ Symbol... ] *macros The association macros.
|
55
55
|
#
|
56
56
|
# @return [ Array<Association> ] The matching association metadata.
|
57
57
|
def reflect_on_all_associations(*macros)
|
@@ -115,7 +115,7 @@ module Mongoid
|
|
115
115
|
# document.method_missing(:test)
|
116
116
|
#
|
117
117
|
# @param [ String | Symbol ] name The name of the method.
|
118
|
-
# @param [
|
118
|
+
# @param [ Object... ] *args The arguments to the method.
|
119
119
|
#
|
120
120
|
# @return [ Object ] The result of the method call.
|
121
121
|
def method_missing(name, *args)
|
@@ -33,8 +33,8 @@ module Mongoid
|
|
33
33
|
# accepts_nested_attributes_for :addresses, :game, :posts
|
34
34
|
# end
|
35
35
|
#
|
36
|
-
# @param [
|
37
|
-
# by
|
36
|
+
# @param [ Symbol..., Hash ] *args A list of association names, followed
|
37
|
+
# by an optional hash of options.
|
38
38
|
#
|
39
39
|
# @option *args [ true | false ] :allow_destroy Can deletion occur?
|
40
40
|
# @option *args [ Proc | Symbol ] :reject_if Block or symbol pointing
|
@@ -6,7 +6,7 @@ module Mongoid
|
|
6
6
|
# This module defines projection helpers.
|
7
7
|
#
|
8
8
|
# Projection rules are rather non-trivial. See
|
9
|
-
# https://
|
9
|
+
# https://www.mongodb.com/docs/manual/reference/method/db.collection.find/#find-projection
|
10
10
|
# for server documentation.
|
11
11
|
# 4.4 server (and presumably all older ones) requires that a projection
|
12
12
|
# for content fields is either exclusionary or inclusionary, i.e. one
|
@@ -61,7 +61,7 @@ module Mongoid
|
|
61
61
|
# attr_readonly :name, :genre
|
62
62
|
# end
|
63
63
|
#
|
64
|
-
# @param [
|
64
|
+
# @param [ Symbol... ] *names The names of the fields.
|
65
65
|
def attr_readonly(*names)
|
66
66
|
names.each do |name|
|
67
67
|
readonly_attributes << database_field_name(name)
|
data/lib/mongoid/attributes.rb
CHANGED
@@ -177,8 +177,14 @@ module Mongoid
|
|
177
177
|
attribute_will_change!(field_name)
|
178
178
|
end
|
179
179
|
if localized
|
180
|
-
|
181
|
-
|
180
|
+
present = fields[field_name].try(:localize_present?)
|
181
|
+
loc_key, loc_val = typed_value.first
|
182
|
+
if present && loc_val.blank?
|
183
|
+
attributes[field_name]&.delete(loc_key)
|
184
|
+
else
|
185
|
+
attributes[field_name] ||= {}
|
186
|
+
attributes[field_name].merge!(typed_value)
|
187
|
+
end
|
182
188
|
else
|
183
189
|
attributes[field_name] = typed_value
|
184
190
|
end
|