Merge branch 'develop' of git.pleroma.social:pleroma/pleroma into develop
[akkoma] / lib / pleroma / plugs / oauth_plug.ex
1 defmodule Pleroma.Plugs.OAuthPlug do
2 import Plug.Conn
3 alias Pleroma.User
4 alias Pleroma.Repo
5 alias Pleroma.Web.OAuth.Token
6
7 def init(options) do
8 options
9 end
10
11 def call(%{assigns: %{user: %User{}}} = conn, _), do: conn
12 def call(conn, opts) do
13 token = case get_req_header(conn, "authorization") do
14 ["Bearer " <> header] -> header
15 _ -> get_session(conn, :oauth_token)
16 end
17 with token when not is_nil(token) <- token,
18 %Token{user_id: user_id} <- Repo.get_by(Token, token: token),
19 %User{} = user <- Repo.get(User, user_id) do
20 conn
21 |> assign(:user, user)
22 else
23 _ -> conn
24 end
25 end
26 end