aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/admin_api/controllers/fallback_controller.ex
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2020-05-25 14:01:16 +0200
committerlain <lain@soykaf.club>2020-05-25 14:01:16 +0200
commitf20dff451e7abf343906b4e74f5d47b6207a3580 (patch)
tree69278b3894508c546b2dd87b3443966dddb11364 /lib/pleroma/web/admin_api/controllers/fallback_controller.ex
parentaeb0875025cf37ad8cefe43c637f56a5a16f8628 (diff)
parent6783d544b2d3856bda3f8f9136011923ee8b30fe (diff)
downloadpleroma-f20dff451e7abf343906b4e74f5d47b6207a3580.tar.gz
Merge branch 'develop' of git.pleroma.social:pleroma/pleroma into 1808-pleroma-sucks
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