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 <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkHttpW http;
    HCkJsonObjectW json;
    const wchar_t *url;
    HCkHttpResponseW resp;
    const wchar_t *access_token;
    int expires_in;
    const wchar_t *token_type;
    const wchar_t *scope;
    const wchar_t *refresh_token;

    success = FALSE;

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

    http = CkHttpW_Create();

    // The HTTP Basic authentication for this request is the
    // OAuth client id and secret you've already obtained.
    CkHttpW_putBasicAuth(http,TRUE);
    CkHttpW_putLogin(http,L"my_akeneo_client_id");
    CkHttpW_putPassword(http,L"my_akeneo_secret");

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

    json = CkJsonObjectW_Create();
    CkJsonObjectW_UpdateString(json,L"grant_type",L"password");
    CkJsonObjectW_UpdateString(json,L"username",L"my_akeneo_username");
    CkJsonObjectW_UpdateString(json,L"password",L"my_akeneo_password");

    // POST this JSON (with the Basic Authentication header)
    url = L"http://pim.my-akeneo-site.com/api/oauth/v1/token";
    resp = CkHttpResponseW_Create();
    success = CkHttpW_HttpJson(http,L"POST",url,json,L"application/json",resp);
    if (success == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(json);
        CkHttpResponseW_Dispose(resp);
        return;
    }

    wprintf(L"Response status code: %d\n",CkHttpResponseW_getStatusCode(resp));
    wprintf(L"Response body: %s\n",CkHttpResponseW_bodyStr(resp));

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

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

        CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp));
        access_token = CkJsonObjectW_stringOf(json,L"access_token");
        expires_in = CkJsonObjectW_IntOf(json,L"expires_in");
        token_type = CkJsonObjectW_stringOf(json,L"token_type");
        scope = CkJsonObjectW_stringOf(json,L"scope");
        refresh_token = CkJsonObjectW_stringOf(json,L"refresh_token");

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



    CkHttpW_Dispose(http);
    CkJsonObjectW_Dispose(json);
    CkHttpResponseW_Dispose(resp);

    }