Sample code for 30+ languages & platforms
PHP Extension

Isabel Connect Create Access Token given Valid Refresh Token

See more Ibanity Examples

Create (refresh) an access token given a valid refresh 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/token \
// --cert certificate.pem:qwertyuiop1 \
// --key private_key.pem  \
// -H "Content-Type: application/x-www-form-urlencoded" \
// -H "Accept: application/vnd.api+json" \
// -H "Ibanity-Idempotency-Key: 94c5586e-e15e-4bae-a1fe-fdbefe1f11d3"  \
// -d grant_type=refresh_token \
// -d refresh_token=valid_refresh_token \
// -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/token');
$req->put_ContentType('application/x-www-form-urlencoded');
$req->AddParam('grant_type','refresh_token');

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

$req->AddParam('refresh_token',$jsonToken->stringOf('refresh_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');

$crypt = new CkCrypt2();
$idempotencyKey = $crypt->generateUuid();
print 'Ibanity-Idempotency-Key: ' . $idempotencyKey . "\n";
$req->AddHeader('Ibanity-Idempotency-Key',$idempotencyKey);

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

$sbResponseBody = new CkStringBuilder();
$resp->GetBodySb($sbResponseBody);
$jResp = new CkJsonObject();
$jResp->LoadSb($sbResponseBody);
$jResp->put_EmitCompact(false);

print 'Response Body:' . "\n";
print $jResp->emit() . "\n";

$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;
}

// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)

// Notice that we don't get a new refresh token.  The original refresh token is used each time we
// want to refresh.  However, we get a new access token.  This access token is to be used in Isabel API calls
// until we need to refresh again.
// {
//   "token_type": "Bearer",
//   "scope": "cloudconnect",
//   "expires_in": 1799,
//   "access_token": "access_token_1603365408"
// }

// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON

$token_type = $jResp->stringOf('token_type');
$scope = $jResp->stringOf('scope');
$expires_in = $jResp->IntOf('expires_in');
$access_token = $jResp->stringOf('access_token');

// Save this to a file so we can load in other examples to include the access token in the HTTP request.
$success = $jResp->WriteFile('qa_data/tokens/isabel_access_token.json');

?>