PHP Extension
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
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');
?>