Visual FoxPro
Visual FoxPro
Get Akeneo Token given Client ID and Secret
See more HTTP Misc Examples
Assumes you're starting with a client ID and secret obtained from your OAuth1 provider, such as OneLogin. Demonstrates how to get an akeneo token using your client id/secret in combination with your akeneo login/password.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL lcUrl
LOCAL loResp
LOCAL lcAccess_token
LOCAL lnExpires_in
LOCAL lcToken_type
LOCAL lcScope
LOCAL lcRefresh_token
lnSuccess = 0
* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = CreateObject('Chilkat.Http')
* The HTTP Basic authentication for this request is the
* OAuth client id and secret you've already obtained.
loHttp.BasicAuth = 1
loHttp.Login = "my_akeneo_client_id"
loHttp.Password = "my_akeneo_secret"
* Build this JSON:
* {
* "grant_type": "password",
* "username": "yourusername",
* "password": "yourpassword"
* }
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("grant_type","password")
loJson.UpdateString("username","my_akeneo_username")
loJson.UpdateString("password","my_akeneo_password")
* POST this JSON (with the Basic Authentication header)
lcUrl = "http://pim.my-akeneo-site.com/api/oauth/v1/token"
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST",lcUrl,loJson,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJson
RELEASE loResp
CANCEL
ENDIF
? "Response status code: " + STR(loResp.StatusCode)
? "Response body: " + loResp.BodyStr
IF (loResp.StatusCode = 200) THEN
* Success.
* Parse the response, which looks like this:
* {
* "access_token": "MTE0NzNkNzI5YTk0ZTBlNmFlNTI5NmVkOWJhZjUxYWRkN2UzZWIwOWNkMTkwNzY5Mzk3NGViMDFmYzdlODJlMg",
* "expires_in": 3600,
* "token_type": "bearer",
* "scope": null,
* "refresh_token": "ZDkyMzA2NDhlZjQ2MGQyMDQ2MWRiMDBmOTdkZjQ5ODY5Mzc3MTEzMjVkNTkwZThmNWRlNWY0MzllYWMxZWQ5ZA"
* }
loJson.Load(loResp.BodyStr)
lcAccess_token = loJson.StringOf("access_token")
lnExpires_in = loJson.IntOf("expires_in")
lcToken_type = loJson.StringOf("token_type")
lcScope = loJson.StringOf("scope")
lcRefresh_token = loJson.StringOf("refresh_token")
? "Access Token: " + lcAccess_token
ENDIF
RELEASE loHttp
RELEASE loJson
RELEASE loResp