Runtime configuration
[akkoma] / lib / pleroma / plugs / oauth_plug.ex
index fc2a907a2ff3d5a928739c39045ff58c5bc699d7..0380ce14db4d0dac270686ad5a8d5633f01d3286 100644 (file)
@@ -9,10 +9,18 @@ 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