Class: ActiveStorage::Attached::One
- Inherits:
-
ActiveStorage::Attached
- Object
- ActiveStorage::Attached
- ActiveStorage::Attached::One
- Defined in:
- lib/active_storage/attached/one.rb
Overview
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
56 57 58 59 60 61 62 63 |
# File 'lib/active_storage/attached/one.rb', line 56 def attach(attachable) if record.persisted? && !record.changed? record.public_send("#{name}=", attachable) record.save else record.public_send("#{name}=", attachable) end end |
#attached? ⇒ Boolean
Returns true
if an attachment has been made.
class User < ApplicationRecord
has_one_attached :avatar
end
User.new.avatar.attached? # => false
72 73 74 |
# File 'lib/active_storage/attached/one.rb', line 72 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.
31 32 33 |
# File 'lib/active_storage/attached/one.rb', line 31 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
42 43 44 |
# File 'lib/active_storage/attached/one.rb', line 42 def blank? !attached? end |
#detach ⇒ Object
:method: detach
Deletes the attachment without purging it, leaving its blob in place.
23 |
# File 'lib/active_storage/attached/one.rb', line 23 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).
11 |
# File 'lib/active_storage/attached/one.rb', line 11 delegate :purge, to: :purge_one |
#purge_later ⇒ Object
:method: purge_later
Purges the attachment through the queuing system.
17 |
# File 'lib/active_storage/attached/one.rb', line 17 delegate :purge_later, to: :purge_one |