Module: Mongoid::Persistable::Updatable
- Included in:
- Mongoid::Persistable
- Defined in:
- lib/mongoid/persistable/updatable.rb
Overview
Defines behaviour for persistence operations that update existing documents.
Instance Method Summary collapse
-
#update(attributes = {}) ⇒ true, false
(also: #update_attributes)
Update the document attributes in the database.
-
#update!(attributes = {}) ⇒ true, false
(also: #update_attributes!)
Update the document attributes in the database and raise an error if validation failed.
-
#update_attribute(name, value) ⇒ true, false
Update a single attribute and persist the entire document.
Instance Method Details
#update(attributes = {}) ⇒ true, false Also known as: update_attributes
Update the document attributes in the database.
49 50 51 52 |
# File 'lib/mongoid/persistable/updatable.rb', line 49 def update(attributes = {}) assign_attributes(attributes) save end |
#update!(attributes = {}) ⇒ true, false Also known as: update_attributes!
Update the document attributes in the database and raise an error if validation failed.
69 70 71 72 73 74 75 76 |
# File 'lib/mongoid/persistable/updatable.rb', line 69 def update!(attributes = {}) result = update_attributes(attributes) unless result fail_due_to_validation! unless errors.empty? fail_due_to_callback!(:update_attributes!) end result end |
#update_attribute(name, value) ⇒ true, false
Update a single attribute and persist the entire document. This skips validation but fires the callbacks.
26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/mongoid/persistable/updatable.rb', line 26 def update_attribute(name, value) as_writable_attribute!(name, value) do |access| normalized = name.to_s setter = "#{normalized}=" if respond_to?(setter) send(setter, value) else write_attribute(access, value) end save(validate: false) end end |