Class: ActiveStorage::Attached::One
- Inherits:
-
ActiveStorage::Attached
- Object
- ActiveStorage::Attached
- ActiveStorage::Attached::One
- 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
Instance Method Summary collapse
-
#attach(attachable) ⇒ Object
Attaches an
attachable
to the record. -
#attached? ⇒ Boolean
Returns
true
if an attachment has been made. -
#attachment ⇒ Object
Returns the associated attachment record.
-
#blank? ⇒ Boolean
Returns
true
if an attachment is not attached. -
#detach ⇒ Object
:method: detach.
-
#purge ⇒ Object
:method: purge.
-
#purge_later ⇒ Object
:method: purge_later.
Methods inherited from ActiveStorage::Attached
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
73 74 75 |
# File 'activestorage/lib/active_storage/attached/one.rb', line 73 def attached? .present? end |
#attachment ⇒ Object
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 change.present? ? change. : 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
44 45 46 |
# File 'activestorage/lib/active_storage/attached/one.rb', line 44 def blank? !attached? end |
#detach ⇒ Object
: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 |
#purge ⇒ Object
: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_later ⇒ Object
: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 |