diff options
author | lain <lain@soykaf.club> | 2018-09-05 17:44:38 +0200 |
---|---|---|
committer | lain <lain@soykaf.club> | 2018-09-05 17:44:38 +0200 |
commit | faf53477488edfc6ba4268529f9945a494f30aee (patch) | |
tree | 1e5e537a825616648e47a7bdf9e346090af345f1 /lib | |
parent | 42bd985e6654a4af55df622753c3f0664e5c6bae (diff) | |
download | pleroma-faf53477488edfc6ba4268529f9945a494f30aee.tar.gz |
Add UserFetcherPlug.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/plugs/user_fetcher_plug.ex | 34 |
1 files changed, 34 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 |