Class: Mongoid::Association::Embedded::EmbedsMany::Proxy
Relationships & Source Files | |
Namespace Children | |
Modules:
| |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
ClassMethods ,
::Mongoid::Association::Many ,
Forwardable,
::Mongoid::Association::Proxy ,
Forwardable
|
|
Instance Chain:
|
|
Inherits: |
Mongoid::Association::Many
|
Defined in: | lib/mongoid/association/embedded/embeds_many/proxy.rb |
Overview
Transparent proxy for embeds_many associations. An instance of this class is returned when calling the association getter method on the parent document. This class inherits from Mongoid::Association::Proxy and forwards most of its methods to the target of the association, i.e. the array of child documents.
Constant Summary
::Mongoid::Association::Proxy
- Inherited
Class Attribute Summary
ClassMethods
- Extended
embedded? | Returns true if the association is an embedded one. |
Class Method Summary
-
.new(base, target, association) ⇒ Many
constructor
Instantiate a new embeds_many association.
ClassMethods
- Extended
eager_loader | Returns the eager loader for this association. |
foreign_key_suffix | Returns the suffix of the foreign key field, either “_id” or “_ids”. |
::Mongoid::Association::Proxy
- Inherited
.apply_ordering | Apply ordering to the criteria if it was defined on the association. |
.new | Sets the target and the association metadata properties. |
Instance Attribute Summary
- #_unscoped rw private
-
#persistable? ⇒ true | false
readonly
private
Are we able to persist this association?
::Mongoid::Association::Embedded::Batchable
- Included
#insertable? | Are we in a state to be able to batch insert? |
#inserts_valid | Are the inserts currently valid? |
#inserts_valid= |
|
#path | Get the atomic path. |
#path= |
|
::Mongoid::Association::Many
- Inherited
::Mongoid::Association::Proxy
- Inherited
#_association, | |
#_base | Model instance for the base of the association. |
#_target | Model instance for one to one associations, or array of model instances for one to many associations, for the target of the association. |
::Mongoid::Threaded::Lifecycle
- Included
#_assigning | Begin the assignment of attributes. |
#_assigning? | Is the current thread in assigning mode? |
#_binding | Execute a block in binding mode. |
#_binding? | Is the current thread in binding mode? |
#_building | Execute a block in building mode. |
#_building? | Is the current thread in building mode? |
#_creating? | Is the current thread in creating mode? |
#_loading | Execute a block in loading mode. |
#_loading? | Is the current thread in loading mode? |
Instance Method Summary
-
#<<(*args)
(also: #push)
Appends a document or array of documents to the association.
-
#_remove(document)
Internal use only
Internal use only
Removes a single document from the collection *in memory only*.
-
#as_document ⇒ Array<Hash>
Get this association as as its representation in the database.
-
#build(attributes = {}, type = nil) ⇒ Document
(also: #new)
Builds a new document in the association and appends it to the target.
-
#clear ⇒ self
Clear the association.
-
#concat(docs) ⇒ Array<Document>
Appends an array of documents to the association.
-
#count(*args, &block) ⇒ Integer
Returns a count of the number of documents in the association that have actually been persisted to the database.
-
#delete(document) ⇒ Document | nil
(also: #delete_one)
Delete the supplied document from the target.
-
#delete_all(conditions = {}) ⇒ Integer
Delete all the documents in the association without running callbacks.
-
#delete_if ⇒ EmbedsMany::Proxy | Enumerator
Delete all the documents for which the provided block returns true.
-
#delete_one(document)
Alias for #delete.
-
#destroy_all(conditions = {}) ⇒ Integer
Destroy all the documents in the association whilst running callbacks.
-
#exists?(id_or_conditions = :none) ⇒ true | false
Determine if any documents in this association exist in the database.
-
#find {|Object| ... } ⇒ Document | Array<Document> | nil
Finds a document in this association through several different methods.
-
#in_memory
Alias for Proxy#_target.
-
#new(attributes = {}, type = nil)
Alias for #build.
-
#pop(count = nil) ⇒ Document | Array<Document> | nil
Pop documents off the association.
-
#push(*args)
Alias for #<<.
-
#shift(count = nil) ⇒ Document | Array<Document> | nil
Shift documents off the association.
-
#substitute(docs) ⇒ Many
Substitutes the supplied target documents for the existing documents in the relation.
-
#unscoped ⇒ Criteria
Return the association with all previous scoping removed.
-
#append(document)
private
Appends the document to the target array, updating the index on the document at the same time.
-
#as_attributes ⇒ Array<Hash>
private
Returns a list of attributes hashes for each document.
-
#binding ⇒ Binding
private
Instantiate the binding associated with this association.
-
#criteria ⇒ Criteria
private
Returns the
::Mongoid::Criteria
object for the target class with its documents set to the list of target documents in the association. -
#integrate(document)
private
Integrate the document into the association.
-
#method_missing ⇒ Criteria | Object
private
If the target array does not respond to the supplied method then try to find a named scope or criteria on the class and send the call there.
- #object_already_related?(document) ⇒ Boolean private
-
#reindex
private
Reindex all the target elements.
-
#remove_all(conditions = {}, method = :delete) ⇒ Integer
private
Remove all documents from the association, either with a delete or a destroy depending on what this was called through.
-
#scope(docs) ⇒ Array<Document>
private
Apply the association ordering and default scoping (defined on association’s target class) to the provided documents.
-
#update_attributes_hash
private
Internal use only
Internal use only
Update the _base’s attributes hash with the _target’s attributes.
::Mongoid::Association::Embedded::Batchable
- Included
#batch_clear | Clear all of the docs out of the association in a single swipe. |
#batch_insert | Insert new documents as a batch push ($push with $each). |
#batch_remove | Batch remove the provided documents as a $pullAll or $pull. |
#batch_replace | Batch replace the provided documents as a $set. |
#add_atomic_sets | Add the atomic sets to the base document. |
#clear_atomic_path_cache | Clear the cache for path and atomic_paths. |
#execute_batch_push | Perform a batch persist of the provided documents with $push and $each. |
#execute_batch_set | Perform a batch persist of the provided documents with a $set. |
#normalize_docs | Normalize the documents, in case they were provided as an array of hashes. |
#post_process_batch_insert | Post process the documents after batch insert. |
#post_process_batch_remove | Post process the batch removal. |
#pre_process_batch_insert | Pre processes the batch insert for the provided documents. |
#pre_process_batch_remove | Pre process the batch removal. |
#selector | Get the selector for executing atomic operations on the collection. |
::Mongoid::Positional
- Included
#positionally | Takes the provided selector and atomic operations and replaces the indexes of the embedded documents with the positional operator when needed. |
#process_operations, #process_updates, #replace_index |
::Mongoid::Association::Many
- Inherited
#cache_version | For compatibility with Rails’ caching. |
#create | Creates a new document on the references many association. |
#create! | Creates a new document on the references many association. |
#find_or_create_by | Find the first document given the conditions, or creates a new document with the conditions that were supplied. |
#find_or_create_by! | Find the first document given the conditions, or creates a new document with the conditions that were supplied. |
#find_or_initialize_by | Find the first |
#respond_to? | Since method_missing is overridden we should override this as well. |
#scoped | This is public access to the association’s criteria. |
#serializable_hash | Gets the document as a serializable hash, used by ActiveModel’s JSON and XML serializers. |
#unscoped | Get a criteria for the embedded documents without the default scoping applied. |
#_session, | |
#analyze_loaded_target | Return a 2-tuple of the number of elements in the relation, and the largest timestamp value. |
#analyze_unloaded_target | Returns a 2-tuple of the number of elements in the relation, and the largest timestamp value. |
#compute_cache_version | Computes the cache version for the relation using the given timestamp colum; see |
#find_or | Find the first object given the supplied attributes or create/initialize it. |
::Mongoid::Association::Proxy
- Inherited
#extend_proxies | Allow extension to be an array and extend each module. |
#extend_proxy, | |
#klass | Get the class from the association, or return nil if no association present. |
#reset_unloaded | Resets the criteria inside the association proxy. |
#substitutable | The default substitutable object for an association proxy is the clone of the target. |
::Mongoid::Association::Marshalable
- Included
#marshal_dump | Provides the data needed to Marshal.dump an association proxy. |
#marshal_load | Takes the provided data and sets it back on the proxy. |
Constructor Details
.new(base, target, association) ⇒ Many
Instantiate a new embeds_many association.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 67
def initialize(base, target, association) super do _target.each_with_index do |doc, index| integrate(doc) doc._index = index end update_attributes_hash @_unscoped = _target.dup @_target = scope(_target) end end
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing ⇒ Criteria | Object
(private)
If the target array does not respond to the supplied method then try to find a named scope or criteria on the class and send the call there.
If the method exists on the array, use the default proxy behavior.
TODO: make sure we are consistently using respond_to_missing
anywhere we define method_missing.
Instance Attribute Details
#_unscoped (rw, private)
[ GitHub ]# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 423
attr_accessor :_unscoped
#persistable? ⇒ true
| false
(readonly, private)
Are we able to persist this association?
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 505
def persistable? _base.persisted? && !_binding? end
Instance Method Details
#<<(*args) Also known as: #push
Appends a document or array of documents to the association. Will set the parent and update the index in the process.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 89
def <<(*args) docs = args.flatten return unless docs.any? return concat(docs) if docs.size > 1 docs.first.tap do |doc| append(doc) doc.save if persistable? && !_assigning? end self end
#_remove(document)
Removes a single document from the collection *in memory only*. It will not persist the change.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 236
def _remove(document) _target.delete_one(document) _unscoped.delete_one(document) update_attributes_hash reindex end
#append(document) (private)
Appends the document to the target array, updating the index on the document at the same time.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 436
def append(document) execute_callback :before_add, document _target.push(*scope([ document ])) unless (document) _unscoped.push(document) integrate(document) update_attributes_hash document._index = _unscoped.size - 1 execute_callback :after_add, document end
#as_attributes ⇒ Array<Hash> (private)
Returns a list of attributes hashes for each document.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 560
def as_attributes _unscoped.map { |doc| doc.send(:as_attributes) } end
#as_document ⇒ Array<Hash>
Get this association as as its representation in the database.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 110
def as_document as_attributes.collect { |attrs| BSON::Document.new(attrs) } end
#binding ⇒ Binding (private)
Instantiate the binding associated with this association.
#build(attributes = {}, type = nil) ⇒ Document Also known as: #new
Builds a new document in the association and appends it to the target. Takes an optional type if you want to specify a subclass.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 138
def build(attributes = {}, type = nil) Factory.execute_build(type || _association.klass, attributes, execute_callbacks: false).tap do |doc| append(doc) doc.apply_post_processed_defaults yield doc if block_given? doc.run_pending_callbacks doc.run_callbacks(:build) { doc } _base._reset_memoized_descendants! end end
#clear ⇒ self
Clear the association. Will delete the documents from the db if they are already persisted.
If the host document is not persisted but its _id matches a persisted document, calling #clear on an association will remove the association’s documents from the database even though the set of documents in the application (as loaded in the host) is different from what is in the database, and the host may not contain any persisted documents in the association either.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 165
def clear batch_clear(_target.dup) update_attributes_hash self end
#concat(docs) ⇒ Array<Document>
Appends an array of documents to the association. Performs a batch insert of the documents instead of persisting one at a time.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 123
def concat(docs) batch_insert(docs) unless docs.empty? self end
#count(*args, &block) ⇒ Integer
Returns a count of the number of documents in the association that have actually been persisted to the database.
Use #size if you want the total number of documents.
If args or block are present, #count will delegate to the #count method on target
and will include both persisted and non-persisted documents.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 193
def count(*args, &block) return _target.count(*args, &block) if args.any? || block _target.count(&:persisted?) end
#criteria ⇒ Criteria (private)
Returns the ::Mongoid::Criteria
object for the target class with its documents set to the list of target documents in the association.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 460
def criteria _association.criteria(_base, _target) end
#delete(document) ⇒ Document | nil
Also known as: #delete_one
Delete the supplied document from the target. This method is proxied in order to reindex the array after the operation occurs.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 208
def delete(document) execute_callbacks_around(:remove, document) do _target.delete_one(document).tap do |doc| if doc && !_binding? _unscoped.delete_one(doc) if _assigning? _base.add_atomic_pull(doc) else doc.delete(suppress: true) unbind_one(doc) end update_attributes_hash end reindex end end end
#delete_all(conditions = {}) ⇒ Integer
Delete all the documents in the association without running callbacks.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 254
def delete_all(conditions = {}) remove_all(conditions, :delete) end
#delete_if ⇒ EmbedsMany::Proxy | Enumerator
Delete all the documents for which the provided block returns true.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 267
def delete_if return super unless block_given? _target.dup.each { |doc| delete(doc) if yield doc } self end
#delete_one(document)
Alias for #delete.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 228
alias delete_one delete
#destroy_all(conditions = {}) ⇒ Integer
Destroy all the documents in the association whilst running callbacks.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 286
def destroy_all(conditions = {}) remove_all(conditions, :destroy) end
#exists?(id_or_conditions = :none) ⇒ true
| false
Determine if any documents in this association exist in the database.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 306
def exists?(id_or_conditions = :none) case id_or_conditions when :none then _target.any?(&:persisted?) when nil, false then false when Hash then where(id_or_conditions).any?(&:persisted?) else where(_id: id_or_conditions).any?(&:persisted?) end end
#find {|Object| ... } ⇒ Document | Array<Document> | nil
Finds a document in this association through several different methods.
This method delegates to Criteria#find. If this method is not given a block, it returns one or many documents for the provided _id values.
If this method is given a block, it returns the first document of those found by the current ::Mongoid::Criteria
object for which the block returns a truthy value.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 340
def find(...) criteria.find(...) end
#in_memory
Alias for Proxy#_target.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 350
alias in_memory _target
#integrate(document) (private)
Integrate the document into the association. will set its metadata and attempt to bind the inverse.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 471
def integrate(document) characterize_one(document) bind_one(document) end
#new(attributes = {}, type = nil)
Alias for #build.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 149
alias new build
#pop(count = nil) ⇒ Document | Array<Document> | nil
Pop documents off the association. This can be a single document or multiples, and will automatically persist the changes.
#push(*args)
Alias for #<<.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 102
alias push <<
#reindex (private)
Reindex all the target elements. This is useful when performing operations on the proxied target directly and the indices need to match that on the database side.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 515
def reindex _unscoped.each_with_index do |doc, index| doc._index = index end end
#remove_all(conditions = {}, method = :delete) ⇒ Integer (private)
Remove all documents from the association, either with a delete or a destroy depending on what this was called through.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 549
def remove_all(conditions = {}, method = :delete) criteria = where(conditions || {}) criteria.size.tap do batch_remove(criteria, method) update_attributes_hash end end
#scope(docs) ⇒ Array<Document> (private)
Apply the association ordering and default scoping (defined on association’s target class) to the provided documents.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 530
def scope(docs) return docs unless _association.order || _association.klass.default_scoping? crit = _association.klass.order_by(_association.order) crit. = true crit.documents = docs crit.entries end
#shift(count = nil) ⇒ Document | Array<Document> | nil
Shift documents off the association. This can be a single document or multiples, and will automatically persist the changes.
#substitute(docs) ⇒ Many
Substitutes the supplied target documents for the existing documents in the relation.
# File 'lib/mongoid/association/embedded/embeds_many/proxy.rb', line 401
def substitute(docs) batch_replace(docs) update_attributes_hash self end
#unscoped ⇒ Criteria
Return the association with all previous scoping removed. This is the exact representation of the docs in the database.
#update_attributes_hash (private)
Update the _base’s attributes hash with the _target’s attributes