aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/admin_api/controllers/fallback_controller.ex
diff options
context:
space:
mode:
authorMaksim Pechnikov <parallel588@gmail.com>2020-05-26 17:12:26 +0300
committerMaksim Pechnikov <parallel588@gmail.com>2020-05-26 17:12:26 +0300
commit1a7ed04f9c67c2fe90d10976f40cf972ca726653 (patch)
tree86e3028fd5788ac75c0110df867983097d9ce18a /lib/pleroma/web/admin_api/controllers/fallback_controller.ex
parent04a26ab0a80a5c2ae87d329a4a83c89532849862 (diff)
parentb233c8e55cba773e8ee9a4affbcce3a3c05d1e2d (diff)
downloadpleroma-1a7ed04f9c67c2fe90d10976f40cf972ca726653.tar.gz
Merge branch 'develop' into fix/mediaproxy-http-invalidation
Diffstat (limited to 'lib/pleroma/web/admin_api/controllers/fallback_controller.ex')
-rw-r--r--lib/pleroma/web/admin_api/controllers/fallback_controller.ex31
1 files changed, 31 insertions, 0 deletions
diff --git a/lib/pleroma/web/admin_api/controllers/fallback_controller.ex b/lib/pleroma/web/admin_api/controllers/fallback_controller.ex
new file mode 100644
index 000000000..82965936d
--- /dev/null
+++ b/lib/pleroma/web/admin_api/controllers/fallback_controller.ex
@@ -0,0 +1,31 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Web.AdminAPI.FallbackController do
+ use Pleroma.Web, :controller
+
+ def call(conn, {:error, :not_found}) do
+ conn
+ |> put_status(:not_found)
+ |> json(%{error: dgettext("errors", "Not found")})
+ end
+
+ def call(conn, {:error, reason}) do
+ conn
+ |> put_status(:bad_request)
+ |> json(%{error: reason})
+ end
+
+ def call(conn, {:param_cast, _}) do
+ conn
+ |> put_status(:bad_request)
+ |> json(dgettext("errors", "Invalid parameters"))
+ end
+
+ def call(conn, _) do
+ conn
+ |> put_status(:internal_server_error)
+ |> json(%{error: dgettext("errors", "Something went wrong")})
+ end
+end