lib/couchrest/model/extended_attachments.rb in couchrest_model-1.0.0.beta7 vs lib/couchrest/model/extended_attachments.rb in couchrest_model-1.0.0.beta8

- old
+ new

@@ -5,15 +5,19 @@ # Add a file attachment to the current document. Expects # :file and :name to be included in the arguments. def create_attachment(args={}) raise ArgumentError unless args[:file] && args[:name] return if has_attachment?(args[:name]) - self['_attachments'] ||= {} set_attachment_attr(args) rescue ArgumentError => e raise ArgumentError, 'You must specify :file and :name' end + + # return all attachments + def attachments + self['_attachments'] ||= {} + end # reads the data from an attachment def read_attachment(attachment_name) database.fetch_attachment(self, attachment_name) end @@ -28,17 +32,17 @@ raise ArgumentError, 'You must specify :file and :name' end # deletes a file attachment from the current doc def delete_attachment(attachment_name) - return unless self['_attachments'] - self['_attachments'].delete attachment_name + return unless attachments + attachments.delete attachment_name end # returns true if attachment_name exists def has_attachment?(attachment_name) - !!(self['_attachments'] && self['_attachments'][attachment_name] && !self['_attachments'][attachment_name].empty?) + !!(attachments && attachments[attachment_name] && !attachments[attachment_name].empty?) end # returns URL to fetch the attachment from def attachment_url(attachment_name) return unless has_attachment?(attachment_name) @@ -60,10 +64,10 @@ end def set_attachment_attr(args) content_type = args[:content_type] ? args[:content_type] : get_mime_type(args[:file].path) content_type ||= (get_mime_type(args[:name]) || 'text/plain') - self['_attachments'][args[:name]] = { + attachments[args[:name]] = { 'content_type' => content_type, 'data' => args[:file].read } end