module TinyDyno::Stateful
This module contains the behaviour for getting the various states a document can transition through.
Attributes
Public Instance Methods
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.
@example Is the document destroyed?
person.destroyed?
@return [ true, false ] True if destroyed, false if not.
# File lib/tiny_dyno/stateful.rb, line 55 def destroyed? @destroyed ||= false end
Returns whether or not the document has been flagged for deletion, but not destroyed yet. Used for atomic pulls of child documents.
@example Is the document flagged?
document.flagged_for_destroy?
@return [ true, false ] If the document is flagged.
@since 2.3.2
# File lib/tiny_dyno/stateful.rb, line 42 def flagged_for_destroy? @flagged_for_destroy ||= false end
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.
@example Is the document new?
person.new_record?
@return [ true, false ] True if new, false if not.
# File lib/tiny_dyno/stateful.rb, line 18 def new_record? @new_record ||= false end
Checks if the document has been saved to the database. Returns false if the document has been destroyed.
@example Is the document persisted?
person.persisted?
@return [ true, false ] True if persisted, false if not.
# File lib/tiny_dyno/stateful.rb, line 29 def persisted? !new_record? && !destroyed? end
Is the document readonly?
@example Is the document readonly?
document.readonly?
@return [ true, false ] If the document is readonly.
@since 4.0.0
# File lib/tiny_dyno/stateful.rb, line 67 def readonly? __selected_fields != nil end
Determine if the document can be set.
@example Is this settable?
person.settable?
@return [ true, false ] Is this document a new embeds one?
@since 2.1.0
# File lib/tiny_dyno/stateful.rb, line 79 def settable? new_record? end
Is the document updateable?
@example Is the document updateable?
person.updateable?
@return [ true, false ] If the document is changed and persisted.
@since 2.1.0
# File lib/tiny_dyno/stateful.rb, line 91 def updateable? persisted? && changed? end