Classic ASP
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
<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>