aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/exec.ex38
-rw-r--r--lib/pleroma/helpers/media_helper.ex19
-rw-r--r--lib/pleroma/web/media_proxy/media_proxy_controller.ex50
3 files changed, 41 insertions, 66 deletions
diff --git a/lib/pleroma/exec.ex b/lib/pleroma/exec.ex
deleted file mode 100644
index 1b088d322..000000000
--- a/lib/pleroma/exec.ex
+++ /dev/null
@@ -1,38 +0,0 @@
-# Pleroma: A lightweight social networking server
-# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
-# SPDX-License-Identifier: AGPL-3.0-only
-
-defmodule Pleroma.Exec do
- @moduledoc "Pleroma wrapper around Exexec commands."
-
- alias Pleroma.Config
-
- def ensure_started(options_overrides \\ %{}) do
- options =
- if Config.get([:exexec, :root_mode]) || System.get_env("USER") == "root" do
- # Note: running as `root` is discouraged (yet Gitlab CI does that by default)
- %{root: true, user: "root", limit_users: ["root"]}
- else
- %{}
- end
-
- options =
- options
- |> Map.merge(Config.get([:exexec, :options], %{}))
- |> Map.merge(options_overrides)
-
- with {:error, {:already_started, pid}} <- Exexec.start(options) do
- {:ok, pid}
- end
- end
-
- def run(cmd, options \\ %{}) do
- ensure_started()
- Exexec.run(cmd, options)
- end
-
- def cmd(cmd, options \\ %{}) do
- options = Map.merge(%{sync: true, stdout: true}, options)
- run(cmd, options)
- end
-end
diff --git a/lib/pleroma/helpers/media_helper.ex b/lib/pleroma/helpers/media_helper.ex
index ecd234558..ca46698cc 100644
--- a/lib/pleroma/helpers/media_helper.ex
+++ b/lib/pleroma/helpers/media_helper.ex
@@ -7,19 +7,24 @@ defmodule Pleroma.Helpers.MediaHelper do
Handles common media-related operations.
"""
- def ffmpeg_resize_remote(uri, %{max_width: max_width, max_height: max_height}) do
+ def ffmpeg_resize(uri_or_path, %{max_width: max_width, max_height: max_height}) do
cmd = ~s"""
- curl -L "#{uri}" |
- ffmpeg -i pipe:0 -f lavfi -i color=c=white \
+ ffmpeg -i #{uri_or_path} -f lavfi -i color=c=white \
-filter_complex "[0:v] scale='min(#{max_width},iw)':'min(#{max_height},ih)': \
force_original_aspect_ratio=decrease [scaled]; \
[1][scaled] scale2ref [bg][img]; [bg] setsar=1 [bg]; [bg][img] overlay=shortest=1" \
- -f image2 -vcodec mjpeg -frames:v 1 pipe:1 | \
- cat
+ -loglevel quiet -f image2 -vcodec mjpeg -frames:v 1 pipe:1
"""
- with {:ok, [stdout: stdout_list]} <- Pleroma.Exec.cmd(cmd) do
- {:ok, Enum.join(stdout_list)}
+ pid = Port.open({:spawn, cmd}, [:use_stdio, :in, :stream, :exit_status, :binary])
+
+ receive do
+ {^pid, {:data, data}} ->
+ send(pid, {self(), :close})
+ {:ok, data}
+
+ {^pid, {:exit_status, status}} when status > 0 ->
+ {:error, status}
end
end
end
diff --git a/lib/pleroma/web/media_proxy/media_proxy_controller.ex b/lib/pleroma/web/media_proxy/media_proxy_controller.ex
index 583c177f2..8861398dd 100644
--- a/lib/pleroma/web/media_proxy/media_proxy_controller.ex
+++ b/lib/pleroma/web/media_proxy/media_proxy_controller.ex
@@ -66,31 +66,23 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
end
end
- defp thumbnail_max_dimensions(params) do
- config = Config.get([:media_preview_proxy], [])
-
- thumbnail_max_width =
- if w = params["thumbnail_max_width"] do
- String.to_integer(w)
- else
- Keyword.fetch!(config, :thumbnail_max_width)
- end
+ defp handle_preview("image/" <> _ = _content_type, conn, url) do
+ handle_image_or_video_preview(conn, url)
+ end
- thumbnail_max_height =
- if h = params["thumbnail_max_height"] do
- String.to_integer(h)
- else
- Keyword.fetch!(config, :thumbnail_max_height)
- end
+ defp handle_preview("video/" <> _ = _content_type, conn, url) do
+ handle_image_or_video_preview(conn, url)
+ end
- {thumbnail_max_width, thumbnail_max_height}
+ defp handle_preview(content_type, conn, _url) do
+ send_resp(conn, :unprocessable_entity, "Unsupported content type: #{content_type}.")
end
- defp handle_preview("image/" <> _ = _content_type, %{params: params} = conn, url) do
+ defp handle_image_or_video_preview(%{params: params} = conn, url) do
with {thumbnail_max_width, thumbnail_max_height} <- thumbnail_max_dimensions(params),
media_proxy_url <- MediaProxy.url(url),
{:ok, thumbnail_binary} <-
- MediaHelper.ffmpeg_resize_remote(
+ MediaHelper.ffmpeg_resize(
media_proxy_url,
%{max_width: thumbnail_max_width, max_height: thumbnail_max_height}
) do
@@ -99,12 +91,28 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
|> send_resp(200, thumbnail_binary)
else
_ ->
- send_resp(conn, :failed_dependency, "Can't handle image preview.")
+ send_resp(conn, :failed_dependency, "Can't handle preview.")
end
end
- defp handle_preview(content_type, conn, _url) do
- send_resp(conn, :unprocessable_entity, "Unsupported content type: #{content_type}.")
+ defp thumbnail_max_dimensions(params) do
+ config = Config.get([:media_preview_proxy], [])
+
+ thumbnail_max_width =
+ if w = params["thumbnail_max_width"] do
+ String.to_integer(w)
+ else
+ Keyword.fetch!(config, :thumbnail_max_width)
+ end
+
+ thumbnail_max_height =
+ if h = params["thumbnail_max_height"] do
+ String.to_integer(h)
+ else
+ Keyword.fetch!(config, :thumbnail_max_height)
+ end
+
+ {thumbnail_max_width, thumbnail_max_height}
end
defp preview_head_request_timeout do