aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/oauth/token/strategy/refresh_token.ex
diff options
context:
space:
mode:
authorRoman Chvanikov <chvanikoff@gmail.com>2019-05-08 17:08:06 +0700
committerRoman Chvanikov <chvanikoff@gmail.com>2019-05-08 17:08:06 +0700
commitb6b5b16ba4d65ecd9812b02d79f844548266eb8b (patch)
tree790623e31fed199f04168bcbddb4222a4bfb0a3a /lib/pleroma/web/oauth/token/strategy/refresh_token.ex
parent0f0cc2703b7ffb99c58e72782925ea4dd61db41d (diff)
parent14deed7f7d0b88d5c8ac19bb3de467429c289746 (diff)
downloadpleroma-b6b5b16ba4d65ecd9812b02d79f844548266eb8b.tar.gz
Merge develop
Diffstat (limited to 'lib/pleroma/web/oauth/token/strategy/refresh_token.ex')
-rw-r--r--lib/pleroma/web/oauth/token/strategy/refresh_token.ex54
1 files changed, 54 insertions, 0 deletions
diff --git a/lib/pleroma/web/oauth/token/strategy/refresh_token.ex b/lib/pleroma/web/oauth/token/strategy/refresh_token.ex
new file mode 100644
index 000000000..7df0be14e
--- /dev/null
+++ b/lib/pleroma/web/oauth/token/strategy/refresh_token.ex
@@ -0,0 +1,54 @@
+defmodule Pleroma.Web.OAuth.Token.Strategy.RefreshToken do
+ @moduledoc """
+ Functions for dealing with refresh token strategy.
+ """
+
+ alias Pleroma.Config
+ alias Pleroma.Repo
+ alias Pleroma.Web.OAuth.Token
+ alias Pleroma.Web.OAuth.Token.Strategy.Revoke
+
+ @doc """
+ Will grant access token by refresh token.
+ """
+ @spec grant(Token.t()) :: {:ok, Token.t()} | {:error, any()}
+ def grant(token) do
+ access_token = Repo.preload(token, [:user, :app])
+
+ result =
+ Repo.transaction(fn ->
+ token_params = %{
+ app: access_token.app,
+ user: access_token.user,
+ scopes: access_token.scopes
+ }
+
+ access_token
+ |> revoke_access_token()
+ |> create_access_token(token_params)
+ end)
+
+ case result do
+ {:ok, {:error, reason}} -> {:error, reason}
+ {:ok, {:ok, token}} -> {:ok, token}
+ {:error, reason} -> {:error, reason}
+ end
+ end
+
+ defp revoke_access_token(token) do
+ Revoke.revoke(token)
+ end
+
+ defp create_access_token({:error, error}, _), do: {:error, error}
+
+ defp create_access_token({:ok, token}, %{app: app, user: user} = token_params) do
+ Token.create_token(app, user, add_refresh_token(token_params, token.refresh_token))
+ end
+
+ defp add_refresh_token(params, token) do
+ case Config.get([:oauth2, :issue_new_refresh_token], false) do
+ true -> Map.put(params, :refresh_token, token)
+ false -> params
+ end
+ end
+end