aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/uploader_controller.ex
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2019-01-23 13:05:58 +0100
committerlain <lain@soykaf.club>2019-01-23 13:05:58 +0100
commit2de208817c04d9a48aaf0fdaf887dd0e10d15907 (patch)
tree38cf094a6405c147fe5d8cff3be173f2379166d9 /lib/pleroma/web/uploader_controller.ex
parent7390192c03248ff18eff19d555f28300a7b07e09 (diff)
parentb624b7a150c813722c4ffe82112c03e246fb5760 (diff)
downloadpleroma-2de208817c04d9a48aaf0fdaf887dd0e10d15907.tar.gz
Merge branch 'develop' into rename/pleroma_activity_consistency
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