Sample code for 30+ languages & platforms
Visual FoxPro

PRODA Get OAuth2 Access Token using JWT

See more PRODA Examples

Demonstrates how to get an OAuth2 access token for the PRODA Australian Government Online Services using a JWT.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loPrivKey
LOCAL loJwt
LOCAL loJose
LOCAL loClaims
LOCAL lnCurDateTime
LOCAL lcJwtToken
LOCAL loHttp
LOCAL loReq
LOCAL loResp

lnSuccess = 0

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

* First create a JWT to be sent in the POST to https://vnd.proda.humanservices.gov.au/mga/sps/oauth/oauth20/token

loPrivKey = CreateObject('Chilkat.PrivateKey')

* Load an RSA private key from a PEM file.
* Chilkat provides alternative methods to load from other formats, or to load from a string or binary data.
lnSuccess = loPrivKey.LoadEncryptedPemFile("qa_data/pem/rsa_passwd.pem","passwd")
IF (lnSuccess = 0) THEN
    ? loPrivKey.LastErrorText
    RELEASE loPrivKey
    CANCEL
ENDIF

loJwt = CreateObject('Chilkat.Jwt')

* Build the JOSE header
loJose = CreateObject('Chilkat.JsonObject')
* Use RS256.  Pass the string "RS384" or "RS512" to use RSA with SHA-384 or SHA-512.
lnSuccess = loJose.AppendString("alg","RS256")
lnSuccess = loJose.AppendString("typ","JWT")
lnSuccess = loJose.AppendString("kid","test-device")

* Now build the JWT claims (also known as the payload)
loClaims = CreateObject('Chilkat.JsonObject')
lnSuccess = loClaims.AppendString("iss","9646844092")
lnSuccess = loClaims.AppendString("sub","test-device")
lnSuccess = loClaims.AppendString("aud","https://proda.humanservices.gov.au")

* Set the timestamp of when the JWT was created to now.
lnCurDateTime = loJwt.GenNumericDate(0)
lnSuccess = loClaims.AddIntAt(-1,"iat",lnCurDateTime)

* Set the timestamp defining an expiration time (end time) for the token
* to be now + 1 hour (3600 seconds)
lnSuccess = loClaims.AddIntAt(-1,"exp",lnCurDateTime + 3600)

* Produce the smallest possible JWT:
loJwt.AutoCompact = 1

* Create the JWT token.  This is where the RSA signature is created.
lcJwtToken = loJwt.CreateJwtPk(loJose.Emit(),loClaims.Emit(),loPrivKey)

* ---------------------------------------------------------------------
* Build and send the POST, which should look something like this:

* POST https://vnd.proda.humanservices.gov.au/mga/sps/oauth/oauth20/token HTTP/1.1
* Content-Type: application/x-www-form-urlencoded
* Content-Length: 666
* Host: vnd.proda.humanservices.gov.au
* 
* grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Ajwt-bearer&assertion=<jwt>&client_id=VendorClient03

loHttp = CreateObject('Chilkat.Http')

loReq = CreateObject('Chilkat.HttpRequest')
loReq.HttpVerb = "POST"
loReq.ContentType = "application/x-www-form-urlencoded"

* Add the request params.
loReq.AddParam("grant_type","urn:ietf:params:oauth:grant-type:jwt-bearer")
loReq.AddParam("assertion",lcJwtToken)
loReq.AddParam("client_id","VendorClient03")

loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpReq("https://vnd.proda.humanservices.gov.au/mga/sps/oauth/oauth20/token",loReq,loResp)
IF (lnSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loPrivKey
    RELEASE loJwt
    RELEASE loJose
    RELEASE loClaims
    RELEASE loHttp
    RELEASE loReq
    RELEASE loResp
    CANCEL
ENDIF

? "Response status code = " + STR(loResp.StatusCode)
? "Response body:"
? loResp.BodyStr

RELEASE loPrivKey
RELEASE loJwt
RELEASE loJose
RELEASE loClaims
RELEASE loHttp
RELEASE loReq
RELEASE loResp