Sample code for 30+ languages & platforms
PowerBuilder

Microsoft Graph Revoke OAuth2 Access Tokens

See more Microsoft Graph Examples

Invalidates all the refresh tokens issued to applications for a user (as well as session cookies in a user's browser), by resetting the signInSessionsValidFromDateTime user property to the current date-time. Typically, this operation is performed (by the user or an administrator) if the user has a lost or stolen device. This operation prevents access to the organization's data through applications on the device by requiring the user to sign in again to all applications that they have previously consented to, independent of device.

Chilkat PowerBuilder Downloads

PowerBuilder
integer li_rc
integer li_Success
oleobject loo_Http
oleobject loo_Resp
oleobject loo_Json

li_Success = 0

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

// Send a POST as shown below to invalidate all the refresh tokens issued to applications for a user (as well as session cookies in a user's browser),
// 

// 	POST /v1.0/me/revokeSignInSessions HTTP/1.1
// 	Host: graph.microsoft.com
//      Authorization: Bearer ACCESS_TOKEN
// 	Content-Type: application/json
// 	Content-Length: 0
// 
// or specify a specific user:
// 
// 	POST /v1.0/users/{id | userPrincipalName}/revokeSignInSessions HTTP/1.1
// 	Host: graph.microsoft.com
//      Authorization: Bearer ACCESS_TOKEN
// 	Content-Type: application/json
// 	Content-Length: 0

loo_Http = create oleobject
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")
if li_rc < 0 then
    destroy loo_Http
    MessageBox("Error","Connecting to COM object failed")
    return
end if

// Set the http.AuthToken property to automatically add the "Authorization: Bearer ACCESS_TOKEN" header
loo_Http.AuthToken = "ACCESS_TOKEN"

// Send an empty JSON request body.
loo_Resp = create oleobject
li_rc = loo_Resp.ConnectToNewObject("Chilkat.HttpResponse")

li_Success = loo_Http.HttpStr("POST","https://graph.microsoft.com/v1.0/me/revokeSignInSessions","","utf-8","application/json",loo_Resp)
if li_Success = 0 then
    Write-Debug loo_Http.LastErrorText
    destroy loo_Http
    destroy loo_Resp
    return
end if

// A response code of 204 is success
if loo_Resp.StatusCode = 204 then
    Write-Debug "Success."
    destroy loo_Http
    destroy loo_Resp
    return
end if

// We have an error...

// Load the JSON response.
loo_Json = create oleobject
li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject")

loo_Json.Load(loo_Resp.BodyStr)
loo_Json.EmitCompact = 0

// Show the JSON response.
Write-Debug loo_Json.Emit()

Write-Debug "Response status code: " + string(loo_Resp.StatusCode)


destroy loo_Http
destroy loo_Resp
destroy loo_Json