Class: ActiveStorage::Attached::One

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

Overview

Active Storage Attached One

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/jpeg")
person.avatar.attach(avatar_blob) # ActiveStorage::Blob object


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

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

#attached?Boolean

Returns true if an attachment has been made.

class User < ApplicationRecord
  has_one_attached :avatar
end

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

Returns:

  • (Boolean)


73
74
75
# File 'activestorage/lib/active_storage/attached/one.rb', line 73

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.



33
34
35
# File 'activestorage/lib/active_storage/attached/one.rb', line 33

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

#blank?Boolean

Returns true if an attachment is not attached.

class User < ApplicationRecord
  has_one_attached :avatar
end

User.new.avatar.blank? # => true

Returns:

  • (Boolean)


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

def blank?
  !attached?
end

#detachObject

:method: detach

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



25
# File 'activestorage/lib/active_storage/attached/one.rb', line 25

delegate :detach, to: :detach_one

#purgeObject

:method: purge

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



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

delegate :purge, to: :purge_one

#purge_laterObject

:method: purge_later

Purges the attachment through the queuing system.



19
# File 'activestorage/lib/active_storage/attached/one.rb', line 19

delegate :purge_later, to: :purge_one