OAuth: Support /revoke endpoint for revoking tokens
authorMartin Kühl <martin.kuehl@gmail.com>
Tue, 28 Aug 2018 23:25:40 +0000 (01:25 +0200)
committerMartin Kühl <martin.kuehl@gmail.com>
Sat, 1 Sep 2018 21:10:48 +0000 (23:10 +0200)
(for compatibility with Mastodon)

lib/pleroma/web/oauth/oauth_controller.ex
lib/pleroma/web/router.ex

index 934171585ecead6b9f98f2b80fdacfd87a76047a..160cedd8ee304f3ab103e9097a630ea9fcbfa2f3 100644 (file)
@@ -118,6 +118,18 @@ defmodule Pleroma.Web.OAuth.OAuthController do
     token_exchange(conn, params)
   end
 
+  def token_revoke(conn, %{"token" => token} = params) do
+    with %App{} = app <- get_app_from_request(conn, params),
+         %Token{} = token <- Repo.get_by(Token, token: token, app_id: app.id),
+         {:ok, %Token{}} <- Repo.delete(token) do
+      json(conn, %{})
+    else
+      _error ->
+        # RFC 7009: invalid tokens [in the request] do not cause an error response
+        json(conn, %{})
+    end
+  end
+
   defp fix_padding(token) do
     token
     |> Base.url_decode64!(padding: false)
index 92732379465af1d6353d7d4c39a8123ac7cbbae6..5f746df31e6c0ebf5cd4913facf74850adf5c3a2 100644 (file)
@@ -93,6 +93,7 @@ defmodule Pleroma.Web.Router do
     get("/authorize", OAuthController, :authorize)
     post("/authorize", OAuthController, :create_authorization)
     post("/token", OAuthController, :token_exchange)
+    post("/revoke", OAuthController, :token_revoke)
   end
 
   scope "/api/v1", Pleroma.Web.MastodonAPI do