Module: Mongoid::Association::Options
- Included in:
- Relatable
- Defined in:
- lib/mongoid/association/options.rb
Overview
Options context used for all association types.
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.
-
#touchable? ⇒ true | false
private
Whether the association object should be automatically touched when its inverse object is updated.
-
#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.
10 11 12 |
# File 'lib/mongoid/association/options.rb', line 10 def as @options[:as] end |
#autobuilding? ⇒ true | false
Whether the association is autobuilding.
38 39 40 |
# File 'lib/mongoid/association/options.rb', line 38 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.
68 69 70 |
# File 'lib/mongoid/association/options.rb', line 68 def autosave !!@options[:autosave] end |
#cascading_callbacks? ⇒ true | false
Whether the association has callbacks cascaded down from the parent.
90 91 92 |
# File 'lib/mongoid/association/options.rb', line 90 def cascading_callbacks? !!@options[:cascade_callbacks] end |
#counter_cached? ⇒ true | false
Whether the association is counter-cached.
76 77 78 |
# File 'lib/mongoid/association/options.rb', line 76 def counter_cached? !!@options[:counter_cache] end |
#cyclic? ⇒ true | false
Is the association cyclic.
45 46 47 |
# File 'lib/mongoid/association/options.rb', line 45 def cyclic? !!@options[:cyclic] end |
#dependent ⇒ String
Specify what happens to the associated object when the owner is destroyed.
17 18 19 |
# File 'lib/mongoid/association/options.rb', line 17 def dependent @options[:dependent] end |
#forced_nil_inverse? ⇒ false
Whether the association has forced nil inverse (So no foreign keys are saved).
102 103 104 |
# File 'lib/mongoid/association/options.rb', line 102 def forced_nil_inverse? false end |
#indexed? ⇒ true | false
Whether to index the primary or foreign key field.
31 32 33 |
# File 'lib/mongoid/association/options.rb', line 31 def indexed? @indexed ||= !!@options[:index] end |
#inverse_of ⇒ String
The name the owning object uses to refer to this association.
52 53 54 |
# File 'lib/mongoid/association/options.rb', line 52 def inverse_of @options[:inverse_of] end |
#order ⇒ Criteria::Queryable::Key
The custom sorting options on the association.
24 25 26 |
# File 'lib/mongoid/association/options.rb', line 24 def order @options[:order] end |
#polymorphic? ⇒ true | false
Whether this association is polymorphic.
83 84 85 |
# File 'lib/mongoid/association/options.rb', line 83 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.
60 61 62 |
# File 'lib/mongoid/association/options.rb', line 60 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.
97 |
# File 'lib/mongoid/association/options.rb', line 97 def store_as; end |
#touch_field ⇒ nil
The field for saving the associated object's type.
114 115 116 |
# File 'lib/mongoid/association/options.rb', line 114 def touch_field @touch_field ||= [:touch] if [:touch].is_a?(String) || [:touch].is_a?(Symbol) end |
#touchable? ⇒ true | false
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Whether the association object should be automatically touched when its inverse object is updated.
125 126 127 |
# File 'lib/mongoid/association/options.rb', line 125 def touchable? !!@options[:touch] end |
#type ⇒ nil
The field for saving the associated object's type.
109 |
# File 'lib/mongoid/association/options.rb', line 109 def type; end |