Sample code for 30+ languages & platforms
Unicode C++

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 Unicode C++ Downloads

Unicode C++
#include <CkHttpW.h>
#include <CkJsonObjectW.h>
#include <CkHttpResponseW.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkHttpW http;

    // The HTTP Basic authentication for this request is the
    // OAuth client id and secret you've already obtained.
    http.put_BasicAuth(true);
    http.put_Login(L"my_akeneo_client_id");
    http.put_Password(L"my_akeneo_secret");

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

    CkJsonObjectW json;
    json.UpdateString(L"grant_type",L"password");
    json.UpdateString(L"username",L"my_akeneo_username");
    json.UpdateString(L"password",L"my_akeneo_password");

    // POST this JSON (with the Basic Authentication header)
    const wchar_t *url = L"http://pim.my-akeneo-site.com/api/oauth/v1/token";
    CkHttpResponseW resp;
    success = http.HttpJson(L"POST",url,json,L"application/json",resp);
    if (success == false) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    wprintf(L"Response status code: %d\n",resp.get_StatusCode());
    wprintf(L"Response body: %s\n",resp.bodyStr());

    if (resp.get_StatusCode() == 200) {
        // Success.
        // Parse the response, which looks like this:

        // 		{
        // 		    "access_token": "MTE0NzNkNzI5YTk0ZTBlNmFlNTI5NmVkOWJhZjUxYWRkN2UzZWIwOWNkMTkwNzY5Mzk3NGViMDFmYzdlODJlMg",
        // 		    "expires_in": 3600,
        // 		    "token_type": "bearer",
        // 		    "scope": null,
        // 		    "refresh_token": "ZDkyMzA2NDhlZjQ2MGQyMDQ2MWRiMDBmOTdkZjQ5ODY5Mzc3MTEzMjVkNTkwZThmNWRlNWY0MzllYWMxZWQ5ZA"
        // 		}

        json.Load(resp.bodyStr());
        const wchar_t *access_token = json.stringOf(L"access_token");
        int expires_in = json.IntOf(L"expires_in");
        const wchar_t *token_type = json.stringOf(L"token_type");
        const wchar_t *scope = json.stringOf(L"scope");
        const wchar_t *refresh_token = json.stringOf(L"refresh_token");

        wprintf(L"Access Token: %s\n",access_token);
    }
    }