2009-02-05 17:06:12 -08:00
|
|
|
require 'delegate'
|
|
|
|
|
|
|
|
module CouchRest
|
2008-11-03 22:52:50 -08:00
|
|
|
class Document < Response
|
2009-02-02 16:10:07 -08:00
|
|
|
include CouchRest::Mixins::Attachments
|
2009-02-10 16:10:35 -08:00
|
|
|
|
2009-03-19 12:50:58 -05:00
|
|
|
extlib_inheritable_accessor :database
|
2008-11-08 16:28:58 -08:00
|
|
|
attr_accessor :database
|
2009-01-28 22:55:42 -08:00
|
|
|
|
|
|
|
# override the CouchRest::Model-wide default_database
|
|
|
|
# This is not a thread safe operation, do not change the model
|
|
|
|
# database at runtime.
|
|
|
|
def self.use_database(db)
|
2009-02-10 16:10:35 -08:00
|
|
|
self.database = db
|
2008-11-08 16:28:58 -08:00
|
|
|
end
|
2009-01-16 01:07:37 -08:00
|
|
|
|
2009-02-02 15:24:31 -08:00
|
|
|
def id
|
|
|
|
self['_id']
|
|
|
|
end
|
|
|
|
|
|
|
|
def rev
|
|
|
|
self['_rev']
|
|
|
|
end
|
|
|
|
|
2009-02-02 16:10:07 -08:00
|
|
|
# returns true if the document has never been saved
|
2009-06-04 20:44:44 -07:00
|
|
|
def new?
|
2009-02-02 16:10:07 -08:00
|
|
|
!rev
|
|
|
|
end
|
2009-07-19 00:01:07 -07:00
|
|
|
alias :new_document? :new?
|
2009-02-02 16:10:07 -08:00
|
|
|
|
|
|
|
# Saves the document to the db using create or update. Also runs the :save
|
|
|
|
# callbacks. Sets the <tt>_id</tt> and <tt>_rev</tt> fields based on
|
|
|
|
# CouchDB's response.
|
|
|
|
# If <tt>bulk</tt> is <tt>true</tt> (defaults to false) the document is cached for bulk save.
|
|
|
|
def save(bulk = false)
|
|
|
|
raise ArgumentError, "doc.database required for saving" unless database
|
|
|
|
result = database.save_doc self, bulk
|
|
|
|
result['ok']
|
|
|
|
end
|
|
|
|
|
|
|
|
# Deletes the document from the database. Runs the :delete callbacks.
|
|
|
|
# Removes the <tt>_id</tt> and <tt>_rev</tt> fields, preparing the
|
|
|
|
# document to be saved to a new <tt>_id</tt>.
|
|
|
|
# If <tt>bulk</tt> is <tt>true</tt> (defaults to false) the document won't
|
|
|
|
# actually be deleted from the db until bulk save.
|
|
|
|
def destroy(bulk = false)
|
|
|
|
raise ArgumentError, "doc.database required to destroy" unless database
|
|
|
|
result = database.delete_doc(self, bulk)
|
|
|
|
if result['ok']
|
|
|
|
self['_rev'] = nil
|
|
|
|
self['_id'] = nil
|
|
|
|
end
|
|
|
|
result['ok']
|
|
|
|
end
|
|
|
|
|
2009-02-01 23:34:30 -08:00
|
|
|
# copies the document to a new id. If the destination id currently exists, a rev must be provided.
|
|
|
|
# <tt>dest</tt> can take one of two forms if overwriting: "id_to_overwrite?rev=revision" or the actual doc
|
|
|
|
# hash with a '_rev' key
|
2009-01-16 01:07:37 -08:00
|
|
|
def copy(dest)
|
|
|
|
raise ArgumentError, "doc.database required to copy" unless database
|
2009-01-28 17:36:36 -08:00
|
|
|
result = database.copy_doc(self, dest)
|
2009-01-16 01:07:37 -08:00
|
|
|
result['ok']
|
|
|
|
end
|
|
|
|
|
2009-01-28 22:55:42 -08:00
|
|
|
# Returns the CouchDB uri for the document
|
|
|
|
def uri(append_rev = false)
|
2009-06-04 20:44:44 -07:00
|
|
|
return nil if new?
|
2009-06-07 18:51:31 -07:00
|
|
|
couch_uri = "http://#{database.root}/#{CGI.escape(id)}"
|
2009-01-28 22:55:42 -08:00
|
|
|
if append_rev == true
|
|
|
|
couch_uri << "?rev=#{rev}"
|
|
|
|
elsif append_rev.kind_of?(Integer)
|
|
|
|
couch_uri << "?rev=#{append_rev}"
|
|
|
|
end
|
|
|
|
couch_uri
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns the document's database
|
|
|
|
def database
|
|
|
|
@database || self.class.database
|
|
|
|
end
|
|
|
|
|
2008-11-03 22:52:50 -08:00
|
|
|
end
|
|
|
|
|
2008-12-15 10:27:53 -06:00
|
|
|
end
|