0

Delete Grant

by
Published 4 days ago

Revoke a consent grant by its id, ending the user's authorization for that application.

Script auth0 Verified

The script

Submitted by hugo989 Typescript (fetch-only)
Verified 5 days ago
1
//native
2

3
async function getManagementToken(auth: RT.Auth0): Promise<string> {
4
  const response = await fetch(`https://${auth.domain}/oauth/token`, {
5
    method: "POST",
6
    headers: { "Content-Type": "application/json" },
7
    body: JSON.stringify({
8
      grant_type: "client_credentials",
9
      client_id: auth.client_id,
10
      client_secret: auth.client_secret,
11
      audience: `https://${auth.domain}/api/v2/`,
12
    }),
13
  })
14
  if (!response.ok) {
15
    throw new Error(`${response.status} ${await response.text()}`)
16
  }
17
  const { access_token } = (await response.json()) as { access_token: string }
18
  return access_token
19
}
20
/**
21
 * Delete Grant
22
 * Revoke a consent grant by its id, ending the user's authorization for that application.
23
 */
24
export async function main(auth: RT.Auth0, grant_id: string) {
25
  const token = await getManagementToken(auth)
26
  const url = new URL(`https://${auth.domain}/api/v2/grants/${grant_id}`)
27

28
  const response = await fetch(url, {
29
    method: "DELETE",
30
    headers: {
31
      Authorization: `Bearer ${token}`,
32
      Accept: "application/json",
33
    },
34
  })
35

36
  if (!response.ok) {
37
    throw new Error(`${response.status} ${await response.text()}`)
38
  }
39

40
  if (response.status === 204) return { success: true }
41
  return await response.json()
42
}
43