mongoid-braxton 2.0.2
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.
- data/LICENSE +20 -0
- data/README.rdoc +50 -0
- data/Rakefile +51 -0
- data/lib/config/locales/bg.yml +41 -0
- data/lib/config/locales/de.yml +41 -0
- data/lib/config/locales/en.yml +45 -0
- data/lib/config/locales/es.yml +41 -0
- data/lib/config/locales/fr.yml +42 -0
- data/lib/config/locales/hu.yml +44 -0
- data/lib/config/locales/id.yml +46 -0
- data/lib/config/locales/it.yml +39 -0
- data/lib/config/locales/ja.yml +40 -0
- data/lib/config/locales/kr.yml +65 -0
- data/lib/config/locales/nl.yml +39 -0
- data/lib/config/locales/pl.yml +39 -0
- data/lib/config/locales/pt-BR.yml +40 -0
- data/lib/config/locales/pt.yml +40 -0
- data/lib/config/locales/ro.yml +46 -0
- data/lib/config/locales/ru.yml +41 -0
- data/lib/config/locales/sv.yml +40 -0
- data/lib/config/locales/vi.yml +45 -0
- data/lib/config/locales/zh-CN.yml +33 -0
- data/lib/mongoid.rb +140 -0
- data/lib/mongoid/atomicity.rb +111 -0
- data/lib/mongoid/attributes.rb +185 -0
- data/lib/mongoid/attributes/processing.rb +145 -0
- data/lib/mongoid/callbacks.rb +23 -0
- data/lib/mongoid/collection.rb +137 -0
- data/lib/mongoid/collections.rb +71 -0
- data/lib/mongoid/collections/master.rb +37 -0
- data/lib/mongoid/collections/operations.rb +42 -0
- data/lib/mongoid/collections/retry.rb +39 -0
- data/lib/mongoid/components.rb +45 -0
- data/lib/mongoid/config.rb +349 -0
- data/lib/mongoid/config/database.rb +167 -0
- data/lib/mongoid/config/replset_database.rb +78 -0
- data/lib/mongoid/contexts.rb +19 -0
- data/lib/mongoid/contexts/enumerable.rb +275 -0
- data/lib/mongoid/contexts/enumerable/sort.rb +43 -0
- data/lib/mongoid/contexts/mongo.rb +345 -0
- data/lib/mongoid/copyable.rb +46 -0
- data/lib/mongoid/criteria.rb +357 -0
- data/lib/mongoid/criterion/builder.rb +34 -0
- data/lib/mongoid/criterion/complex.rb +34 -0
- data/lib/mongoid/criterion/creational.rb +34 -0
- data/lib/mongoid/criterion/exclusion.rb +108 -0
- data/lib/mongoid/criterion/inclusion.rb +198 -0
- data/lib/mongoid/criterion/inspection.rb +22 -0
- data/lib/mongoid/criterion/optional.rb +193 -0
- data/lib/mongoid/criterion/selector.rb +143 -0
- data/lib/mongoid/criterion/unconvertable.rb +20 -0
- data/lib/mongoid/cursor.rb +86 -0
- data/lib/mongoid/default_scope.rb +36 -0
- data/lib/mongoid/dirty.rb +253 -0
- data/lib/mongoid/document.rb +284 -0
- data/lib/mongoid/errors.rb +13 -0
- data/lib/mongoid/errors/document_not_found.rb +29 -0
- data/lib/mongoid/errors/invalid_collection.rb +19 -0
- data/lib/mongoid/errors/invalid_database.rb +20 -0
- data/lib/mongoid/errors/invalid_field.rb +19 -0
- data/lib/mongoid/errors/invalid_options.rb +16 -0
- data/lib/mongoid/errors/invalid_type.rb +26 -0
- data/lib/mongoid/errors/mixed_relations.rb +37 -0
- data/lib/mongoid/errors/mongoid_error.rb +27 -0
- data/lib/mongoid/errors/too_many_nested_attribute_records.rb +21 -0
- data/lib/mongoid/errors/unsaved_document.rb +23 -0
- data/lib/mongoid/errors/unsupported_version.rb +21 -0
- data/lib/mongoid/errors/validations.rb +24 -0
- data/lib/mongoid/extensions.rb +123 -0
- data/lib/mongoid/extensions/array/conversions.rb +23 -0
- data/lib/mongoid/extensions/array/parentization.rb +13 -0
- data/lib/mongoid/extensions/big_decimal/conversions.rb +19 -0
- data/lib/mongoid/extensions/binary/conversions.rb +17 -0
- data/lib/mongoid/extensions/boolean/conversions.rb +27 -0
- data/lib/mongoid/extensions/date/conversions.rb +25 -0
- data/lib/mongoid/extensions/datetime/conversions.rb +12 -0
- data/lib/mongoid/extensions/false_class/equality.rb +13 -0
- data/lib/mongoid/extensions/float/conversions.rb +20 -0
- data/lib/mongoid/extensions/hash/conversions.rb +19 -0
- data/lib/mongoid/extensions/hash/criteria_helpers.rb +22 -0
- data/lib/mongoid/extensions/hash/scoping.rb +12 -0
- data/lib/mongoid/extensions/integer/conversions.rb +20 -0
- data/lib/mongoid/extensions/nil/collectionization.rb +12 -0
- data/lib/mongoid/extensions/object/checks.rb +32 -0
- data/lib/mongoid/extensions/object/conversions.rb +25 -0
- data/lib/mongoid/extensions/object/reflections.rb +17 -0
- data/lib/mongoid/extensions/object/yoda.rb +27 -0
- data/lib/mongoid/extensions/object_id/conversions.rb +96 -0
- data/lib/mongoid/extensions/proc/scoping.rb +12 -0
- data/lib/mongoid/extensions/range/conversions.rb +25 -0
- data/lib/mongoid/extensions/set/conversions.rb +20 -0
- data/lib/mongoid/extensions/string/conversions.rb +34 -0
- data/lib/mongoid/extensions/string/inflections.rb +97 -0
- data/lib/mongoid/extensions/symbol/conversions.rb +21 -0
- data/lib/mongoid/extensions/symbol/inflections.rb +40 -0
- data/lib/mongoid/extensions/time_conversions.rb +38 -0
- data/lib/mongoid/extensions/true_class/equality.rb +13 -0
- data/lib/mongoid/extras.rb +42 -0
- data/lib/mongoid/factory.rb +37 -0
- data/lib/mongoid/field.rb +162 -0
- data/lib/mongoid/fields.rb +183 -0
- data/lib/mongoid/finders.rb +127 -0
- data/lib/mongoid/hierarchy.rb +85 -0
- data/lib/mongoid/identity.rb +92 -0
- data/lib/mongoid/indexes.rb +38 -0
- data/lib/mongoid/inspection.rb +54 -0
- data/lib/mongoid/javascript.rb +21 -0
- data/lib/mongoid/javascript/functions.yml +37 -0
- data/lib/mongoid/json.rb +16 -0
- data/lib/mongoid/keys.rb +131 -0
- data/lib/mongoid/logger.rb +18 -0
- data/lib/mongoid/matchers.rb +32 -0
- data/lib/mongoid/matchers/all.rb +11 -0
- data/lib/mongoid/matchers/default.rb +70 -0
- data/lib/mongoid/matchers/exists.rb +13 -0
- data/lib/mongoid/matchers/gt.rb +11 -0
- data/lib/mongoid/matchers/gte.rb +11 -0
- data/lib/mongoid/matchers/in.rb +11 -0
- data/lib/mongoid/matchers/lt.rb +11 -0
- data/lib/mongoid/matchers/lte.rb +11 -0
- data/lib/mongoid/matchers/ne.rb +11 -0
- data/lib/mongoid/matchers/nin.rb +11 -0
- data/lib/mongoid/matchers/or.rb +30 -0
- data/lib/mongoid/matchers/size.rb +11 -0
- data/lib/mongoid/matchers/strategies.rb +63 -0
- data/lib/mongoid/multi_database.rb +11 -0
- data/lib/mongoid/multi_parameter_attributes.rb +82 -0
- data/lib/mongoid/named_scope.rb +137 -0
- data/lib/mongoid/nested_attributes.rb +51 -0
- data/lib/mongoid/observer.rb +67 -0
- data/lib/mongoid/paranoia.rb +103 -0
- data/lib/mongoid/paths.rb +61 -0
- data/lib/mongoid/persistence.rb +240 -0
- data/lib/mongoid/persistence/atomic.rb +88 -0
- data/lib/mongoid/persistence/atomic/add_to_set.rb +32 -0
- data/lib/mongoid/persistence/atomic/inc.rb +28 -0
- data/lib/mongoid/persistence/atomic/operation.rb +44 -0
- data/lib/mongoid/persistence/atomic/pull_all.rb +33 -0
- data/lib/mongoid/persistence/atomic/push.rb +28 -0
- data/lib/mongoid/persistence/command.rb +71 -0
- data/lib/mongoid/persistence/insert.rb +53 -0
- data/lib/mongoid/persistence/insert_embedded.rb +43 -0
- data/lib/mongoid/persistence/remove.rb +44 -0
- data/lib/mongoid/persistence/remove_all.rb +40 -0
- data/lib/mongoid/persistence/remove_embedded.rb +48 -0
- data/lib/mongoid/persistence/update.rb +77 -0
- data/lib/mongoid/railtie.rb +139 -0
- data/lib/mongoid/railties/database.rake +171 -0
- data/lib/mongoid/railties/document.rb +12 -0
- data/lib/mongoid/relations.rb +107 -0
- data/lib/mongoid/relations/accessors.rb +175 -0
- data/lib/mongoid/relations/auto_save.rb +34 -0
- data/lib/mongoid/relations/binding.rb +26 -0
- data/lib/mongoid/relations/bindings.rb +9 -0
- data/lib/mongoid/relations/bindings/embedded/in.rb +82 -0
- data/lib/mongoid/relations/bindings/embedded/many.rb +98 -0
- data/lib/mongoid/relations/bindings/embedded/one.rb +66 -0
- data/lib/mongoid/relations/bindings/referenced/in.rb +74 -0
- data/lib/mongoid/relations/bindings/referenced/many.rb +96 -0
- data/lib/mongoid/relations/bindings/referenced/many_to_many.rb +103 -0
- data/lib/mongoid/relations/bindings/referenced/one.rb +66 -0
- data/lib/mongoid/relations/builder.rb +42 -0
- data/lib/mongoid/relations/builders.rb +79 -0
- data/lib/mongoid/relations/builders/embedded/in.rb +25 -0
- data/lib/mongoid/relations/builders/embedded/many.rb +32 -0
- data/lib/mongoid/relations/builders/embedded/one.rb +26 -0
- data/lib/mongoid/relations/builders/nested_attributes/many.rb +126 -0
- data/lib/mongoid/relations/builders/nested_attributes/one.rb +135 -0
- data/lib/mongoid/relations/builders/referenced/in.rb +29 -0
- data/lib/mongoid/relations/builders/referenced/many.rb +47 -0
- data/lib/mongoid/relations/builders/referenced/many_to_many.rb +29 -0
- data/lib/mongoid/relations/builders/referenced/one.rb +27 -0
- data/lib/mongoid/relations/cascading.rb +55 -0
- data/lib/mongoid/relations/cascading/delete.rb +19 -0
- data/lib/mongoid/relations/cascading/destroy.rb +19 -0
- data/lib/mongoid/relations/cascading/nullify.rb +18 -0
- data/lib/mongoid/relations/cascading/strategy.rb +26 -0
- data/lib/mongoid/relations/constraint.rb +42 -0
- data/lib/mongoid/relations/cyclic.rb +103 -0
- data/lib/mongoid/relations/embedded/atomic.rb +86 -0
- data/lib/mongoid/relations/embedded/atomic/operation.rb +63 -0
- data/lib/mongoid/relations/embedded/atomic/pull.rb +65 -0
- data/lib/mongoid/relations/embedded/atomic/push_all.rb +59 -0
- data/lib/mongoid/relations/embedded/atomic/set.rb +61 -0
- data/lib/mongoid/relations/embedded/atomic/unset.rb +41 -0
- data/lib/mongoid/relations/embedded/in.rb +173 -0
- data/lib/mongoid/relations/embedded/many.rb +499 -0
- data/lib/mongoid/relations/embedded/one.rb +170 -0
- data/lib/mongoid/relations/macros.rb +310 -0
- data/lib/mongoid/relations/many.rb +215 -0
- data/lib/mongoid/relations/metadata.rb +539 -0
- data/lib/mongoid/relations/nested_builder.rb +68 -0
- data/lib/mongoid/relations/one.rb +47 -0
- data/lib/mongoid/relations/polymorphic.rb +54 -0
- data/lib/mongoid/relations/proxy.rb +143 -0
- data/lib/mongoid/relations/referenced/batch.rb +71 -0
- data/lib/mongoid/relations/referenced/batch/insert.rb +57 -0
- data/lib/mongoid/relations/referenced/in.rb +216 -0
- data/lib/mongoid/relations/referenced/many.rb +516 -0
- data/lib/mongoid/relations/referenced/many_to_many.rb +396 -0
- data/lib/mongoid/relations/referenced/one.rb +222 -0
- data/lib/mongoid/relations/reflections.rb +45 -0
- data/lib/mongoid/safe.rb +23 -0
- data/lib/mongoid/safety.rb +207 -0
- data/lib/mongoid/scope.rb +31 -0
- data/lib/mongoid/serialization.rb +99 -0
- data/lib/mongoid/sharding.rb +51 -0
- data/lib/mongoid/state.rb +67 -0
- data/lib/mongoid/timestamps.rb +14 -0
- data/lib/mongoid/timestamps/created.rb +31 -0
- data/lib/mongoid/timestamps/updated.rb +33 -0
- data/lib/mongoid/validations.rb +124 -0
- data/lib/mongoid/validations/associated.rb +44 -0
- data/lib/mongoid/validations/referenced.rb +58 -0
- data/lib/mongoid/validations/uniqueness.rb +85 -0
- data/lib/mongoid/version.rb +4 -0
- data/lib/mongoid/versioning.rb +113 -0
- data/lib/rails/generators/mongoid/config/config_generator.rb +25 -0
- data/lib/rails/generators/mongoid/config/templates/mongoid.yml +20 -0
- data/lib/rails/generators/mongoid/model/model_generator.rb +24 -0
- data/lib/rails/generators/mongoid/model/templates/model.rb +19 -0
- data/lib/rails/generators/mongoid/observer/observer_generator.rb +17 -0
- data/lib/rails/generators/mongoid/observer/templates/observer.rb +4 -0
- data/lib/rails/generators/mongoid_generator.rb +70 -0
- data/lib/rails/mongoid.rb +58 -0
- metadata +406 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
|
|
5
|
+
# This module contains the behaviour for auto-saving relations in
|
|
6
|
+
# different collections.
|
|
7
|
+
module AutoSave
|
|
8
|
+
extend ActiveSupport::Concern
|
|
9
|
+
|
|
10
|
+
module ClassMethods #:nodoc:
|
|
11
|
+
|
|
12
|
+
# Set up the autosave behaviour for references many and references one
|
|
13
|
+
# relations. When the option is set to true, these relations will get
|
|
14
|
+
# saved automatically when the parent is first saved, but not if the
|
|
15
|
+
# parent already exists in the database.
|
|
16
|
+
#
|
|
17
|
+
# @example Set up autosave options.
|
|
18
|
+
# Person.autosave(metadata)
|
|
19
|
+
#
|
|
20
|
+
# @param [ Metadata ] metadata The relation metadata.
|
|
21
|
+
#
|
|
22
|
+
# @since 2.0.0.rc.1
|
|
23
|
+
def autosave(metadata)
|
|
24
|
+
if metadata.autosave?
|
|
25
|
+
set_callback :create, :after do |document|
|
|
26
|
+
relation = document.send(metadata.name)
|
|
27
|
+
relation.to_a.each(&:save) if relation
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
end
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
|
|
5
|
+
# Superclass for all objects that bind relations together.
|
|
6
|
+
class Binding
|
|
7
|
+
attr_reader :base, :target, :metadata
|
|
8
|
+
|
|
9
|
+
OPTIONS = { :binding => true, :continue => false }
|
|
10
|
+
|
|
11
|
+
# Create the new binding.
|
|
12
|
+
#
|
|
13
|
+
# @example Initialize a binding.
|
|
14
|
+
# Binding.new(base, target, metadata)
|
|
15
|
+
#
|
|
16
|
+
# @param [ Document ] base The base of the binding.
|
|
17
|
+
# @param [ Document, Array<Document> ] target The target of the binding.
|
|
18
|
+
# @param [ Metadata ] metadata The relation's metadata.
|
|
19
|
+
#
|
|
20
|
+
# @since 2.0.0.rc.1
|
|
21
|
+
def initialize(base, target, metadata)
|
|
22
|
+
@base, @target, @metadata = base, target, metadata
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
require "mongoid/relations/binding"
|
|
3
|
+
require "mongoid/relations/bindings/embedded/in"
|
|
4
|
+
require "mongoid/relations/bindings/embedded/many"
|
|
5
|
+
require "mongoid/relations/bindings/embedded/one"
|
|
6
|
+
require "mongoid/relations/bindings/referenced/in"
|
|
7
|
+
require "mongoid/relations/bindings/referenced/many"
|
|
8
|
+
require "mongoid/relations/bindings/referenced/many_to_many"
|
|
9
|
+
require "mongoid/relations/bindings/referenced/one"
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
module Bindings #:nodoc:
|
|
5
|
+
module Embedded #:nodoc:
|
|
6
|
+
|
|
7
|
+
# Binding class for embedded_in relations.
|
|
8
|
+
class In < Binding
|
|
9
|
+
|
|
10
|
+
# Binds the base object to the inverse of the relation. This is so we
|
|
11
|
+
# are referenced to the actual objects themselves on both sides.
|
|
12
|
+
#
|
|
13
|
+
# This case sets the metadata on the inverse object as well as the
|
|
14
|
+
# document itself.
|
|
15
|
+
#
|
|
16
|
+
# @example Bind the documents.
|
|
17
|
+
# name.person.bind(:continue => true)
|
|
18
|
+
# name.person = Person.new
|
|
19
|
+
#
|
|
20
|
+
# @param [ Hash ] options The binding options.
|
|
21
|
+
#
|
|
22
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
23
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
24
|
+
#
|
|
25
|
+
# @since 2.0.0.rc.1
|
|
26
|
+
def bind(options = {})
|
|
27
|
+
inverse = metadata.inverse(target)
|
|
28
|
+
base.metadata = target.reflect_on_association(inverse)
|
|
29
|
+
base.parentize(target)
|
|
30
|
+
if options[:continue]
|
|
31
|
+
if base.embedded_many?
|
|
32
|
+
target.do_or_do_not(
|
|
33
|
+
inverse,
|
|
34
|
+
false,
|
|
35
|
+
:binding => true,
|
|
36
|
+
:continue => false
|
|
37
|
+
).push(base, :binding => true, :continue => false)
|
|
38
|
+
else
|
|
39
|
+
target.do_or_do_not(
|
|
40
|
+
metadata.inverse_setter(target),
|
|
41
|
+
base,
|
|
42
|
+
:binding => true,
|
|
43
|
+
:continue => false
|
|
44
|
+
)
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
alias :bind_one :bind
|
|
49
|
+
|
|
50
|
+
# Unbinds the base object and the inverse, caused by setting the
|
|
51
|
+
# reference to nil.
|
|
52
|
+
#
|
|
53
|
+
# @example Unbind the document.
|
|
54
|
+
# name.person.unbind(:continue => true)
|
|
55
|
+
# name.person = nil
|
|
56
|
+
#
|
|
57
|
+
# @param [ Hash ] options The options to pass through.
|
|
58
|
+
#
|
|
59
|
+
# @option options [ true, false ] :continue Do we continue unbinding?
|
|
60
|
+
#
|
|
61
|
+
# @since 2.0.0.rc.1
|
|
62
|
+
def unbind(options = {})
|
|
63
|
+
if options[:continue]
|
|
64
|
+
if base.embedded_many?
|
|
65
|
+
inverse = metadata.inverse(target)
|
|
66
|
+
target.do_or_do_not(inverse).delete(base)
|
|
67
|
+
else
|
|
68
|
+
target.do_or_do_not(
|
|
69
|
+
metadata.inverse_setter(target),
|
|
70
|
+
nil,
|
|
71
|
+
:binding => true,
|
|
72
|
+
:continue => false
|
|
73
|
+
)
|
|
74
|
+
end
|
|
75
|
+
end
|
|
76
|
+
end
|
|
77
|
+
alias :unbind_one :unbind
|
|
78
|
+
end
|
|
79
|
+
end
|
|
80
|
+
end
|
|
81
|
+
end
|
|
82
|
+
end
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
module Bindings #:nodoc:
|
|
5
|
+
module Embedded #:nodoc:
|
|
6
|
+
|
|
7
|
+
# Binding class for embeds_many relations.
|
|
8
|
+
class Many < Binding
|
|
9
|
+
|
|
10
|
+
# Binds the base object to the inverse of the relation. This is so we
|
|
11
|
+
# are referenced to the actual objects themselves on both sides.
|
|
12
|
+
#
|
|
13
|
+
# This case sets the metadata on the inverse object as well as the
|
|
14
|
+
# document itself.
|
|
15
|
+
#
|
|
16
|
+
# @example Bind all the documents.
|
|
17
|
+
# person.addresses.bind
|
|
18
|
+
# person.addresses = [ Address.new ]
|
|
19
|
+
#
|
|
20
|
+
# @param [ Hash ] options The binding options.
|
|
21
|
+
#
|
|
22
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
23
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
24
|
+
#
|
|
25
|
+
# @since 2.0.0.rc.1
|
|
26
|
+
def bind(options = {})
|
|
27
|
+
target.each { |doc| bind_one(doc, options) }
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
# Binds a single document with the inverse relation. Used
|
|
31
|
+
# specifically when appending to the proxy.
|
|
32
|
+
#
|
|
33
|
+
# @example Bind one document.
|
|
34
|
+
# person.addresses.bind_one(address)
|
|
35
|
+
#
|
|
36
|
+
# @param [ Document ] doc The single document to bind.
|
|
37
|
+
# @param [ Hash ] options The binding options.
|
|
38
|
+
#
|
|
39
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
40
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
41
|
+
#
|
|
42
|
+
# @since 2.0.0.rc.1
|
|
43
|
+
def bind_one(doc, options = {})
|
|
44
|
+
doc.parentize(base)
|
|
45
|
+
if options[:continue]
|
|
46
|
+
name = metadata.inverse_setter(target)
|
|
47
|
+
doc.do_or_do_not(
|
|
48
|
+
name,
|
|
49
|
+
base,
|
|
50
|
+
:binding => true,
|
|
51
|
+
:continue => false
|
|
52
|
+
) unless name == "versions="
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
# Unbinds the base object and the inverse, caused by setting the
|
|
57
|
+
# reference to nil.
|
|
58
|
+
#
|
|
59
|
+
# @example Unbind the documents.
|
|
60
|
+
# person.addresses.unbind
|
|
61
|
+
# person.addresses = nil
|
|
62
|
+
#
|
|
63
|
+
# @param [ Hash ] options The binding options.
|
|
64
|
+
#
|
|
65
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
66
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
67
|
+
#
|
|
68
|
+
# @since 2.0.0.rc.1
|
|
69
|
+
def unbind(options = {})
|
|
70
|
+
target.each { |doc| unbind_one(doc, options) }
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
# Unbind a single document.
|
|
74
|
+
#
|
|
75
|
+
# @example Unbind the document.
|
|
76
|
+
# person.addresses.unbind_one(document)
|
|
77
|
+
#
|
|
78
|
+
# @param [ Hash ] options The binding options.
|
|
79
|
+
#
|
|
80
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
81
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
82
|
+
#
|
|
83
|
+
# @since 2.0.0.rc.1
|
|
84
|
+
def unbind_one(doc, options = {})
|
|
85
|
+
if options[:continue]
|
|
86
|
+
doc.do_or_do_not(
|
|
87
|
+
metadata.inverse_setter(target),
|
|
88
|
+
nil,
|
|
89
|
+
:binding => true,
|
|
90
|
+
:continue => false
|
|
91
|
+
)
|
|
92
|
+
end
|
|
93
|
+
end
|
|
94
|
+
end
|
|
95
|
+
end
|
|
96
|
+
end
|
|
97
|
+
end
|
|
98
|
+
end
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
module Bindings #:nodoc:
|
|
5
|
+
module Embedded #:nodoc:
|
|
6
|
+
|
|
7
|
+
# Binding class for embeds_one relations.
|
|
8
|
+
class One < Binding
|
|
9
|
+
|
|
10
|
+
# Binds the base object to the inverse of the relation. This is so we
|
|
11
|
+
# are referenced to the actual objects themselves on both sides.
|
|
12
|
+
#
|
|
13
|
+
# This case sets the metadata on the inverse object as well as the
|
|
14
|
+
# document itself.
|
|
15
|
+
#
|
|
16
|
+
# @example Bind the document.
|
|
17
|
+
# person.name.bind(:continue => true)
|
|
18
|
+
# person.name = Name.new
|
|
19
|
+
#
|
|
20
|
+
# @param [ Hash ] options The options to pass through.
|
|
21
|
+
#
|
|
22
|
+
# @option options [ true, false ] :continue Do we continue binding?
|
|
23
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
24
|
+
#
|
|
25
|
+
# @since 2.0.0.rc.1
|
|
26
|
+
def bind(options = {})
|
|
27
|
+
if options[:continue]
|
|
28
|
+
target.do_or_do_not(
|
|
29
|
+
metadata.inverse_setter(target),
|
|
30
|
+
base,
|
|
31
|
+
:binding => true,
|
|
32
|
+
:continue => false
|
|
33
|
+
)
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
alias :bind_one :bind
|
|
37
|
+
|
|
38
|
+
# Unbinds the base object and the inverse, caused by setting the
|
|
39
|
+
# reference to nil.
|
|
40
|
+
#
|
|
41
|
+
# @example Unbind the document.
|
|
42
|
+
# person.name.unbind(:continue => true)
|
|
43
|
+
# person.name = nil
|
|
44
|
+
#
|
|
45
|
+
# @param [ Hash ] options The options to pass through.
|
|
46
|
+
#
|
|
47
|
+
# @option options [ true, false ] :continue Do we continue unbinding?
|
|
48
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
49
|
+
#
|
|
50
|
+
# @since 2.0.0.rc.1
|
|
51
|
+
def unbind(options = {})
|
|
52
|
+
if options[:continue]
|
|
53
|
+
target.do_or_do_not(
|
|
54
|
+
metadata.inverse_setter(target),
|
|
55
|
+
nil,
|
|
56
|
+
:binding => true,
|
|
57
|
+
:continue => false
|
|
58
|
+
)
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
alias :unbind_one :unbind
|
|
62
|
+
end
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
end
|
|
66
|
+
end
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
module Bindings #:nodoc:
|
|
5
|
+
module Referenced #:nodoc:
|
|
6
|
+
|
|
7
|
+
# Binding class for all referenced_in relations.
|
|
8
|
+
class In < Binding
|
|
9
|
+
|
|
10
|
+
# Binds the base object to the inverse of the relation. This is so we
|
|
11
|
+
# are referenced to the actual objects themselves on both sides.
|
|
12
|
+
#
|
|
13
|
+
# This case sets the metadata on the inverse object as well as the
|
|
14
|
+
# document itself.
|
|
15
|
+
#
|
|
16
|
+
# @example Bind the documents.
|
|
17
|
+
# game.person.bind(:continue => true)
|
|
18
|
+
# game.person = Person.new
|
|
19
|
+
#
|
|
20
|
+
# @param [ Hash ] options The binding options.
|
|
21
|
+
#
|
|
22
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
23
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
24
|
+
#
|
|
25
|
+
# @since 2.0.0.rc.1
|
|
26
|
+
def bind(options = {})
|
|
27
|
+
inverse = metadata.inverse(target)
|
|
28
|
+
base.send(metadata.foreign_key_setter, target.id)
|
|
29
|
+
if metadata.inverse_type
|
|
30
|
+
base.send(metadata.inverse_type_setter, target.class.model_name)
|
|
31
|
+
end
|
|
32
|
+
if inverse
|
|
33
|
+
base.metadata = target.reflect_on_association(inverse)
|
|
34
|
+
if options[:continue]
|
|
35
|
+
if base.referenced_many?
|
|
36
|
+
target.do_or_do_not(
|
|
37
|
+
inverse, false, OPTIONS
|
|
38
|
+
).push(base, :binding => true, :continue => false)
|
|
39
|
+
else
|
|
40
|
+
target.do_or_do_not(
|
|
41
|
+
metadata.inverse_setter(target),
|
|
42
|
+
base,
|
|
43
|
+
OPTIONS
|
|
44
|
+
)
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
alias :bind_one :bind
|
|
50
|
+
|
|
51
|
+
# Unbinds the base object and the inverse, caused by setting the
|
|
52
|
+
# reference to nil.
|
|
53
|
+
#
|
|
54
|
+
# @example Unbind the document.
|
|
55
|
+
# game.person.unbind(:continue => true)
|
|
56
|
+
# game.person = nil
|
|
57
|
+
#
|
|
58
|
+
# @param [ Hash ] options The options to pass through.
|
|
59
|
+
#
|
|
60
|
+
# @option options [ true, false ] :continue Do we continue unbinding?
|
|
61
|
+
#
|
|
62
|
+
# @since 2.0.0.rc.1
|
|
63
|
+
def unbind(options = {})
|
|
64
|
+
base.do_or_do_not(metadata.foreign_key_setter, nil)
|
|
65
|
+
if options[:continue]
|
|
66
|
+
target.do_or_do_not(metadata.inverse_setter(target), nil, OPTIONS)
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
alias :unbind_one :unbind
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
end
|
|
73
|
+
end
|
|
74
|
+
end
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
module Mongoid # :nodoc:
|
|
3
|
+
module Relations #:nodoc:
|
|
4
|
+
module Bindings #:nodoc:
|
|
5
|
+
module Referenced #:nodoc:
|
|
6
|
+
|
|
7
|
+
# Binding class for references_many relations.
|
|
8
|
+
class Many < Binding
|
|
9
|
+
|
|
10
|
+
# Binds the base object to the inverse of the relation. This is so we
|
|
11
|
+
# are referenced to the actual objects themselves on both sides.
|
|
12
|
+
#
|
|
13
|
+
# This case sets the metadata on the inverse object as well as the
|
|
14
|
+
# document itself.
|
|
15
|
+
#
|
|
16
|
+
# @example Bind all the documents.
|
|
17
|
+
# person.posts.bind
|
|
18
|
+
# person.posts = [ Post.new ]
|
|
19
|
+
#
|
|
20
|
+
# @param [ Hash ] options The binding options.
|
|
21
|
+
#
|
|
22
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
23
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
24
|
+
#
|
|
25
|
+
# @since 2.0.0.rc.1
|
|
26
|
+
def bind(options = {})
|
|
27
|
+
target.each { |doc| bind_one(doc, options) }
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
# Binds a single document with the inverse relation. Used
|
|
31
|
+
# specifically when appending to the proxy.
|
|
32
|
+
#
|
|
33
|
+
# @example Bind one document.
|
|
34
|
+
# person.posts.bind_one(post)
|
|
35
|
+
#
|
|
36
|
+
# @param [ Document ] doc The single document to bind.
|
|
37
|
+
# @param [ Hash ] options The binding options.
|
|
38
|
+
#
|
|
39
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
40
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
41
|
+
#
|
|
42
|
+
# @since 2.0.0.rc.1
|
|
43
|
+
def bind_one(doc, options = {})
|
|
44
|
+
if options[:continue]
|
|
45
|
+
doc.do_or_do_not(metadata.foreign_key_setter, base.id)
|
|
46
|
+
doc.do_or_do_not(
|
|
47
|
+
metadata.inverse_setter,
|
|
48
|
+
base,
|
|
49
|
+
OPTIONS
|
|
50
|
+
)
|
|
51
|
+
end
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
# Unbinds the base object and the inverse, caused by setting the
|
|
55
|
+
# reference to nil.
|
|
56
|
+
#
|
|
57
|
+
# @example Unbind the documents.
|
|
58
|
+
# person.posts.unbind
|
|
59
|
+
# person.posts = nil
|
|
60
|
+
#
|
|
61
|
+
# @param [ Hash ] options The binding options.
|
|
62
|
+
#
|
|
63
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
64
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
65
|
+
#
|
|
66
|
+
# @since 2.0.0.rc.1
|
|
67
|
+
def unbind(options = {})
|
|
68
|
+
target.each { |doc| unbind_one(doc, options) }
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
# Unbind a single document.
|
|
72
|
+
#
|
|
73
|
+
# @example Unbind the document.
|
|
74
|
+
# person.posts.unbind_one(document)
|
|
75
|
+
#
|
|
76
|
+
# @param [ Hash ] options The binding options.
|
|
77
|
+
#
|
|
78
|
+
# @option options [ true, false ] :continue Continue binding the inverse.
|
|
79
|
+
# @option options [ true, false ] :binding Are we in build mode?
|
|
80
|
+
#
|
|
81
|
+
# @since 2.0.0.rc.1
|
|
82
|
+
def unbind_one(doc, options = {})
|
|
83
|
+
if options[:continue]
|
|
84
|
+
doc.do_or_do_not(metadata.foreign_key_setter, nil)
|
|
85
|
+
doc.do_or_do_not(
|
|
86
|
+
metadata.inverse_setter,
|
|
87
|
+
nil,
|
|
88
|
+
OPTIONS
|
|
89
|
+
)
|
|
90
|
+
end
|
|
91
|
+
end
|
|
92
|
+
end
|
|
93
|
+
end
|
|
94
|
+
end
|
|
95
|
+
end
|
|
96
|
+
end
|