aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/oauth/token/strategy/revoke.ex
diff options
context:
space:
mode:
authorlambda <lain@soykaf.club>2019-05-06 17:51:03 +0000
committerlambda <lain@soykaf.club>2019-05-06 17:51:03 +0000
commit6b79be4a06064b8bb54fe73c2ac768d10d52068b (patch)
treedb56c5118b7e853f27d5bd0d0782ab72f532d821 /lib/pleroma/web/oauth/token/strategy/revoke.ex
parentaacac9da0beddcf797958acca330747b8f2d1f06 (diff)
parent1040caf096347b638b9fda5b23fcccde87b32ede (diff)
downloadpleroma-6b79be4a06064b8bb54fe73c2ac768d10d52068b.tar.gz
Merge branch 'issue_800' into 'develop'
[#800] added ability renew access_token by refresh_token See merge request pleroma/pleroma!1045
Diffstat (limited to 'lib/pleroma/web/oauth/token/strategy/revoke.ex')
-rw-r--r--lib/pleroma/web/oauth/token/strategy/revoke.ex22
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/pleroma/web/oauth/token/strategy/revoke.ex b/lib/pleroma/web/oauth/token/strategy/revoke.ex
new file mode 100644
index 000000000..dea63ca54
--- /dev/null
+++ b/lib/pleroma/web/oauth/token/strategy/revoke.ex
@@ -0,0 +1,22 @@
+defmodule Pleroma.Web.OAuth.Token.Strategy.Revoke do
+ @moduledoc """
+ Functions for dealing with revocation.
+ """
+
+ alias Pleroma.Repo
+ alias Pleroma.Web.OAuth.App
+ alias Pleroma.Web.OAuth.Token
+
+ @doc "Finds and revokes access token for app and by token"
+ @spec revoke(App.t(), map()) :: {:ok, Token.t()} | {:error, :not_found | Ecto.Changeset.t()}
+ def revoke(%App{} = app, %{"token" => token} = _attrs) do
+ with {:ok, token} <- Token.get_by_token(app, token),
+ do: revoke(token)
+ end
+
+ @doc "Revokes access token"
+ @spec revoke(Token.t()) :: {:ok, Token.t()} | {:error, Ecto.Changeset.t()}
+ def revoke(%Token{} = token) do
+ Repo.delete(token)
+ end
+end