Skip to content

Commit

Permalink
Merge pull request #133 from OkinawaNet/storage_behavior
Browse files Browse the repository at this point in the history
Added StorageBehavior
  • Loading branch information
achempion authored Nov 27, 2024
2 parents 735c731 + 4f1b992 commit 71ce749
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 0 deletions.
20 changes: 20 additions & 0 deletions lib/waffle/behaviors/storage_behaviour.ex
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
defmodule Waffle.StorageBehavior do
@moduledoc """
Defines the behavior for file storage.
## Callbacks
- `put/3`: Saves a file and returns the file name or an error.
- `url/3`: Generates a URL for accessing a file.
- `delete/3`: Deletes a file and returns the result of the operation.
"""

@callback put(definition :: atom, version :: atom, file_and_scope :: {Waffle.File.t(), any}) ::
{:ok, file_name :: String.t()} | {:error, reason :: any}

@callback url(definition :: atom, version :: atom, file_and_scope :: {Waffle.File.t(), any}) ::
String.t()

@callback delete(definition :: atom, version :: atom, file_and_scope :: {Waffle.File.t(), any}) ::
atom
end
5 changes: 5 additions & 0 deletions lib/waffle/storage/local.ex
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,11 @@ defmodule Waffle.Storage.Local do
end
"""

@behaviour Waffle.StorageBehavior

alias Waffle.Definition.Versioning

@impl true
def put(definition, version, {file, scope}) do
destination_path = Path.join([
definition.storage_dir_prefix(),
Expand All @@ -41,6 +44,7 @@ defmodule Waffle.Storage.Local do
{:ok, file.file_name}
end

@impl true
def url(definition, version, file_and_scope, _options \\ []) do
local_path = Path.join([
definition.storage_dir(version, file_and_scope),
Expand All @@ -56,6 +60,7 @@ defmodule Waffle.Storage.Local do
|> URI.encode()
end

@impl true
def delete(definition, version, file_and_scope) do
Path.join([
definition.storage_dir_prefix(),
Expand Down
5 changes: 5 additions & 0 deletions lib/waffle/storage/s3.ex
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,8 @@ defmodule Waffle.Storage.S3 do
"""
require Logger

@behaviour Waffle.StorageBehavior

alias ExAws.Config
alias ExAws.Request.Url
alias ExAws.S3
Expand All @@ -138,6 +140,7 @@ defmodule Waffle.Storage.S3 do

@default_expiry_time 60 * 5

@impl true
def put(definition, version, {file, scope}) do
destination_dir = definition.storage_dir(version, {file, scope})
s3_bucket = s3_bucket(definition, {file, scope})
Expand All @@ -152,13 +155,15 @@ defmodule Waffle.Storage.S3 do
do_put(file, {s3_bucket, s3_key, s3_options})
end

@impl true
def url(definition, version, file_and_scope, options \\ []) do
case Keyword.get(options, :signed, false) do
false -> build_url(definition, version, file_and_scope, options)
true -> build_signed_url(definition, version, file_and_scope, options)
end
end

@impl true
def delete(definition, version, {file, scope}) do
s3_bucket(definition, {file, scope})
|> S3.delete_object(s3_key(definition, version, {file, scope}))
Expand Down

0 comments on commit 71ce749

Please sign in to comment.