extract get_or_exchange token
This commit is contained in:
parent
dafdadfb72
commit
4c89219fb8
3 changed files with 12 additions and 26 deletions
|
@ -22,21 +22,13 @@ defmodule Pleroma.Web.MastodonAPI.AuthController do
|
||||||
|
|
||||||
@local_mastodon_name "Mastodon-Local"
|
@local_mastodon_name "Mastodon-Local"
|
||||||
|
|
||||||
defp get_or_exchange_token(%Authorization{} = auth, %App{} = app, %User{} = user) do
|
|
||||||
if auth.used do
|
|
||||||
Token.get_preeexisting_by_app_and_user(app, user)
|
|
||||||
else
|
|
||||||
Token.exchange_token(app, auth)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
@doc "GET /web/login"
|
@doc "GET /web/login"
|
||||||
# Local Mastodon FE login callback action
|
# Local Mastodon FE login callback action
|
||||||
def login(conn, %{"code" => auth_token} = params) do
|
def login(conn, %{"code" => auth_token} = params) do
|
||||||
with {:ok, app} <- local_mastofe_app(),
|
with {:ok, app} <- local_mastofe_app(),
|
||||||
{:ok, auth} <- Authorization.get_by_token(app, auth_token),
|
{:ok, auth} <- Authorization.get_by_token(app, auth_token),
|
||||||
%User{} = user <- User.get_cached_by_id(auth.user_id),
|
%User{} = user <- User.get_cached_by_id(auth.user_id),
|
||||||
{:ok, oauth_token} <- get_or_exchange_token(auth, app, user) do
|
{:ok, oauth_token} <- Token.get_or_exchange_token(auth, app, user) do
|
||||||
redirect_to =
|
redirect_to =
|
||||||
conn
|
conn
|
||||||
|> local_mastodon_post_login_path()
|
|> local_mastodon_post_login_path()
|
||||||
|
|
|
@ -291,27 +291,13 @@ def token_exchange(%Plug.Conn{} = conn, %{"grant_type" => "authorization_code"}
|
||||||
with {:ok, app} <- Token.Utils.fetch_app(conn),
|
with {:ok, app} <- Token.Utils.fetch_app(conn),
|
||||||
fixed_token = Token.Utils.fix_padding(params["code"]),
|
fixed_token = Token.Utils.fix_padding(params["code"]),
|
||||||
{:ok, auth} <- Authorization.get_by_token(app, fixed_token),
|
{:ok, auth} <- Authorization.get_by_token(app, fixed_token),
|
||||||
%User{} = user <- User.get_cached_by_id(auth.user_id) do
|
%User{} = user <- User.get_cached_by_id(auth.user_id),
|
||||||
if auth.used do
|
{:ok, token} <- Token.get_or_exchange_token(auth, app, user) do
|
||||||
# reuse token, we already have a valid one
|
|
||||||
with {:ok, token} <- Token.get_preeexisting_by_app_and_user(app, user) do
|
|
||||||
after_token_exchange(conn, %{user: user, token: token})
|
after_token_exchange(conn, %{user: user, token: token})
|
||||||
else
|
else
|
||||||
error ->
|
error ->
|
||||||
handle_token_exchange_error(conn, error)
|
handle_token_exchange_error(conn, error)
|
||||||
end
|
end
|
||||||
else
|
|
||||||
with {:ok, token} <- Token.exchange_token(app, auth) do
|
|
||||||
after_token_exchange(conn, %{user: user, token: token})
|
|
||||||
else
|
|
||||||
error ->
|
|
||||||
handle_token_exchange_error(conn, error)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
else
|
|
||||||
error ->
|
|
||||||
handle_token_exchange_error(conn, error)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def token_exchange(
|
def token_exchange(
|
||||||
|
|
|
@ -96,6 +96,14 @@ defp put_refresh_token(changeset, attrs) do
|
||||||
|> unique_constraint(:refresh_token)
|
|> unique_constraint(:refresh_token)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get_or_exchange_token(%Authorization{} = auth, %App{} = app, %User{} = user) do
|
||||||
|
if auth.used do
|
||||||
|
get_preeexisting_by_app_and_user(app, user)
|
||||||
|
else
|
||||||
|
exchange_token(app, auth)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
defp put_valid_until(changeset, attrs) do
|
defp put_valid_until(changeset, attrs) do
|
||||||
valid_until =
|
valid_until =
|
||||||
Map.get(attrs, :valid_until, NaiveDateTime.add(NaiveDateTime.utc_now(), lifespan()))
|
Map.get(attrs, :valid_until, NaiveDateTime.add(NaiveDateTime.utc_now(), lifespan()))
|
||||||
|
|
Loading…
Reference in a new issue