Make getting the uploader constistent

It was possible to get the uploader from opts.
But during the upload flow, a function was called who didn't use opts and just got it from settings.
This is inconsistent.

In practice, providing the uploader through opts was never used, so I removed it and now we always get it from settings.
This commit is contained in:
ilja 2023-03-19 12:00:45 +01:00
parent 053276ef6c
commit 5db2e998c5

View file

@ -66,7 +66,7 @@ defmodule Pleroma.Upload do
defstruct [:id, :name, :tempfile, :content_type, :width, :height, :blurhash, :path] defstruct [:id, :name, :tempfile, :content_type, :width, :height, :blurhash, :path]
defp get_description(opts, upload) do defp get_description(opts, upload) do
case {opts[:description], Pleroma.Config.get([Pleroma.Upload, :default_description])} do case {opts[:description], Config.get([Pleroma.Upload, :default_description])} do
{description, _} when is_binary(description) -> description {description, _} when is_binary(description) -> description
{_, :filename} -> upload.name {_, :filename} -> upload.name
{_, str} when is_binary(str) -> str {_, str} when is_binary(str) -> str
@ -78,6 +78,7 @@ defp get_description(opts, upload) do
@doc "Store a file. If using a `Plug.Upload{}` as the source, be sure to use `Majic.Plug` to ensure its content_type and filename is correct." @doc "Store a file. If using a `Plug.Upload{}` as the source, be sure to use `Majic.Plug` to ensure its content_type and filename is correct."
def store(upload, opts \\ []) do def store(upload, opts \\ []) do
opts = get_opts(opts) opts = get_opts(opts)
uploader = Config.get([__MODULE__, :uploader])
with {:ok, upload} <- prepare_upload(upload, opts), with {:ok, upload} <- prepare_upload(upload, opts),
upload = %__MODULE__{upload | path: upload.path || "#{upload.id}/#{upload.name}"}, upload = %__MODULE__{upload | path: upload.path || "#{upload.id}/#{upload.name}"},
@ -85,8 +86,8 @@ def store(upload, opts \\ []) do
description = get_description(opts, upload), description = get_description(opts, upload),
{_, true} <- {_, true} <-
{:description_limit, {:description_limit,
String.length(description) <= Pleroma.Config.get([:instance, :description_limit])}, String.length(description) <= Config.get([:instance, :description_limit])},
{:ok, file} <- Pleroma.Uploaders.Uploader.put_file(opts.uploader, upload) do {:ok, file} <- Pleroma.Uploaders.Uploader.put_file(uploader, upload) do
{:ok, {:ok,
%{ %{
"id" => Utils.generate_object_id(), "id" => Utils.generate_object_id(),
@ -110,7 +111,7 @@ def store(upload, opts \\ []) do
{:error, error} -> {:error, error} ->
Logger.error( Logger.error(
"#{__MODULE__} store (using #{inspect(opts.uploader)}) failed: #{inspect(error)}" "#{__MODULE__} store (using #{inspect(uploader)}) failed: #{inspect(error)}"
) )
{:error, error} {:error, error}
@ -125,23 +126,22 @@ defp get_opts(opts) do
{size_limit, activity_type} = {size_limit, activity_type} =
case Keyword.get(opts, :type) do case Keyword.get(opts, :type) do
:banner -> :banner ->
{Pleroma.Config.get!([:instance, :banner_upload_limit]), "Image"} {Config.get!([:instance, :banner_upload_limit]), "Image"}
:avatar -> :avatar ->
{Pleroma.Config.get!([:instance, :avatar_upload_limit]), "Image"} {Config.get!([:instance, :avatar_upload_limit]), "Image"}
:background -> :background ->
{Pleroma.Config.get!([:instance, :background_upload_limit]), "Image"} {Config.get!([:instance, :background_upload_limit]), "Image"}
_ -> _ ->
{Pleroma.Config.get!([:instance, :upload_limit]), "Document"} {Config.get!([:instance, :upload_limit]), "Document"}
end end
%{ %{
activity_type: Keyword.get(opts, :activity_type, activity_type), activity_type: Keyword.get(opts, :activity_type, activity_type),
size_limit: Keyword.get(opts, :size_limit, size_limit), size_limit: Keyword.get(opts, :size_limit, size_limit),
uploader: Keyword.get(opts, :uploader, Pleroma.Config.get([__MODULE__, :uploader])), filters: Keyword.get(opts, :filters, Config.get([__MODULE__, :filters])),
filters: Keyword.get(opts, :filters, Pleroma.Config.get([__MODULE__, :filters])),
description: Keyword.get(opts, :description) description: Keyword.get(opts, :description)
} }
end end
@ -219,7 +219,7 @@ defp get_url(%__MODULE__{name: name}, {:file, path}) do
path = path =
URI.encode(path, &char_unescaped?/1) <> URI.encode(path, &char_unescaped?/1) <>
if Pleroma.Config.get([__MODULE__, :link_name], false) do if Config.get([__MODULE__, :link_name], false) do
"?name=#{URI.encode(name, &char_unescaped?/1)}" "?name=#{URI.encode(name, &char_unescaped?/1)}"
else else
"" ""
@ -231,8 +231,5 @@ defp get_url(%__MODULE__{name: name}, {:file, path}) do
defp get_url(_upload, {:url, url}), do: url defp get_url(_upload, {:url, url}), do: url
def base_url do def base_url(), do: Config.get([__MODULE__, :uploader]).base_url()
uploader = Config.get([Pleroma.Upload, :uploader])
uploader.base_url()
end
end end