View Source Trunk.Storage.S3 (trunk v1.5.1)
A Trunk.Storage
implementation for Amazon’s S3 service.
Summary
Functions
Generates a URL to the S3 object
Copies the file within Amazon S3.
Deletes the file from Amazon S3.
Callback implementation for Trunk.Storage.retrieve/4
.
Saves the file to Amazon S3.
Functions
Generates a URL to the S3 object
directory
- The directory (will be combined with thefilename
to form the S3 object key.filename
- The name of the file (will be combined with thedirectory
to form the S3 object key.opts
- The options for the storage systembucket:
(required) The S3 bucket in which to store the object.virtual_host:
(optional) boolean indicator whether to generate a virtual host style URL or not.signed:
(optional) boolean whether to sign the URL or not.ex_aws:
(optional) override options forex_aws
Example:
Trunk.Storage.S3.build_url("path/to", "file.ext", bucket: "my-bucket")
#=> "https://s3.amazonaws.com/my-bucket/path/to/file.ext"
Trunk.Storage.S3.build_url("path/to", "file.ext", bucket: "my-bucket", virtual_host: true)
#=> "https://my-bucket.s3.amazonaws.com/path/to/file.ext"
Trunk.Storage.S3.build_url("path/to", "file.ext", bucket: "my-bucket", signed: true)
#=> "https://s3.amazonaws.com/my-bucket/path/to/file.ext?X-Amz-Algorithm=AWS4-HMAC-SHA256&…"
@spec copy( directory :: String.t(), filename :: String.t(), to_directory :: String.t(), to_filename :: String.t(), opts :: keyword() ) :: :ok | {:error, :file.posix()}
Copies the file within Amazon S3.
directory
- The relative directory within which to find the file (will be combined with thefilename
to form the source S3 object key).filename
- The name of the file to be copied from (will be combined with thedirectory
to form the source S3 object key).to_directory
- The relative directory within which to copy the file (will be combined with theto_filename
to form the destination S3 object key).to_filename
- The name of the file to be copied to (will be combined with theto_directory
to form the destination S3 object key).opts
- The options for the storage systempath:
(required) The base path within which to save filesacl:
(optional) The file mode to store the file (accepts octal0o644
or string"0644"
). SeeFile.chmod/2
for more info.
Example:
The file will be copied from s3.amazonaws.com/my-bucket/path/to/file.ext to s3.amazonaws.com/my-bucket/copied/to/file.copy
Trunk.Storage.S3.copy("path/to/", "file.ext", "copied/to/", "file.copy", bucket: "my-bucket")
@spec delete(String.t(), String.t(), keyword()) :: :ok | {:error, :file.posix()}
Deletes the file from Amazon S3.
directory
- The directory (will be combined with thefilename
to form the S3 object key.filename
- The name of the file (will be combined with thedirectory
to form the S3 object key.opts
- The options for the storage systembucket:
(required) The S3 bucket in which to store the objectex_aws:
(optional) override options forex_aws
Example:
The file will be removed from s3.amazonaws.com/my-bucket/path/to/file.ext
Trunk.Storage.S3.delete("path/to/", "file.ext", bucket: "my-bucket")
Callback implementation for Trunk.Storage.retrieve/4
.
@spec save( directory :: String.t(), filename :: String.t(), source_path :: String.t(), opts :: keyword() ) :: :ok | {:error, :file.posix()}
Saves the file to Amazon S3.
directory
- The directory (will be combined with thefilename
to form the S3 object key).filename
- The name of the file (will be combined with thedirectory
to form the S3 object key).source_path
- The full path to the file to be stored. This is a path to the uploaded file or a temporary file that has undergone transformationopts
- The options for the storage systembucket:
(required) The S3 bucket in which to store the objectex_aws:
(optional) override options forex_aws
- All other options are passed through to S3 put object which means you can pass in anything accepted by
ExAws.S3.put_object_opts/0
including but not limited to:acl
,:meta
,:content_type
, and:content_disposition
Example:
The file will be saved to s3.amazonaws.com/my-bucket/path/to/file.ext
Trunk.Storage.S3.save("path/to/", "file.ext", "/tmp/uploaded_file.ext", bucket: "my-bucket")