Class: ActiveStorage::Attached::One

Inherits:
ActiveStorage::Attached show all
Defined in:
lib/active_storage/attached/one.rb

Overview

Representation of a single attachment to a model.

Instance Attribute Summary

Attributes inherited from ActiveStorage::Attached

#name, #record

Instance Method Summary collapse

Methods inherited from ActiveStorage::Attached

#initialize

Constructor Details

This class inherits a constructor from ActiveStorage::Attached

Instance Method Details

#attach(attachable) ⇒ Object

Attaches an attachable to the record.

If the record is persisted and unchanged, the attachment is saved to the database immediately. Otherwise, it'll be saved to the DB when the record is next saved.

person.avatar.attach(params[:avatar]) # ActionDispatch::Http::UploadedFile object
person.avatar.attach(params[:signed_blob_id]) # Signed reference to blob from direct upload
person.avatar.attach(io: File.open("/path/to/face.jpg"), filename: "face.jpg", content_type: "image/jpg")
person.avatar.attach(avatar_blob) # ActiveStorage::Blob object


30
31
32
33
34
35
36
# File 'lib/active_storage/attached/one.rb', line 30

def attach(attachable)
  if record.persisted? && !record.changed?
    record.update(name => attachable)
  else
    record.public_send("#{name}=", attachable)
  end
end

#attached?Boolean

Returns true if an attachment has been made.

class User < ActiveRecord::Base
  has_one_attached :avatar
end

User.new.avatar.attached? # => false

Returns:

  • (Boolean)


45
46
47
# File 'lib/active_storage/attached/one.rb', line 45

def attached?
  attachment.present?
end

#attachmentObject

Returns the associated attachment record.

You don't have to call this method to access the attachment's methods as they are all available at the model level.



12
13
14
# File 'lib/active_storage/attached/one.rb', line 12

def attachment
  change.present? ? change.attachment : record.public_send("#{name}_attachment")
end

#blank?Boolean

Returns:

  • (Boolean)


16
17
18
# File 'lib/active_storage/attached/one.rb', line 16

def blank?
  !attached?
end

#detachObject

Deletes the attachment without purging it, leaving its blob in place.



50
51
52
53
54
55
# File 'lib/active_storage/attached/one.rb', line 50

def detach
  if attached?
    attachment.delete
    write_attachment nil
  end
end

#purgeObject

Directly purges the attachment (i.e. destroys the blob and attachment and deletes the file on the service).



59
60
61
62
63
64
# File 'lib/active_storage/attached/one.rb', line 59

def purge
  if attached?
    attachment.purge
    write_attachment nil
  end
end

#purge_laterObject

Purges the attachment through the queuing system.



67
68
69
70
71
72
# File 'lib/active_storage/attached/one.rb', line 67

def purge_later
  if attached?
    attachment.purge_later
    write_attachment nil
  end
end