Sample code for 30+ languages & platforms
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

Visual FoxPro
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