diff options
author | Mark Felder <feld@feld.me> | 2021-01-07 18:34:30 -0600 |
---|---|---|
committer | Mark Felder <feld@feld.me> | 2021-01-08 17:32:42 -0600 |
commit | ad7998361498b08d45ea0971f8b6ecbd8ca0740e (patch) | |
tree | ecb40efdb1a7f92a49c7022363dd2b47578bee5f | |
parent | 5822338f3a42852c18a323c35041b14b29661de6 (diff) | |
download | pleroma-ad7998361498b08d45ea0971f8b6ecbd8ca0740e.tar.gz |
Fix URL generated for backup files, try to create a source of truth we can reuse throughout the codebase
-rw-r--r-- | lib/pleroma/upload.ex | 26 | ||||
-rw-r--r-- | lib/pleroma/web/pleroma_api/views/backup_view.ex | 2 |
2 files changed, 27 insertions, 1 deletions
diff --git a/lib/pleroma/upload.ex b/lib/pleroma/upload.ex index db2cc1dae..101cfec98 100644 --- a/lib/pleroma/upload.ex +++ b/lib/pleroma/upload.ex @@ -31,6 +31,7 @@ defmodule Pleroma.Upload do """ alias Ecto.UUID + alias Pleroma.Config require Logger @type source :: @@ -228,4 +229,29 @@ defmodule Pleroma.Upload do end defp url_from_spec(_upload, _base_url, {:url, url}), do: url + + def base_url do + uploader = Config.get([Pleroma.Upload, :uploader]) + upload_base_url = Config.get([Pleroma.Upload, :base_url]) + + case uploader do + Pleroma.Uploaders.Local -> + cond do + !is_nil(upload_base_url) -> + upload_base_url + + true -> + Pleroma.Web.base_url() <> "/media/" + end + + _ -> + cond do + !is_nil(Config.get([uploader, :public_endpoint])) -> + Config.get([uploader, :public_endpoint]) + + true -> + upload_base_url + end + end + end end diff --git a/lib/pleroma/web/pleroma_api/views/backup_view.ex b/lib/pleroma/web/pleroma_api/views/backup_view.ex index 39affe979..e04c8fc0f 100644 --- a/lib/pleroma/web/pleroma_api/views/backup_view.ex +++ b/lib/pleroma/web/pleroma_api/views/backup_view.ex @@ -24,6 +24,6 @@ defmodule Pleroma.Web.PleromaAPI.BackupView do end def download_url(%Backup{file_name: file_name}) do - Pleroma.Web.Endpoint.url() <> "/media/backups/" <> file_name + Pleroma.Upload.base_url() <> "/backups/" <> file_name end end |