Sample code for 30+ languages & platforms
PHP Extension

Isabel Connect Revoke Access Token

See more Ibanity Examples

Revokes an access token.

Chilkat PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

$success = false;

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

$http = new CkHttp();

// // Implements the following CURL command:
// 
// curl -X POST https://api.ibanity.com/isabel-connect/oauth2/revoke \
// --cert certificate.pem:qwertyuiop1 \
// --key private_key.pem  \
// -H "Content-Type: application/x-www-form-urlencoded" \
// -H "Accept: application/vnd.api+json"  \
// -d token=8787 \
// -d client_id=valid_client_id \
// -d client_secret=valid_client_secret 

// Ibanity provides the certificate + private key in PFX format.  This example will use the .pfx instead of the pair of PEM files.
// (It is also possible to implement using Chilkat with the PEM files, but PFX is easier.)
$cert = new CkCert();
$success = $cert->LoadPfxFile('qa_data/pfx/my_ibanity_certificate.pfx','my_pfx_password');
if ($success == false) {
    print $cert->lastErrorText() . "\n";
    exit;
}

$success = $http->SetSslClientCert($cert);
if ($success == false) {
    print $http->lastErrorText() . "\n";
    exit;
}

$req = new CkHttpRequest();
$req->put_HttpVerb('POST');
$req->put_Path('/isabel-connect/oauth2/revoke');
$req->put_ContentType('application/x-www-form-urlencoded');

// Load the previously obtained access token.
$jsonToken = new CkJsonObject();
$success = $jsonToken->LoadFile('qa_data/tokens/isabel_access_token.json');
if ($success == false) {
    print 'No existing access token.' . "\n";
    exit;
}

$req->AddParam('token',$jsonToken->stringOf('access_token'));

// Note: For sandbox testing, we literally want to use the strings
// "valid_client_id", and "valid_client_secret".
// For the live app, you would replace these with actual values.
$req->AddParam('client_id','valid_client_id');
$req->AddParam('client_secret','valid_client_secret');

$req->AddHeader('Accept','application/vnd.api+json');

$resp = new CkHttpResponse();
$success = $http->HttpReq('https://api.ibanity.com/isabel-connect/oauth2/revoke',$req,$resp);
if ($success == false) {
    print $http->lastErrorText() . "\n";
    exit;
}

$sbResponseBody = new CkStringBuilder();
$resp->GetBodySb($sbResponseBody);

$respStatusCode = $resp->get_StatusCode();
print 'Response Status Code = ' . $respStatusCode . "\n";
if ($respStatusCode >= 400) {
    print 'Response Header:' . "\n";
    print $resp->header() . "\n";
    print 'Failed.' . "\n";
    exit;
}

print 'Response Body:' . "\n";
print $sbResponseBody->getAsString() . "\n";

// If successful, the response status code = 200, and the response body is "{}"

?>