aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/uploader_controller.ex
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2019-01-25 05:00:47 +0000
committerkaniini <nenolod@gmail.com>2019-01-25 05:00:47 +0000
commitc9b418e5477229017b3750c55cf3ea3d03b7e609 (patch)
treed1b458bea76ff3ec296897de405f9e3c8578f897 /lib/pleroma/web/uploader_controller.ex
parent44693fbf6e5c5ec5622207e263688e3af7d1a83a (diff)
parent4df71cd88b2725f1838c2899b3078a74dbb0c33f (diff)
downloadpleroma-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.ex25
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