Sample code for 30+ languages & platforms
.NET Core C#

Isabel Connect Revoke Access Token

See more Ibanity Examples

Revokes an access token.

Chilkat .NET Core C# Downloads

.NET Core C#
bool success = false;

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

Chilkat.Http http = new Chilkat.Http();

// // 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.)
Chilkat.Cert cert = new Chilkat.Cert();
success = cert.LoadPfxFile("qa_data/pfx/my_ibanity_certificate.pfx","my_pfx_password");
if (success == false) {
    Debug.WriteLine(cert.LastErrorText);
    return;
}

success = http.SetSslClientCert(cert);
if (success == false) {
    Debug.WriteLine(http.LastErrorText);
    return;
}

Chilkat.HttpRequest req = new Chilkat.HttpRequest();
req.HttpVerb = "POST";
req.Path = "/isabel-connect/oauth2/revoke";
req.ContentType = "application/x-www-form-urlencoded";

// Load the previously obtained access token.
Chilkat.JsonObject jsonToken = new Chilkat.JsonObject();
success = jsonToken.LoadFile("qa_data/tokens/isabel_access_token.json");
if (success == false) {
    Debug.WriteLine("No existing access token.");
    return;
}

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");

Chilkat.HttpResponse resp = new Chilkat.HttpResponse();
success = http.HttpReq("https://api.ibanity.com/isabel-connect/oauth2/revoke",req,resp);
if (success == false) {
    Debug.WriteLine(http.LastErrorText);
    return;
}

Chilkat.StringBuilder sbResponseBody = new Chilkat.StringBuilder();
resp.GetBodySb(sbResponseBody);

int respStatusCode = resp.StatusCode;
Debug.WriteLine("Response Status Code = " + Convert.ToString(respStatusCode));
if (respStatusCode >= 400) {
    Debug.WriteLine("Response Header:");
    Debug.WriteLine(resp.Header);
    Debug.WriteLine("Failed.");
    return;
}

Debug.WriteLine("Response Body:");
Debug.WriteLine(sbResponseBody.GetAsString());

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