Unicode C
Unicode C
ABN AMRO OAuth2 Client Credentials Authentication
See more ABN AMRO Examples
Demonstrates how to obtain an access token for an ABN AMRO online API using OAuth2 with the Client Credentials flow.Chilkat Unicode C Downloads
#include <C_CkCertW.h>
#include <C_CkBinDataW.h>
#include <C_CkPrivateKeyW.h>
#include <C_CkHttpW.h>
#include <C_CkHttpRequestW.h>
#include <C_CkHttpResponseW.h>
#include <C_CkJsonObjectW.h>
void ChilkatSample(void)
{
BOOL success;
HCkCertW cert;
HCkBinDataW bdKey;
HCkPrivateKeyW privKey;
HCkHttpW http;
HCkHttpRequestW req;
HCkHttpResponseW resp;
HCkJsonObjectW json;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// This example sends the following CURL request:
// curl -X POST -k https://auth-sandbox.connect.abnamro.com:8443/as/token.oauth2 \
// -v \
// --cert TPPCertificate.crt \
// --key TPPprivateKey.key \
// -H 'Cache-Control: no-cache' \
// -H 'Content-Type: application/x-www-form-urlencoded' \
// -d 'grant_type=client_credentials&client_id=TPP_test&scope=psd2:payment:sepa:write psd2:payment:sepa:read'
cert = CkCertW_Create();
success = CkCertW_LoadFromFile(cert,L"qa_data/certs/TPPCertificate.cer");
if (success == FALSE) {
wprintf(L"%s\n",CkCertW_lastErrorText(cert));
CkCertW_Dispose(cert);
return;
}
bdKey = CkBinDataW_Create();
success = CkBinDataW_LoadFile(bdKey,L"qa_data/certs/TPPprivateKey.key");
privKey = CkPrivateKeyW_Create();
success = CkPrivateKeyW_LoadAnyFormat(privKey,bdKey,L"passwordIfNeeded");
if (success == FALSE) {
wprintf(L"%s\n",CkPrivateKeyW_lastErrorText(privKey));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
return;
}
success = CkCertW_SetPrivateKey(cert,privKey);
if (success == FALSE) {
wprintf(L"%s\n",CkCertW_lastErrorText(cert));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
return;
}
http = CkHttpW_Create();
success = CkHttpW_SetSslClientCert(http,cert);
if (success == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
CkHttpW_Dispose(http);
return;
}
req = CkHttpRequestW_Create();
CkHttpRequestW_AddParam(req,L"grant_type",L"client_credentials");
CkHttpRequestW_AddParam(req,L"client_id",L"TPP_test");
CkHttpRequestW_AddParam(req,L"scope",L"psd2:payment:sepa:write psd2:payment:sepa:read");
CkHttpRequestW_putHttpVerb(req,L"POST");
CkHttpRequestW_putContentType(req,L"application/x-www-form-urlencoded");
resp = CkHttpResponseW_Create();
success = CkHttpW_HttpReq(http,L"https://auth-sandbox.connect.abnamro.com:8443/as/token.oauth2",req,resp);
if (success == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
CkHttpW_Dispose(http);
CkHttpRequestW_Dispose(req);
CkHttpResponseW_Dispose(resp);
return;
}
if (CkHttpResponseW_getStatusCode(resp) != 200) {
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
CkHttpW_Dispose(http);
CkHttpRequestW_Dispose(req);
CkHttpResponseW_Dispose(resp);
return;
}
// Get the JSON result:
// {"access_token":"TIhycwl8rfrZPkXGw15mwldASAAK","token_type":"Bearer","expires_in":7200}
json = CkJsonObjectW_Create();
CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp));
wprintf(L"access_token: %s\n",CkJsonObjectW_stringOf(json,L"access_token"));
wprintf(L"token_type: %s\n",CkJsonObjectW_stringOf(json,L"token_type"));
wprintf(L"expires_in: %s\n",CkJsonObjectW_stringOf(json,L"expires_in"));
CkCertW_Dispose(cert);
CkBinDataW_Dispose(bdKey);
CkPrivateKeyW_Dispose(privKey);
CkHttpW_Dispose(http);
CkHttpRequestW_Dispose(req);
CkHttpResponseW_Dispose(resp);
CkJsonObjectW_Dispose(json);
}