forked from mongodb/mongoid
/
in.rb
70 lines (67 loc) · 2.28 KB
/
in.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# encoding: utf-8
module Mongoid
module Relations
module Bindings
module Referenced
# Binding class for all referenced_in relations.
class In < Binding
# Binds the base object to the inverse of the relation. This is so we
# are referenced to the actual objects themselves on both sides.
#
# This case sets the metadata on the inverse object as well as the
# document itself.
#
# @example Bind the documents.
# game.person.bind(:continue => true)
# game.person = Person.new
#
# @since 2.0.0.rc.1
def bind_one
binding do
check_inverses!(target)
bind_foreign_key(base, target.id)
bind_polymorphic_inverse_type(base, target.class.model_name)
if inverse = metadata.inverse(target)
if set_base_metadata
bind_inverse_of_field(base, base.metadata_name)
if base.referenced_many?
target.__send__(inverse).push(base) unless Mongoid.using_identity_map?
else
target.do_or_do_not(metadata.inverse_setter(target), base)
end
end
end
end
end
# Unbinds the base object and the inverse, caused by setting the
# reference to nil.
#
# @example Unbind the document.
# game.person.unbind(:continue => true)
# game.person = nil
#
# @since 2.0.0.rc.1
def unbind_one
binding do
inverse = metadata.inverse(target)
if !inverse && metadata.inverse_of_field
inverse = base.__send__(metadata.inverse_of_field)
end
bind_foreign_key(base, nil)
bind_polymorphic_inverse_type(base, nil)
bind_inverse_of_field(base, nil)
if inverse
set_base_metadata
if base.referenced_many?
target.__send__(inverse).delete(base)
else
target.__send__("#{inverse}=", nil)
end
end
end
end
end
end
end
end
end