"""
@behaviour Pleroma.Upload.Filter
- require Logger
-
+ @spec filter(Pleroma.Upload.t()) :: :ok | {:error, String.t()}
def filter(%Pleroma.Upload{tempfile: file, content_type: "image" <> _}) do
- if Pleroma.Utils.command_available?("exiftool") do
- System.cmd("exiftool", ["-overwrite_original", "-gps:all=", file], parallelism: true)
- else
- Logger.warn("exiftool is not available, filter #{__MODULE__} skipped")
+ try do
+ case System.cmd("exiftool", ["-overwrite_original", "-gps:all=", file], parallelism: true) do
+ {_response, 0} -> :ok
+ {error, 1} -> {:error, error}
+ end
+ rescue
+ _e in ErlangError ->
+ {:error, "exiftool command not found"}
end
-
- :ok
end
def filter(_), do: :ok