aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/uploaders/s3.ex
diff options
context:
space:
mode:
authorfeld <feld@feld.me>2020-01-12 18:48:59 +0000
committerfeld <feld@feld.me>2020-01-12 18:48:59 +0000
commita431e8c9f7033c739e10b0e8b34c75f2cc1d38d4 (patch)
treeb03a833986d9cbdadc7e807ff3ae6054a36842e5 /lib/pleroma/uploaders/s3.ex
parent8b4d81609d5627d62b826bcd3e87290cb513495f (diff)
parent88f0eed0f24cb05949edcea49215ee939babac58 (diff)
downloadpleroma-a431e8c9f7033c739e10b0e8b34c75f2cc1d38d4.tar.gz
Merge branch 'feature/attachments-cleanup' into 'develop'
Delete attachments when status is deleted See merge request pleroma/pleroma!2036
Diffstat (limited to 'lib/pleroma/uploaders/s3.ex')
-rw-r--r--lib/pleroma/uploaders/s3.ex14
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/pleroma/uploaders/s3.ex b/lib/pleroma/uploaders/s3.ex
index 9876b6398..feb89cea6 100644
--- a/lib/pleroma/uploaders/s3.ex
+++ b/lib/pleroma/uploaders/s3.ex
@@ -10,6 +10,7 @@ defmodule Pleroma.Uploaders.S3 do
# The file name is re-encoded with S3's constraints here to comply with previous
# links with less strict filenames
+ @impl true
def get_file(file) do
config = Config.get([__MODULE__])
bucket = Keyword.fetch!(config, :bucket)
@@ -35,6 +36,7 @@ defmodule Pleroma.Uploaders.S3 do
])}}
end
+ @impl true
def put_file(%Pleroma.Upload{} = upload) do
config = Config.get([__MODULE__])
bucket = Keyword.get(config, :bucket)
@@ -69,6 +71,18 @@ defmodule Pleroma.Uploaders.S3 do
end
end
+ @impl true
+ def delete_file(file) do
+ [__MODULE__, :bucket]
+ |> Config.get()
+ |> ExAws.S3.delete_object(file)
+ |> ExAws.request()
+ |> case do
+ {:ok, %{status_code: 204}} -> :ok
+ error -> {:error, inspect(error)}
+ end
+ end
+
@regex Regex.compile!("[^0-9a-zA-Z!.*/'()_-]")
def strict_encode(name) do
String.replace(name, @regex, "-")