ActiveStorage::Attached::One - Ruby on Rails API (original) (raw)

Active Storage Attached One

Representation of a single attachment to a model.

Inherits From

Public instance methods

**attach**(attachable)

Permalink

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

Source code GitHub

# 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?**()

Permalink

Returns true if an attachment has been made.

class User < ApplicationRecord
  has_one_attached :avatar
end

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

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 73
def attached?
  attachment.present?
end

**attachment**()

Permalink

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.

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 33
def attachment
  change.present? ? change.attachment : record.public_send("#{name}_attachment")
end

**blank?**()

Permalink

Returns true if an attachment is not attached.

class User < ApplicationRecord
  has_one_attached :avatar
end

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

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 44
def blank?
  !attached?
end

**detach**

Permalink

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

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 25
delegate :detach, to: :detach_one

**purge**

Permalink

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

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 13
delegate :purge, to: :purge_one

**purge_later**

Permalink

Purges the attachment through the queuing system.

Source code GitHub

# File activestorage/lib/active_storage/attached/one.rb, line 19
delegate :purge_later, to: :purge_one

Definition files