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 attachableto the record.
- 
  
    
      #attached?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Returns trueif an attachment has been made.
- 
  
    
      #attachment  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Returns the associated attachment record. 
- #blank? ⇒ Boolean
- 
  
    
      #detach  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Deletes the attachment without purging it, leaving its blob in place. 
- 
  
    
      #purge  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Directly purges the attachment (i.e. destroys the blob and attachment and deletes the file on the service). 
- 
  
    
      #purge_later  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Purges the attachment through the queuing system. 
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/jpg")
person.avatar.attach(avatar_blob) # ActiveStorage::Blob object
| 30 31 32 33 34 35 36 37 | # File '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 | 
#attached? ⇒ Boolean
Returns true if an attachment has been made.
class User < ApplicationRecord
  has_one_attached :avatar
end
User.new.avatar.attached? # => false
| 46 47 48 | # File 'lib/active_storage/attached/one.rb', line 46 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.
| 12 13 14 | # File 'lib/active_storage/attached/one.rb', line 12 def change.present? ? change. : record.public_send("#{name}_attachment") end | 
#blank? ⇒ Boolean
| 16 17 18 | # File 'lib/active_storage/attached/one.rb', line 16 def blank? !attached? end | 
#detach ⇒ Object
Deletes the attachment without purging it, leaving its blob in place.
| 51 52 53 54 55 56 | # File 'lib/active_storage/attached/one.rb', line 51 def detach if attached? .delete nil end end | 
#purge ⇒ Object
Directly purges the attachment (i.e. destroys the blob and attachment and deletes the file on the service).
| 60 61 62 63 64 65 | # File 'lib/active_storage/attached/one.rb', line 60 def purge if attached? .purge nil end end | 
#purge_later ⇒ Object
Purges the attachment through the queuing system.
| 68 69 70 71 72 73 | # File 'lib/active_storage/attached/one.rb', line 68 def purge_later if attached? .purge_later nil end end |