Sample code for 30+ languages & platforms
AutoIt

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 AutoIt Downloads

AutoIt
Local $bSuccess = False

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

$oHttp = ObjCreate("Chilkat.Http")

; The HTTP Basic authentication for this request is the
; OAuth client id and secret you've already obtained.
$oHttp.BasicAuth = True
$oHttp.Login = "my_akeneo_client_id"
$oHttp.Password = "my_akeneo_secret"

; Build this JSON:
; {
;   "grant_type": "password",
;   "username": "yourusername",
;   "password": "yourpassword"
; }

$oJson = ObjCreate("Chilkat.JsonObject")
$oJson.UpdateString("grant_type","password")
$oJson.UpdateString("username","my_akeneo_username")
$oJson.UpdateString("password","my_akeneo_password")

; POST this JSON (with the Basic Authentication header)
Local $sUrl = "http://pim.my-akeneo-site.com/api/oauth/v1/token"
$oResp = ObjCreate("Chilkat.HttpResponse")
$bSuccess = $oHttp.HttpJson("POST",$sUrl,$oJson,"application/json",$oResp)
If ($bSuccess = False) Then
    ConsoleWrite($oHttp.LastErrorText & @CRLF)
    Exit
EndIf

ConsoleWrite("Response status code: " & $oResp.StatusCode & @CRLF)
ConsoleWrite("Response body: " & $oResp.BodyStr & @CRLF)

If ($oResp.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"
    ; 		}

    $oJson.Load($oResp.BodyStr)
Local $sAccess_token = $oJson.StringOf("access_token")
Local $iExpires_in = $oJson.IntOf("expires_in")
Local $sToken_type = $oJson.StringOf("token_type")
Local $scope = $oJson.StringOf("scope")
Local $sRefresh_token = $oJson.StringOf("refresh_token")

    ConsoleWrite("Access Token: " & $sAccess_token & @CRLF)
EndIf