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