diff options
author | kaniini <nenolod@gmail.com> | 2019-01-25 05:00:47 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2019-01-25 05:00:47 +0000 |
commit | c9b418e5477229017b3750c55cf3ea3d03b7e609 (patch) | |
tree | d1b458bea76ff3ec296897de405f9e3c8578f897 /lib/pleroma/web/uploader_controller.ex | |
parent | 44693fbf6e5c5ec5622207e263688e3af7d1a83a (diff) | |
parent | 4df71cd88b2725f1838c2899b3078a74dbb0c33f (diff) | |
download | pleroma-c9b418e5477229017b3750c55cf3ea3d03b7e609.tar.gz |
Merge branch 'develop' into 'oembed_provider'
# Conflicts:
# lib/pleroma/activity.ex
Diffstat (limited to 'lib/pleroma/web/uploader_controller.ex')
-rw-r--r-- | lib/pleroma/web/uploader_controller.ex | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/pleroma/web/uploader_controller.ex b/lib/pleroma/web/uploader_controller.ex new file mode 100644 index 000000000..6c28d1197 --- /dev/null +++ b/lib/pleroma/web/uploader_controller.ex @@ -0,0 +1,25 @@ +defmodule Pleroma.Web.UploaderController do + use Pleroma.Web, :controller + + alias Pleroma.Uploaders.Uploader + + def callback(conn, params = %{"upload_path" => upload_path}) do + process_callback(conn, :global.whereis_name({Uploader, upload_path}), params) + end + + def callbacks(conn, _) do + send_resp(conn, 400, "bad request") + end + + defp process_callback(conn, pid, params) when is_pid(pid) do + send(pid, {Uploader, self(), conn, params}) + + receive do + {Uploader, conn} -> conn + end + end + + defp process_callback(conn, _, _) do + send_resp(conn, 400, "bad request") + end +end |