Class: ActiveStorage::Service
Relationships & Source Files | |
Namespace Children | |
Classes:
| |
Extension / Inclusion / Inheritance Descendants | |
Subclasses:
|
|
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Inherits: | Object |
Defined in: | activestorage/lib/active_storage/service.rb |
Overview
Abstract class serving as an interface for concrete services.
The available services are:
-
Disk
, to manage attachments saved directly on the hard drive. -
GCS
, to manage attachments through Google Cloud Storage. -
S3
, to manage attachments through Amazon S3. -
AzureStorage
, to manage attachments through Microsoft Azure Storage. -
Mirror
, to be able to use several services to manage attachments.
Inside a ::Rails
application, you can set-up your services through the generated config/storage.yml
file and reference one of the aforementioned constant under the service
key. For example:
local:
service: Disk
root: <%= Rails.root.join("storage") %>
You can checkout the service’s constructor to know which keys are required.
Then, in your application’s configuration, you can specify the service to use like this:
config.active_storage.service = :local
If you are using Active Storage outside of a Ruby on ::Rails
application, you can configure the service to use like this:
ActiveStorage::Blob.service = ActiveStorage::Service.configure(
:Disk,
root: Pathname("/foo/bar/storage")
)
Class Attribute Summary
Class Method Summary
-
.configure(service_name, configurations)
Configure an Active Storage service by name from a set of configurations, typically loaded from a YAML file.
::ActiveSupport::Autoload
- Extended
Instance Attribute Summary
Instance Method Summary
-
#delete(key)
Delete the file at the
key
. -
#delete_prefixed(prefix)
Delete files at keys starting with the
prefix
. -
#download(key)
Return the content of the file at the
key
. -
#download_chunk(key, range)
Return the partial content in the byte
range
of the file at thekey
. -
#exist?(key) ⇒ Boolean
Return
true
if a file exists at thekey
. -
#headers_for_direct_upload(key, filename:, content_type:, content_length:, checksum:)
Returns a
::Hash
of headers for #url_for_direct_upload requests. -
#update_metadata(key, **metadata)
Update metadata for the file identified by
key
in the service. -
#upload(key, io, checksum: nil, **options)
Upload the
io
to thekey
specified. -
#url(key, expires_in:, disposition:, filename:, content_type:)
Returns a signed, temporary URL for the file at the
key
. -
#url_for_direct_upload(key, expires_in:, content_type:, content_length:, checksum:)
Returns a signed, temporary URL that a direct upload file can be PUT to on the
key
.
Class Attribute Details
.url_expires_in (rw)
[ GitHub ]# File 'activestorage/lib/active_storage/service.rb', line 44
class_attribute :url_expires_in, default: 5.minutes
.url_expires_in? ⇒ Boolean
(rw)
[ GitHub ]
# File 'activestorage/lib/active_storage/service.rb', line 44
class_attribute :url_expires_in, default: 5.minutes
Class Method Details
.configure(service_name, configurations)
Configure an Active Storage service by name from a set of configurations, typically loaded from a YAML file. The Active Storage engine uses this to set the global Active Storage service when the app boots.
# File 'activestorage/lib/active_storage/service.rb', line 50
def configure(service_name, configurations) Configurator.build(service_name, configurations) end
Instance Attribute Details
#url_expires_in (rw)
[ GitHub ]# File 'activestorage/lib/active_storage/service.rb', line 44
class_attribute :url_expires_in, default: 5.minutes
#url_expires_in? ⇒ Boolean
(rw)
[ GitHub ]
# File 'activestorage/lib/active_storage/service.rb', line 44
class_attribute :url_expires_in, default: 5.minutes
Instance Method Details
#delete(key)
Delete the file at the key
.
# File 'activestorage/lib/active_storage/service.rb', line 88
def delete(key) raise NotImplementedError end
#delete_prefixed(prefix)
Delete files at keys starting with the prefix
.
# File 'activestorage/lib/active_storage/service.rb', line 93
def delete_prefixed(prefix) raise NotImplementedError end
#download(key)
Return the content of the file at the key
.
# File 'activestorage/lib/active_storage/service.rb', line 78
def download(key) raise NotImplementedError end
#download_chunk(key, range)
Return the partial content in the byte range
of the file at the key
.
# File 'activestorage/lib/active_storage/service.rb', line 83
def download_chunk(key, range) raise NotImplementedError end
#exist?(key) ⇒ Boolean
Return true
if a file exists at the key
.
# File 'activestorage/lib/active_storage/service.rb', line 98
def exist?(key) raise NotImplementedError end
#headers_for_direct_upload(key, filename:, content_type:, content_length:, checksum:)
Returns a ::Hash
of headers for #url_for_direct_upload requests.
# File 'activestorage/lib/active_storage/service.rb', line 118
def headers_for_direct_upload(key, filename:, content_type:, content_length:, checksum:) {} end
#update_metadata(key, **metadata)
Update metadata for the file identified by key
in the service. Override in subclasses only if the service needs to store specific metadata that has to be updated upon identification.
# File 'activestorage/lib/active_storage/service.rb', line 74
def (key, ** ) end
#upload(key, io, checksum: nil, **options)
Upload the io
to the key
specified. If a checksum
is provided, the service will ensure a match when the upload has completed or raise an IntegrityError
.
# File 'activestorage/lib/active_storage/service.rb', line 67
def upload(key, io, checksum: nil, ** ) raise NotImplementedError end
#url(key, expires_in:, disposition:, filename:, content_type:)
Returns a signed, temporary URL for the file at the key
. The URL will be valid for the amount of seconds specified in expires_in
. You most also provide the disposition
(:inline
or :attachment
), filename
, and content_type
that you wish the file to be served with on request.
# File 'activestorage/lib/active_storage/service.rb', line 105
def url(key, expires_in:, disposition:, filename:, content_type:) raise NotImplementedError end
#url_for_direct_upload(key, expires_in:, content_type:, content_length:, checksum:)
Returns a signed, temporary URL that a direct upload file can be PUT to on the key
. The URL will be valid for the amount of seconds specified in expires_in
. You must also provide the content_type
, content_length
, and checksum
of the file that will be uploaded. All these attributes will be validated by the service upon upload.
# File 'activestorage/lib/active_storage/service.rb', line 113
def url_for_direct_upload(key, expires_in:, content_type:, content_length:, checksum:) raise NotImplementedError end