class ActiveStorage::Attached::One

Parent:
ActiveStorage::Attached

Representation of a single attachment to a model.

Public Instance Methods

attach(attachable) Show source
# File activestorage/lib/active_storage/attached/one.rb, line 30
def attach(attachable)
  if record.persisted? && !record.changed?
    record.public_send("#{name}=", attachable)
    record.save
  else
    record.public_send("#{name}=", attachable)
  end
end

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
attached?() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 46
def attached?
  attachment.present?
end

Returns true if an attachment has been made.

class User < ApplicationRecord
  has_one_attached :avatar
end

User.new.avatar.attached? # => false
attachment() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 12
def attachment
  change.present? ? change.attachment : record.public_send("#{name}_attachment")
end

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.

blank?() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 16
def blank?
  !attached?
end
detach() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 51
def detach
  if attached?
    attachment.delete
    write_attachment nil
  end
end

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

purge() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 60
def purge
  if attached?
    attachment.purge
    write_attachment nil
  end
end

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

purge_later() Show source
# File activestorage/lib/active_storage/attached/one.rb, line 68
def purge_later
  if attached?
    attachment.purge_later
    write_attachment nil
  end
end

Purges the attachment through the queuing system.

© 2004–2020 David Heinemeier Hansson
Licensed under the MIT License.