Module: Mongoid::Association::Options
- Included in:
- Relatable
- Defined in:
- lib/mongoid/association/options.rb
Instance Method Summary collapse
-
#as ⇒ String, Symbol
Returns the name of the parent to a polymorphic child.
-
#autobuilding? ⇒ true, false
Whether the association is autobuilding.
-
#autosave ⇒ true, false
(also: #autosave?)
Options to save any loaded members and destroy members that are marked for destruction when the parent object is saved.
-
#cascading_callbacks? ⇒ true, false
Whether the association has callbacks cascaded down from the parent.
-
#counter_cached? ⇒ true, false
Whether the association is counter-cached.
-
#cyclic? ⇒ true, false
Is the association cyclic.
-
#dependent ⇒ String
Specify what happens to the associated object when the owner is destroyed.
-
#forced_nil_inverse? ⇒ false
Whether the association has forced nil inverse (So no foreign keys are saved).
-
#indexed? ⇒ true, false
Whether to index the primary or foreign key field.
-
#inverse_of ⇒ String
The name the owning object uses to refer to this association.
-
#order ⇒ Criteria::Queryable::Key
The custom sorting options on the association.
-
#polymorphic? ⇒ true, false
Whether this association is polymorphic.
-
#primary_key ⇒ Symbol, String
Mongoid assumes that the field used to hold the primary key of the association is id.
-
#store_as ⇒ nil
The store_as option.
-
#touch_field ⇒ nil
The field for saving the associated object’s type.
-
#type ⇒ nil
The field for saving the associated object’s type.
Instance Method Details
#as ⇒ String, Symbol
Returns the name of the parent to a polymorphic child.
14 15 16 |
# File 'lib/mongoid/association/options.rb', line 14 def as @options[:as] end |
#autobuilding? ⇒ true, false
Whether the association is autobuilding.
50 51 52 |
# File 'lib/mongoid/association/options.rb', line 50 def autobuilding? !!@options[:autobuild] end |
#autosave ⇒ true, false Also known as: autosave?
Options to save any loaded members and destroy members that are marked for destruction when the parent object is saved.
88 89 90 |
# File 'lib/mongoid/association/options.rb', line 88 def autosave !!@options[:autosave] end |
#cascading_callbacks? ⇒ true, false
Whether the association has callbacks cascaded down from the parent.
114 115 116 |
# File 'lib/mongoid/association/options.rb', line 114 def cascading_callbacks? !!@options[:cascade_callbacks] end |
#counter_cached? ⇒ true, false
Whether the association is counter-cached.
98 99 100 |
# File 'lib/mongoid/association/options.rb', line 98 def counter_cached? !!@options[:counter_cache] end |
#cyclic? ⇒ true, false
Is the association cyclic.
59 60 61 |
# File 'lib/mongoid/association/options.rb', line 59 def cyclic? !!@options[:cyclic] end |
#dependent ⇒ String
Specify what happens to the associated object when the owner is destroyed.
23 24 25 |
# File 'lib/mongoid/association/options.rb', line 23 def dependent @options[:dependent] end |
#forced_nil_inverse? ⇒ false
Whether the association has forced nil inverse (So no foreign keys are saved).
130 |
# File 'lib/mongoid/association/options.rb', line 130 def forced_nil_inverse?; false; end |
#indexed? ⇒ true, false
Whether to index the primary or foreign key field.
41 42 43 |
# File 'lib/mongoid/association/options.rb', line 41 def indexed? @indexed ||= !!@options[:index] end |
#inverse_of ⇒ String
The name the owning object uses to refer to this association.
68 69 70 |
# File 'lib/mongoid/association/options.rb', line 68 def inverse_of @options[:inverse_of] end |
#order ⇒ Criteria::Queryable::Key
The custom sorting options on the association.
32 33 34 |
# File 'lib/mongoid/association/options.rb', line 32 def order @options[:order] end |
#polymorphic? ⇒ true, false
Whether this association is polymorphic.
107 |
# File 'lib/mongoid/association/options.rb', line 107 def polymorphic?; false; end |
#primary_key ⇒ Symbol, String
Mongoid assumes that the field used to hold the primary key of the association is id. You can override this and explicitly specify the primary key with the :primary_key option.
78 79 80 |
# File 'lib/mongoid/association/options.rb', line 78 def primary_key @primary_key ||= @options[:primary_key] ? @options[:primary_key].to_s : Relatable::PRIMARY_KEY_DEFAULT end |
#store_as ⇒ nil
The store_as option.
123 |
# File 'lib/mongoid/association/options.rb', line 123 def store_as; end |
#touch_field ⇒ nil
The field for saving the associated object’s type.
144 145 146 |
# File 'lib/mongoid/association/options.rb', line 144 def touch_field @touch_field ||= [:touch] if ([:touch].is_a?(String) || [:touch].is_a?(Symbol)) end |
#type ⇒ nil
The field for saving the associated object’s type.
137 |
# File 'lib/mongoid/association/options.rb', line 137 def type; end |