aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2018-09-05 17:44:38 +0200
committerlain <lain@soykaf.club>2018-09-05 17:44:38 +0200
commitfaf53477488edfc6ba4268529f9945a494f30aee (patch)
tree1e5e537a825616648e47a7bdf9e346090af345f1
parent42bd985e6654a4af55df622753c3f0664e5c6bae (diff)
downloadpleroma-faf53477488edfc6ba4268529f9945a494f30aee.tar.gz
Add UserFetcherPlug.
-rw-r--r--lib/pleroma/plugs/user_fetcher_plug.ex34
-rw-r--r--test/plugs/user_fetcher_plug_test.exs37
2 files changed, 71 insertions, 0 deletions
diff --git a/lib/pleroma/plugs/user_fetcher_plug.ex b/lib/pleroma/plugs/user_fetcher_plug.ex
new file mode 100644
index 000000000..9cbaaf40a
--- /dev/null
+++ b/lib/pleroma/plugs/user_fetcher_plug.ex
@@ -0,0 +1,34 @@
+defmodule Pleroma.Plugs.UserFetcherPlug do
+ import Plug.Conn
+ alias Pleroma.Repo
+ alias Pleroma.User
+
+ def init(options) do
+ options
+ end
+
+ def call(conn, options) do
+ with %{auth_credentials: %{username: username}} <- conn.assigns,
+ {:ok, %User{} = user} <- user_fetcher(username) do
+ conn
+ |> assign(:auth_user, user)
+ else
+ _ -> conn
+ end
+ end
+
+ defp user_fetcher(username_or_email) do
+ {
+ :ok,
+ cond do
+ # First, try logging in as if it was a name
+ user = Repo.get_by(User, %{nickname: username_or_email}) ->
+ user
+
+ # If we get nil, we try using it as an email
+ user = Repo.get_by(User, %{email: username_or_email}) ->
+ user
+ end
+ }
+ end
+end
diff --git a/test/plugs/user_fetcher_plug_test.exs b/test/plugs/user_fetcher_plug_test.exs
new file mode 100644
index 000000000..5195a0c4a
--- /dev/null
+++ b/test/plugs/user_fetcher_plug_test.exs
@@ -0,0 +1,37 @@
+defmodule Pleroma.Plugs.UserFetcherPlugTest do
+ use Pleroma.Web.ConnCase, async: true
+
+ alias Pleroma.Plugs.UserFetcherPlug
+ import Pleroma.Factory
+
+ setup do
+ user = insert(:user)
+ %{user: user}
+ end
+
+ test "if an auth_credentials assign is present, it tries to fetch the user and assigns it", %{
+ conn: conn,
+ user: user
+ } do
+ conn =
+ conn
+ |> assign(:auth_credentials, %{
+ username: user.nickname,
+ password: nil
+ })
+
+ conn =
+ conn
+ |> UserFetcherPlug.call(%{})
+
+ assert conn.assigns[:auth_user] == user
+ end
+
+ test "without a credential assign it doesn't do anything", %{conn: conn} do
+ ret_conn =
+ conn
+ |> UserFetcherPlug.call(%{})
+
+ assert conn == ret_conn
+ end
+end