Merge branch 'fix/tootdon-mentions' into 'develop'
[akkoma] / lib / pleroma / plugs / oauth_plug.ex
index fc2a907a2ff3d5a928739c39045ff58c5bc699d7..be737dc9a22e7738893fee460879db7bf6262bba 100644 (file)
@@ -9,10 +9,15 @@ defmodule Pleroma.Plugs.OAuthPlug do
   end
 
   def call(%{assigns: %{user: %User{}}} = conn, _), do: conn
-  def call(conn, opts) do
-    with ["Bearer " <> header] <- get_req_header(conn, "authorization"),
-         %Token{user_id: user_id} <- Repo.get_by(Token, token: header),
-         %User{} = user <- Repo.get(User, user_id) do
+  def call(conn, _) do
+    token = case get_req_header(conn, "authorization") do
+              ["Bearer " <> header] -> header
+              _ -> get_session(conn, :oauth_token)
+            end
+    with token when not is_nil(token) <- token,
+         %Token{user_id: user_id} <- Repo.get_by(Token, token: token),
+         %User{} = user <- Repo.get(User, user_id),
+         false <- !!user.info["deactivated"] do
       conn
       |> assign(:user, user)
     else