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
::ActiveStorage::Attached
- Inherited
Instance Attribute Summary
-
#attached? ⇒ Boolean
readonly
Returns
true
if an attachment has been made. - #blank? ⇒ Boolean readonly
::ActiveStorage::Attached
- Inherited
Instance Method Summary
-
#attach(attachable)
Attaches an
attachable
to the record. -
#attachment
Returns the associated attachment record.
-
#detach
Deletes the attachment without purging it, leaving its blob in place.
-
#purge
Directly purges the attachment (i.e.
-
#purge_later
Purges the attachment through the queuing system.
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
# File 'activestorage/lib/active_storage/attached/one.rb', line 46
def attached? .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
#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.
#detach
Deletes the attachment without purging it, leaving its blob in place.
# File 'activestorage/lib/active_storage/attached/one.rb', line 51
def detach if attached? .delete nil end end
#purge
Directly purges the attachment (i.e. destroys the blob and attachment and deletes the file on the service).
# File 'activestorage/lib/active_storage/attached/one.rb', line 60
def purge if attached? .purge nil end end
#purge_later
Purges the attachment through the queuing system.
# File 'activestorage/lib/active_storage/attached/one.rb', line 68
def purge_later if attached? .purge_later nil end end