Module: Mongoid::Associations::ClassMethods
- Defined in:
- lib/mongoid/associations.rb
Instance Method Summary collapse
-
#belongs_to(name, options = {}, &block) ⇒ Object
Adds the association back to the parent document.
-
#belongs_to_related(name, options = {}, &block) ⇒ Object
Adds a relational association from the child Document to a Document in another database or collection.
-
#has_many(name, options = {}, &block) ⇒ Object
Adds the association from a parent document to its children.
-
#has_many_related(name, options = {}, &block) ⇒ Object
Adds a relational association from the Document to many Documents in another database or collection.
-
#has_one(name, options = {}, &block) ⇒ Object
Adds the association from a parent document to its child.
-
#has_one_related(name, options = {}, &block) ⇒ Object
Adds a relational association from the Document to one Document in another database or collection.
-
#reflect_on_association(name) ⇒ Object
Returns the macro associated with the supplied association name.
Instance Method Details
#belongs_to(name, options = {}, &block) ⇒ Object
Adds the association back to the parent document. This macro is necessary to set the references from the child back to the parent document. If a child does not define this association calling persistence methods on the child object will cause a save to fail.
Options:
name: A Symbol
that matches the name of the parent class.
Example:
class Person
include Mongoid::Document
has_many :addresses
end
class Address
include Mongoid::Document
belongs_to :person, :inverse_of => :addresses
end
64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/mongoid/associations.rb', line 64 def belongs_to(name, = {}, &block) unless .has_key?(:inverse_of) raise Errors::InvalidOptions.new("Options for belongs_to association must include :inverse_of") end self. = true add_association( Associations::BelongsTo, Associations::Options.new( .merge(:name => name, :extend => block) ) ) end |
#belongs_to_related(name, options = {}, &block) ⇒ Object
91 92 93 94 95 96 97 98 |
# File 'lib/mongoid/associations.rb', line 91 def (name, = {}, &block) opts = Associations::Options.new( .merge(:name => name, :extend => block, :foreign_key => foreign_key(name, )) ) add_association(Associations::BelongsToRelated, opts) field(opts.foreign_key, :type => Mongoid.use_object_ids ? Mongo::ObjectID : String) index(opts.foreign_key) unless self. end |
#has_many(name, options = {}, &block) ⇒ Object
Adds the association from a parent document to its children. The name of the association needs to be a pluralized form of the child class name.
Options:
name: A Symbol
that is the plural child class name.
Example:
class Person
include Mongoid::Document
has_many :addresses
end
class Address
include Mongoid::Document
belongs_to :person, :inverse_of => :addresses
end
119 120 121 122 123 124 125 126 |
# File 'lib/mongoid/associations.rb', line 119 def has_many(name, = {}, &block) add_association( Associations::HasMany, Associations::Options.new( .merge(:name => name, :extend => block) ) ) end |
#has_many_related(name, options = {}, &block) ⇒ Object
142 143 144 145 146 147 148 149 150 151 |
# File 'lib/mongoid/associations.rb', line 142 def (name, = {}, &block) add_association(Associations::HasManyRelated, Associations::Options.new( .merge(:name => name, :foreign_key => foreign_key(self.name, ), :extend => block) ) ) before_save do |document| document.update_associations(name) end end |
#has_one(name, options = {}, &block) ⇒ Object
Adds the association from a parent document to its child. The name of the association needs to be a singular form of the child class name.
Options:
name: A Symbol
that is the plural child class name.
Example:
class Person
include Mongoid::Document
has_many :addresses
end
class Address
include Mongoid::Document
belongs_to :person
end
172 173 174 175 176 177 178 179 180 |
# File 'lib/mongoid/associations.rb', line 172 def has_one(name, = {}, &block) opts = Associations::Options.new( .merge(:name => name, :extend => block) ) type = Associations::HasOne add_association(type, opts) add_builder(type, opts) add_creator(type, opts) end |
#has_one_related(name, options = {}, &block) ⇒ Object
195 196 197 198 199 200 201 202 203 204 205 |
# File 'lib/mongoid/associations.rb', line 195 def (name, = {}, &block) add_association( Associations::HasOneRelated, Associations::Options.new( .merge(:name => name, :foreign_key => foreign_key(name, ), :extend => block) ) ) before_save do |document| document.update_association(name) end end |
#reflect_on_association(name) ⇒ Object
Returns the macro associated with the supplied association name. This will return has_one, has_many, belongs_to or nil.
Options:
name: The association name.
Example:
Person.reflect_on_association(:addresses)
217 218 219 220 |
# File 'lib/mongoid/associations.rb', line 217 def reflect_on_association(name) association = associations[name.to_s] association ? association.macro : nil end |