Visual FoxPro
Visual FoxPro
Refresh a Dynamics CRM OAuth2 Access Token
See more OAuth2 Examples
Demonstrates how to refresh an expiring Dynamics CRM access token using the refresh token. endpoint.(If a REST API call fails with a 401 unauthorized error, an application can auto-recover by refreshing the access token, and then re-send the request using the new token.)
Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loJson
LOCAL loDtExpire
LOCAL loReq
LOCAL loHttp
LOCAL loResp
LOCAL loFac
lnSuccess = 0
* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
* We previously obtained an access token and saved the JSON to a file using this example:
* Get Dynamics CRM OAuth2 Access Token
* This example will examine the JSON and expiration date, and if near expiration will
* refresh the access token.
loJson = CreateObject('Chilkat.JsonObject')
lnSuccess = loJson.LoadFile("qa_data/tokens/dynamicsCrm.json")
IF (lnSuccess <> 1) THEN
RELEASE loJson
CANCEL
ENDIF
* The contents of the JSON look like this:
* {
* "token_type": "Bearer",
* "scope": "user_impersonation",
* "expires_in": "3599",
* "ext_expires_in": "0",
* "expires_on": "1524783438",
* "not_before": "1524779538",
* "resource": "https://mydomain.api.crm.dynamics.com",
* "access_token": "...",
* "refresh_token": "...",
* "id_token": "..."
* }
* The "expires_on" value is a Unix time.
loDtExpire = CreateObject('Chilkat.CkDateTime')
loDtExpire.SetFromUnixTime(0,loJson.IntOf("expires_on"))
* If this date/time expires within 10 minutes of the current system time, refresh the token.
* OK, we need to refresh the access token by sending a POST...
*
loReq = CreateObject('Chilkat.HttpRequest')
loReq.AddParam("grant_type","refresh_token")
loReq.AddParam("redirect_uri","http://localhost:3017/")
loReq.AddParam("client_id","DYNAMICS-CRM-CLIENT-ID")
loReq.AddParam("client_secret","DYNAMICS-CRM-SECRET-KEY")
loReq.AddParam("refresh_token",loJson.StringOf("refresh_token"))
loReq.AddParam("resource","https://mydynamicsdomain.api.crm.dynamics.com")
loHttp = CreateObject('Chilkat.Http')
loReq.HttpVerb = "POST"
loReq.ContentType = "application/x-www-form-urlencoded"
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpReq("https://login.microsoftonline.com/DYNAMICS-ENDPOINT-GUID/oauth2/token",loReq,loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loJson
RELEASE loDtExpire
RELEASE loReq
RELEASE loHttp
RELEASE loResp
CANCEL
ENDIF
* Load the JSON response.
loJson.Load(loResp.BodyStr)
loJson.EmitCompact = 0
* Show the JSON response.
? loJson.Emit()
? "Response status code: " + STR(loResp.StatusCode)
* If the response status code is not 200, then it's an error.
IF (loResp.StatusCode <> 200) THEN
RELEASE loJson
RELEASE loDtExpire
RELEASE loReq
RELEASE loHttp
RELEASE loResp
CANCEL
ENDIF
* If an "expires_on" member does not exist, then add the JSON member by
* getting the current system date/time and adding the "expires_in" seconds.
* This way we'll know when the token expires.
IF (loJson.HasMember("expires_on") <> 1) THEN
loDtExpire.SetFromCurrentSystemTime()
loDtExpire.AddSeconds(loJson.IntOf("expires_in"))
loJson.AppendString("expires_on",loDtExpire.GetAsUnixTimeStr(0))
ENDIF
* Save the refreshed access token JSON to a file for future requests.
loFac = CreateObject('Chilkat.FileAccess')
loFac.WriteEntireTextFile("qa_data/tokens/dynamicsCrm.json",loJson.Emit(),"utf-8",0)
RELEASE loJson
RELEASE loDtExpire
RELEASE loReq
RELEASE loHttp
RELEASE loResp
RELEASE loFac