Sample code for 30+ languages & platforms
Classic ASP

Isabel Connect Create Access Token given Valid Refresh Token

See more Ibanity Examples

Create (refresh) an access token given a valid refresh token.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

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

set http = Server.CreateObject("Chilkat.Http")

' 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.)
set cert = Server.CreateObject("Chilkat.Cert")
success = cert.LoadPfxFile("qa_data/pfx/my_ibanity_certificate.pfx","my_pfx_password")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( cert.LastErrorText) & "</pre>"
    Response.End
End If

success = http.SetSslClientCert(cert)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
    Response.End
End If

set req = Server.CreateObject("Chilkat.HttpRequest")
req.HttpVerb = "POST"
req.Path = "/isabel-connect/oauth2/token"
req.ContentType = "application/x-www-form-urlencoded"
req.AddParam "grant_type","refresh_token"

' Load the previously obtained refresh token.
set jsonToken = Server.CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile("qa_data/tokens/isabel_refresh_token.json")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( "No existing access token.") & "</pre>"
    Response.End
End If

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"

set crypt = Server.CreateObject("Chilkat.Crypt2")
idempotencyKey = crypt.GenerateUuid()
Response.Write "<pre>" & Server.HTMLEncode( "Ibanity-Idempotency-Key: " & idempotencyKey) & "</pre>"
req.AddHeader "Ibanity-Idempotency-Key",idempotencyKey

set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpReq("https://api.ibanity.com/isabel-connect/oauth2/token",req,resp)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
    Response.End
End If

set sbResponseBody = Server.CreateObject("Chilkat.StringBuilder")
success = resp.GetBodySb(sbResponseBody)
set jResp = Server.CreateObject("Chilkat.JsonObject")
success = jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = 0

Response.Write "<pre>" & Server.HTMLEncode( "Response Body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( jResp.Emit()) & "</pre>"

respStatusCode = resp.StatusCode
Response.Write "<pre>" & Server.HTMLEncode( "Response Status Code = " & respStatusCode) & "</pre>"
If (respStatusCode >= 400) Then
    Response.Write "<pre>" & Server.HTMLEncode( "Response Header:") & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( resp.Header) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Failed.") & "</pre>"
    Response.End
End If

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

%>
</body>
</html>