Merge branch 'login-with-email' into 'develop'
authorkaniini <nenolod@gmail.com>
Sun, 26 Aug 2018 21:35:12 +0000 (21:35 +0000)
committerkaniini <nenolod@gmail.com>
Sun, 26 Aug 2018 21:35:12 +0000 (21:35 +0000)
When logging in, try treating the login as an email

Closes #245

See merge request pleroma/pleroma!295

lib/pleroma/web/router.ex

index 2dadf974c74f09a1514fb5380fb6e0f740242bad..913152c5a33208250a70ed28051df31799c8425f 100644 (file)
@@ -8,8 +8,16 @@ defmodule Pleroma.Web.Router do
   @public Keyword.get(@instance, :public)
   @registrations_open Keyword.get(@instance, :registrations_open)
 
-  def user_fetcher(username) do
-    {:ok, Repo.get_by(User, %{nickname: username})}
+  def 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
 
   pipeline :api do