Module: Mongoid::Persistence::ClassMethods
- Defined in:
- lib/mongoid/persistence.rb
Overview
:nodoc:
Instance Method Summary collapse
-
#create(attributes = nil, options = {}, &block) ⇒ Document+
Create a new document.
-
#create!(attributes = {}, options = {}, &block) ⇒ Document+
Create a new document.
-
#delete_all(conditions = nil) ⇒ Integer
Delete all documents given the supplied conditions.
-
#destroy_all(conditions = nil) ⇒ Integer
Delete all documents given the supplied conditions.
-
#fail_callback!(document, method) ⇒ Object
Raise an error if a callback failed.
-
#fail_validate!(document) ⇒ Object
Raise an error if validation failed.
Instance Method Details
#create(attributes = nil, options = {}, &block) ⇒ Document+
Create a new document. This will instantiate a new document and insert it in a single call. Will always return the document whether save passed or not.
240 241 242 243 244 245 246 247 248 249 250 |
# File 'lib/mongoid/persistence.rb', line 240 def create(attributes = nil, = {}, &block) _creating do if attributes.is_a?(::Array) attributes.map { |attrs| create(attrs, , &block) } else doc = new(attributes, , &block) doc.save doc end end end |
#create!(attributes = {}, options = {}, &block) ⇒ Document+
Create a new document. This will instantiate a new document and insert it in a single call. Will always return the document whether save passed or not, and if validation fails an error will be raise.
271 272 273 274 275 276 277 278 279 280 281 282 |
# File 'lib/mongoid/persistence.rb', line 271 def create!(attributes = {}, = {}, &block) _creating do if attributes.is_a?(::Array) attributes.map { |attrs| create!(attrs, , &block) } else doc = new(attributes, , &block) fail_validate!(doc) unless doc.insert.errors.empty? fail_callback!(doc, :create!) if doc.new_record? doc end end end |
#delete_all(conditions = nil) ⇒ Integer
Delete all documents given the supplied conditions. If no conditions are passed, the entire collection will be dropped for performance benefits. Does not fire any callbacks.
297 298 299 300 301 302 303 304 305 |
# File 'lib/mongoid/persistence.rb', line 297 def delete_all(conditions = nil) conds = conditions || {} selector = conds[:conditions] || conds selector.merge!(_type: name) if hereditary? coll = collection deleted = coll.find(selector).count coll.find(selector).remove_all deleted end |
#destroy_all(conditions = nil) ⇒ Integer
Delete all documents given the supplied conditions. If no conditions are passed, the entire collection will be dropped for performance benefits. Fires the destroy callbacks if conditions were passed.
320 321 322 323 324 325 326 |
# File 'lib/mongoid/persistence.rb', line 320 def destroy_all(conditions = nil) conds = conditions || {} documents = where(conds[:conditions] || conds) destroyed = documents.count documents.each { |doc| doc.destroy } destroyed end |
#fail_callback!(document, method) ⇒ Object
Raise an error if a callback failed.
347 348 349 |
# File 'lib/mongoid/persistence.rb', line 347 def fail_callback!(document, method) raise Errors::Callback.new(document.class, method) end |
#fail_validate!(document) ⇒ Object
Raise an error if validation failed.
334 335 336 |
# File 'lib/mongoid/persistence.rb', line 334 def fail_validate!(document) raise Errors::Validations.new(document) end |