Active Storage Service
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(
:local,
{ local: {service: "Disk", root: Pathname("/tmp/foo/storage") } }
)
Namespace
Class
- ActiveStorage::Service::AzureStorageService
- ActiveStorage::Service::DiskService
- ActiveStorage::Service::GCSService
- ActiveStorage::Service::MirrorService
- ActiveStorage::Service::S3Service
Methods
- compose
- configure
- delete
- delete_prefixed
- download
- download_chunk
- exist?
- headers_for_direct_upload
- open
- public?
- update_metadata
- upload
- url
- url_for_direct_upload
Attributes
[RW] | name |
Class Public methods
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.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 52
def configure(service_name, configurations)
Configurator.build(service_name, configurations)
end
🔎 See on GitHub
Instance Public methods
compose(source_keys, destination_key, filename: nil, content_type: nil, disposition: nil, custom_metadata: {})
Concatenate multiple files into a single “composed” file.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 96
def compose(source_keys, destination_key, filename: nil, content_type: nil, disposition: nil, custom_metadata: {})
raise NotImplementedError
end
🔎 See on GitHub
delete(key)
Delete the file at the key
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 101
def delete(key)
raise NotImplementedError
end
🔎 See on GitHub
delete_prefixed(prefix)
Delete files at keys starting with the prefix
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 106
def delete_prefixed(prefix)
raise NotImplementedError
end
🔎 See on GitHub
download(key)
Return the content of the file at the key
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 82
def download(key)
raise NotImplementedError
end
🔎 See on GitHub
download_chunk(key, range)
Return the partial content in the byte range
of the file at the key
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 87
def download_chunk(key, range)
raise NotImplementedError
end
🔎 See on GitHub
exist?(key)
Return true
if a file exists at the key
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 111
def exist?(key)
raise NotImplementedError
end
🔎 See on GitHub
headers_for_direct_upload(key, filename:, content_type:, content_length:, checksum:, custom_metadata: {})
Returns a Hash
of headers for url_for_direct_upload
requests.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 143
def headers_for_direct_upload(key, filename:, content_type:, content_length:, checksum:, custom_metadata: {})
{}
end
🔎 See on GitHub
open(*args, **options, &block)
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 91
def open(*args, **options, &block)
ActiveStorage::Downloader.new(self).open(*args, **options, &block)
end
🔎 See on GitHub
public?()
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 147
def public?
@public
end
🔎 See on GitHub
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.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 78
def update_metadata(key, **metadata)
end
🔎 See on GitHub
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 ActiveStorage::IntegrityError
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 71
def upload(key, io, checksum: nil, **options)
raise NotImplementedError
end
🔎 See on GitHub
url(key, **options)
Returns the URL for the file at the key
. This returns a permanent URL for public files, and returns a short-lived URL for private files. For private files you can provide the disposition
(:inline
or :attachment
), filename
, and content_type
that you wish the file to be served with on request. Additionally, you can also provide the amount of seconds the URL will be valid for, specified in expires_in
.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 119
def url(key, **options)
instrument :url, key: key do |payload|
generated_url =
if public?
public_url(key, **options)
else
private_url(key, **options)
end
payload[:url] = generated_url
generated_url
end
end
🔎 See on GitHub
url_for_direct_upload(key, expires_in:, content_type:, content_length:, checksum:, custom_metadata: {})
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.
📝 Source code
# File activestorage/lib/active_storage/service.rb, line 138
def url_for_direct_upload(key, expires_in:, content_type:, content_length:, checksum:, custom_metadata: {})
raise NotImplementedError
end
🔎 See on GitHub