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

Bitfinex v2 REST Tickers

See more Bitfinex v2 REST Examples

The tickers endpoint provides a high level overview of the state of the market. It shows the current best bid and ask, the last traded price, as well as information on the daily volume and price movement over the last day. The endpoint can retrieve multiple tickers with a single query.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkHttpW.h>
#include <CkStringBuilderW.h>
#include <CkJsonArrayW.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkHttpW http;

    // Implements the following CURL command:

    // curl https://api-pub.bitfinex.com/v2/tickers?symbols=tBTCUSD,tLTCUSD,fUSD

    // Use the following online tool to generate HTTP code from a CURL command
    // Convert a cURL Command to HTTP Source Code

    CkStringBuilderW sbResponseBody;
    success = http.QuickGetSb(L"https://api-pub.bitfinex.com/v2/tickers?symbols=tBTCUSD,tLTCUSD,fUSD",sbResponseBody);
    if (success == false) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    CkJsonArrayW jarrResp;
    jarrResp.LoadSb(sbResponseBody);
    jarrResp.put_EmitCompact(false);

    wprintf(L"Response Body:\n");
    wprintf(L"%s\n",jarrResp.emit());

    int respStatusCode = http.get_LastStatus();
    wprintf(L"Response Status Code = %d\n",respStatusCode);
    if (respStatusCode >= 400) {
        wprintf(L"Response Header:\n");
        wprintf(L"%s\n",http.lastHeader());
        wprintf(L"Failed.\n");
        return;
    }

    // Sample JSON response:
    // (Sample code for parsing the JSON response is shown below)

    // [
    //   [
    //     "tBTCUSD",
    //     9318.6,
    //     21.53815472,
    //     9318.7,
    //     5.30463105,
    //     223.5,
    //     0.0246,
    //     9318.7,
    //     4125.21689058,
    //     9370.998872,
    //     9075.80199233
    //   ],
    //   [
    //     "tLTCUSD",
    //     44.008,
    //     1807.8617840300003,
    //     44.019,
    //     2394.7625575100005,
    //     2.359,
    //     0.0566,
    //     44.019,
    //     27051.34115724,
    //     44.16,
    //     41.559
    //   ],
    //   [
    //     "fUSD",
    //     0.00022955068493150685,
    //     0.000199,
    //     30,
    //     871597.2359141599,
    //     0.0001962,
    //     2,
    //     67926.11558407999,
    //     -0.00001146,
    //     -0.0523,
    //     0.00020757,
    //     167542924.22214913,
    //     0.00024,
    //     0.00000299,
    //     null,
    //     null,
    //     82649109.90968154
    //   ]
    // ]

    // Sample code for parsing the JSON response...
    // Use the following online tool to generate parsing code from sample JSON:
    // Generate Parsing Code from JSON

    // Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
    // See this example explaining how this memory should be used: const char * functions.

    CkJsonArrayW jarr_1;
    int j;
    int count_j;
    const wchar_t *strVal = 0;

    int i = 0;
    int count_i = jarrResp.get_Size();
    while (i < count_i) {
        jarrResp.ArrayAt2(i,jarr_1);
        j = 0;
        count_j = jarr_1.get_Size();
        while (j < count_j) {
            strVal = jarr_1.stringAt(j);
            j = j + 1;
        }

        i = i + 1;
    }
    }