projects
/
akkoma
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'config-behaviours-runtime' into 'develop'
[akkoma]
/
lib
/
pleroma
/
uploaders
/
local.ex
diff --git
a/lib/pleroma/uploaders/local.ex
b/lib/pleroma/uploaders/local.ex
index fc533da23cd2fa0194d96c7185a3014869da7be1..10b3069f4c91610aad0deab6607cfc6e005ea3d5 100644
(file)
--- a/
lib/pleroma/uploaders/local.ex
+++ b/
lib/pleroma/uploaders/local.ex
@@
-1,17
+1,19
@@
# Pleroma: A lightweight social networking server
# Pleroma: A lightweight social networking server
-# Copyright © 2017-20
19
Pleroma Authors <https://pleroma.social/>
+# Copyright © 2017-20
20
Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Uploaders.Local do
@behaviour Pleroma.Uploaders.Uploader
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Uploaders.Local do
@behaviour Pleroma.Uploaders.Uploader
+ @impl true
def get_file(_) do
{:ok, {:static_dir, upload_path()}}
end
def get_file(_) do
{:ok, {:static_dir, upload_path()}}
end
+ @impl true
def put_file(upload) do
{local_path, file} =
def put_file(upload) do
{local_path, file} =
- case Enum.reverse(
String.split(upload.path, "/", trim: true
)) do
+ case Enum.reverse(
Path.split(upload.path
)) do
[file] ->
{upload_path(), file}
[file] ->
{upload_path(), file}
@@
-23,7
+25,7
@@
defmodule Pleroma.Uploaders.Local do
result_file = Path.join(local_path, file)
result_file = Path.join(local_path, file)
-
unless
File.exists?(result_file) do
+
if not
File.exists?(result_file) do
File.cp!(upload.tempfile, result_file)
end
File.cp!(upload.tempfile, result_file)
end
@@
-33,4
+35,15
@@
defmodule Pleroma.Uploaders.Local do
def upload_path do
Pleroma.Config.get!([__MODULE__, :uploads])
end
def upload_path do
Pleroma.Config.get!([__MODULE__, :uploads])
end
+
+ @impl true
+ def delete_file(path) do
+ upload_path()
+ |> Path.join(path)
+ |> File.rm()
+ |> case do
+ :ok -> :ok
+ {:error, posix_error} -> {:error, to_string(posix_error)}
+ end
+ end
end
end