Module: Mongoid::Stateful
- Included in:
- Composable
- Defined in:
- lib/mongoid/stateful.rb
Overview
This module contains the behavior for getting the various states a document can transition through.
Instance Attribute Summary collapse
-
#destroyed ⇒ Object
writeonly
Sets the attribute destroyed.
-
#flagged_for_destroy ⇒ Object
writeonly
Sets the attribute flagged_for_destroy.
-
#new_record ⇒ Object
writeonly
Sets the attribute new_record.
Instance Method Summary collapse
-
#destroyed? ⇒ true, false
Returns true if the
Document
has been succesfully destroyed, and false if it hasn’t. -
#flagged_for_destroy? ⇒ true, false
(also: #marked_for_destruction?, #_destroy)
Returns whether or not the document has been flagged for deletion, but not destroyed yet.
-
#new_record? ⇒ true, false
Returns true if the
Document
has not been persisted to the database, false if it has. -
#persisted? ⇒ true, false
Checks if the document has been saved to the database.
-
#pushable? ⇒ true, false
Determine if the document can be pushed.
-
#readonly? ⇒ true, false
Is the document readonly?.
-
#settable? ⇒ true, false
Determine if the document can be set.
-
#updateable? ⇒ true, false
Is the document updateable?.
Instance Attribute Details
#destroyed=(value) ⇒ Object (writeonly)
Sets the attribute destroyed
9 10 11 |
# File 'lib/mongoid/stateful.rb', line 9 def destroyed=(value) @destroyed = value end |
#flagged_for_destroy=(value) ⇒ Object (writeonly)
Sets the attribute flagged_for_destroy
9 10 11 |
# File 'lib/mongoid/stateful.rb', line 9 def flagged_for_destroy=(value) @flagged_for_destroy = value end |
#new_record=(value) ⇒ Object (writeonly)
Sets the attribute new_record
9 10 11 |
# File 'lib/mongoid/stateful.rb', line 9 def new_record=(value) @new_record = value end |
Instance Method Details
#destroyed? ⇒ true, false
Returns true if the Document
has been succesfully destroyed, and false if it hasn’t. This is determined by the variable @destroyed and NOT by checking the database.
55 56 57 |
# File 'lib/mongoid/stateful.rb', line 55 def destroyed? @destroyed ||= false end |
#flagged_for_destroy? ⇒ true, false Also known as: marked_for_destruction?, _destroy
Returns whether or not the document has been flagged for deletion, but not destroyed yet. Used for atomic pulls of child documents.
41 42 43 |
# File 'lib/mongoid/stateful.rb', line 41 def flagged_for_destroy? @flagged_for_destroy ||= false end |
#new_record? ⇒ true, false
Returns true if the Document
has not been persisted to the database, false if it has. This is determined by the variable @new_record and NOT if the object has an id.
19 20 21 |
# File 'lib/mongoid/stateful.rb', line 19 def new_record? @new_record ||= false end |
#persisted? ⇒ true, false
Checks if the document has been saved to the database. Returns false if the document has been destroyed.
30 31 32 |
# File 'lib/mongoid/stateful.rb', line 30 def persisted? !new_record? && !destroyed? end |
#pushable? ⇒ true, false
Determine if the document can be pushed.
65 66 67 68 69 70 |
# File 'lib/mongoid/stateful.rb', line 65 def pushable? new_record? && && _parent.persisted? && !_parent.delayed_atomic_sets[atomic_path] end |
#readonly? ⇒ true, false
Is the document readonly?
78 79 80 |
# File 'lib/mongoid/stateful.rb', line 78 def readonly? __selected_fields != nil end |
#settable? ⇒ true, false
Determine if the document can be set.
88 89 90 |
# File 'lib/mongoid/stateful.rb', line 88 def settable? new_record? && && _parent.persisted? end |
#updateable? ⇒ true, false
Is the document updateable?
98 99 100 |
# File 'lib/mongoid/stateful.rb', line 98 def updateable? persisted? && changed? end |