123456789_123456789_123456789_123456789_123456789_

Class: ActiveStorage::Attached::One

Relationships & Source Files
Super Chains via Extension / Inclusion / Inheritance
Class Chain:
Instance Chain:
Inherits: ActiveStorage::Attached
Defined in: activestorage/lib/active_storage/attached/one.rb

Overview

Representation of a single attachment to a model.

Class Method Summary

Instance Attribute Summary

::ActiveStorage::Attached - Inherited

Instance Method Summary

Constructor Details

This class inherits a constructor from ActiveStorage::Attached

Instance Attribute Details

#attached?Boolean (readonly)

Returns true if an attachment has been made.

class User < ApplicationRecord
  has_one_attached :avatar
end

User.new.avatar.attached? # => false
[ GitHub ]

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

def attached?
  attachment.present?
end

#blank?Boolean (readonly)

[ GitHub ]

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

def blank?
  !attached?
end

Instance Method Details

#attach(attachable)

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
[ GitHub ]

  
# 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

#attachment

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.

[ GitHub ]

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

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

#detach

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

[ GitHub ]

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

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

#purge

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

[ GitHub ]

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

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

#purge_later

Purges the attachment through the queuing system.

[ GitHub ]

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

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