Module: Mongoid::Document
- Extended by:
- ActiveSupport::Concern
- Includes:
- Composable
- Defined in:
- lib/mongoid/document.rb,
lib/mongoid/railties/document.rb
Overview
This is the base module for all domain objects that need to be persisted to the database as documents.
Defined Under Namespace
Modules: ClassMethods
Constant Summary
Constants included from Composable
Constants included from Interceptable
Constants included from Persistable
Constants included from Matchable
Constants included from Fields
Fields::IDS, Fields::TYPE_MAPPINGS
Constants included from Atomic
Instance Attribute Summary collapse
-
#__selected_fields ⇒ Object
Returns the value of attribute __selected_fields.
-
#new_record ⇒ Object
readonly
Returns the value of attribute new_record.
Attributes included from Stateful
#destroyed, #flagged_for_destroy
Attributes included from Relations
Attributes included from Attributes
Instance Method Summary collapse
-
#_destroy ⇒ Object
Used in conjunction with fields_for to build a form element for the destruction of this association.
-
#as_document ⇒ Hash
Return a hash of the entire document hierarchy from this document and below.
-
#as_json(options = nil) ⇒ Hash
Calls #as_json on the document with additional, Mongoid-specific options.
-
#becomes(klass) ⇒ Document
Returns an instance of the specified class with the attributes, errors, and embedded documents of the current document.
-
#cache_key ⇒ String
Print out the cache key.
-
#freeze ⇒ Document
Freezes the internal attributes of the document.
-
#frozen? ⇒ true, false
Checks if the document is frozen.
-
#hash ⇒ Integer
Delegates to identity in order to allow two records of the same identity to work with something like:.
-
#identity ⇒ Array
A Document’s is identified absolutely by its class and database id:.
-
#initialize(attrs = nil) ⇒ Document
Instantiate a new
Document
, setting the Document’s attributes if given. -
#model_name ⇒ String
Return the model name of the document.
-
#to_a ⇒ Array<Document>
Return an array with this
Document
only in it. -
#to_key ⇒ String
Return the key value for the document.
Methods included from Composable
Methods included from Equality
Methods included from Copyable
Methods included from Interceptable
#callback_executable?, #in_callback_state?, #run_after_callbacks, #run_before_callbacks, #run_callbacks
Methods included from Validatable
#begin_validate, #exit_validate, #performing_validations?, #read_attribute_for_validation, #valid?, #validated?, #validating_with_query?
Methods included from Traversable
#_children, #_parent, #_parent=, #_reset_memoized_children!, #_root, #_root?, #collect_children, #flag_children_persisted, #hereditary?, #parentize, #remove_child, #reset_persisted_children
Methods included from Stateful
#destroyed?, #flagged_for_destroy?, #new_record?, #persisted?, #pushable?, #readonly?, #settable?, #updateable?
Methods included from Shardable
#shard_key_fields, #shard_key_selector
Methods included from Serializable
Methods included from Selectable
Methods included from Reloadable
Methods included from Relations
#embedded?, #embedded_many?, #embedded_one?, #metadata_name, #referenced_many?, #referenced_one?, #reload_relations
Methods included from Relations::CounterCache
Methods included from Relations::Touchable
Methods included from Relations::Synchronization
#remove_inverse_keys, #syncable?, #synced, #synced?, #update_inverse_keys
Methods included from Relations::Reflections
#reflect_on_all_associations, #reflect_on_association
Methods included from Relations::Macros
Methods included from Relations::Cascading
Methods included from Relations::AutoSave
#__autosaving__, #autosaved?, #changed_for_autosave?
Methods included from Relations::Accessors
#__build__, #create_relation, #reset_relation_criteria, #set_relation
Methods included from Persistable
#atomically, #fail_due_to_callback!, #fail_due_to_validation!, #hasherizer
Methods included from Persistable::Unsettable
Methods included from Persistable::Upsertable
Methods included from Persistable::Updatable
#update, #update!, #update_attribute
Methods included from Persistable::Settable
Methods included from Persistable::Savable
Methods included from Persistable::Renamable
Methods included from Persistable::Pushable
Methods included from Persistable::Pullable
Methods included from Positional
Methods included from Persistable::Poppable
Methods included from Persistable::Logical
Methods included from Persistable::Incrementable
Methods included from Persistable::Destroyable
Methods included from Persistable::Deletable
Methods included from Persistable::Creatable
Methods included from Matchable
Methods included from Inspectable
Methods included from Fields
#apply_default, #apply_defaults, #apply_post_processed_defaults, #apply_pre_processed_defaults, #attribute_names, #database_field_name, #lazy_settable?, option, options, #using_object_ids?
Methods included from Evolvable
Methods included from Attributes
#assign_attributes, #attribute_missing?, #attribute_present?, #attributes_before_type_cast, #has_attribute?, #has_attribute_before_type_cast?, #read_attribute, #read_attribute_before_type_cast, #remove_attribute, #write_attribute, #write_attributes
Methods included from Attributes::Readonly
Methods included from Attributes::Processing
Methods included from Clients
clear, clients, #collection, #collection_name, default, disconnect, #mongo_client, set, with_name
Methods included from Clients::Options
#collection_name, #mongo_client, #persistence_options, #with
Methods included from Changeable
#changed, #changed?, #changed_attributes, #changes, #children_changed?, #move_changes, #post_persist, #previous_changes, #remove_change, #setters
Methods included from Atomic
#add_atomic_pull, #add_atomic_unset, #atomic_array_add_to_sets, #atomic_array_pulls, #atomic_array_pushes, #atomic_attribute_name, #atomic_delete_modifier, #atomic_insert_modifier, #atomic_path, #atomic_paths, #atomic_position, #atomic_pulls, #atomic_pushes, #atomic_sets, #atomic_unsets, #atomic_updates, #delayed_atomic_pulls, #delayed_atomic_sets, #delayed_atomic_unsets, #flag_as_destroyed, #flagged_destroys, #process_flagged_destroys
Instance Attribute Details
#__selected_fields ⇒ Object
Returns the value of attribute __selected_fields.
27 28 29 |
# File 'lib/mongoid/document.rb', line 27 def __selected_fields @__selected_fields end |
#new_record ⇒ Object (readonly)
Returns the value of attribute new_record.
28 29 30 |
# File 'lib/mongoid/document.rb', line 28 def new_record @new_record end |
Instance Method Details
#_destroy ⇒ Object
Used in conjunction with fields_for to build a form element for the destruction of this association. Always returns false because Mongoid only supports immediate deletion of associations.
See ActionView::Helpers::FormHelper::fields_for for more info.
8 9 10 |
# File 'lib/mongoid/railties/document.rb', line 8 def _destroy false end |
#as_document ⇒ Hash
Return a hash of the entire document hierarchy from this document and below. Used when the attributes are needed for everything and not just the current document.
167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 |
# File 'lib/mongoid/document.rb', line 167 def as_document return attributes if frozen? .each_pair do |name, | without_autobuild do relation, stored = send(name), .store_as if attributes.key?(stored) || !relation.blank? if relation attributes[stored] = relation.as_document else attributes.delete(stored) end end end end attributes end |
#as_json(options = nil) ⇒ Hash
Calls #as_json on the document with additional, Mongoid-specific options.
197 198 199 200 201 202 203 |
# File 'lib/mongoid/document.rb', line 197 def as_json( = nil) if && ([:compact] == true) super().reject! { |k,v| v.nil? } else super() end end |
#becomes(klass) ⇒ Document
Returns an instance of the specified class with the attributes, errors, and embedded documents of the current document.
218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 |
# File 'lib/mongoid/document.rb', line 218 def becomes(klass) unless klass.include?(Mongoid::Document) raise ArgumentError, "A class which includes Mongoid::Document is expected" end became = klass.new(clone_document) became._id = _id became.instance_variable_set(:@changed_attributes, changed_attributes) became.instance_variable_set(:@errors, ActiveModel::Errors.new(became)) became.errors.instance_variable_set(:@messages, errors.instance_variable_get(:@messages)) became.instance_variable_set(:@new_record, new_record?) became.instance_variable_set(:@destroyed, destroyed?) became.changed_attributes["_type"] = self.class.to_s became._type = klass.to_s # mark embedded docs as persisted .each_pair do |name, | without_autobuild do relation = became.__send__(name) Array.wrap(relation).each do |r| r.instance_variable_set(:@new_record, new_record?) end end end became end |
#cache_key ⇒ String
Print out the cache key. This will append different values on the plural model name.
If new_record? - will append /new If not - will append /id-updated_at.to_s(:nsec) Without updated_at - will append /id
This is usually called insode a cache() block
261 262 263 264 265 |
# File 'lib/mongoid/document.rb', line 261 def cache_key return "#{model_key}/new" if new_record? return "#{model_key}/#{id}-#{updated_at.utc.to_s(:nsec)}" if do_or_do_not(:updated_at) "#{model_key}/#{id}" end |
#freeze ⇒ Document
Freezes the internal attributes of the document.
42 43 44 |
# File 'lib/mongoid/document.rb', line 42 def freeze as_document.freeze and self end |
#frozen? ⇒ true, false
Checks if the document is frozen
54 55 56 |
# File 'lib/mongoid/document.rb', line 54 def frozen? attributes.frozen? end |
#hash ⇒ Integer
Delegates to identity in order to allow two records of the same identity to work with something like:
[ Person.find(1), Person.find(2), Person.find(3) ] &
[ Person.find(1), Person.find(4) ] # => [ Person.find(1) ]
70 71 72 |
# File 'lib/mongoid/document.rb', line 70 def hash identity.hash end |
#identity ⇒ Array
A Document’s is identified absolutely by its class and database id:
Person.first.identity #=> [Person, BSON::ObjectId(‘4f775130a04745933a000003’)]
84 85 86 |
# File 'lib/mongoid/document.rb', line 84 def identity [ self.class, self._id ] end |
#initialize(attrs = nil) ⇒ Document
Instantiate a new Document
, setting the Document’s attributes if given. If no attributes are provided, they will be initialized with an empty Hash
.
If a primary key is defined, the document’s id will be set to that key, otherwise it will be set to a fresh BSON::ObjectId
string.
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 |
# File 'lib/mongoid/document.rb', line 103 def initialize(attrs = nil) @__parent = nil _building do @new_record = true @attributes ||= {} with(self.class.) apply_pre_processed_defaults apply_default_scoping process_attributes(attrs) do yield(self) if block_given? end apply_post_processed_defaults # @todo: #2586: Need to have access to parent document in these # callbacks. run_callbacks(:initialize) unless _initialize_callbacks.empty? end end |
#model_name ⇒ String
Return the model name of the document.
129 130 131 |
# File 'lib/mongoid/document.rb', line 129 def model_name self.class.model_name end |
#to_a ⇒ Array<Document>
Return an array with this Document
only in it.
153 154 155 |
# File 'lib/mongoid/document.rb', line 153 def to_a [ self ] end |
#to_key ⇒ String
Return the key value for the document.
141 142 143 |
# File 'lib/mongoid/document.rb', line 141 def to_key (persisted? || destroyed?) ? [ id.to_s ] : nil end |