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

SugarCRM Filtering Records

See more SugarCRM Examples

Export records and filter.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkRestW.h>
#include <CkJsonObjectW.h>
#include <CkStringBuilderW.h>

void ChilkatSample(void)
    {
    bool success = false;

    CkRestW rest;

    success = rest.Connect(L"your.site.domain",443,true,true);
    if (success != true) {
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    rest.AddHeader(L"Cache-Control",L"no-cache");
    rest.AddHeader(L"OAuth-Token",L"<access_token>");

    // The following code creates the JSON request body.
    // The JSON created by this code is shown below.
    CkJsonObjectW jsonReq;
    jsonReq.UpdateString(L"filter[0].$or[0].name.$starts",L"A");
    jsonReq.UpdateString(L"filter[0].$or[1].name.$starts",L"b");
    jsonReq.UpdateNumber(L"max_num",L"2");
    jsonReq.UpdateNumber(L"offset",L"0");
    jsonReq.UpdateString(L"fields",L"id");
    jsonReq.UpdateString(L"order_by",L"date_entered");
    jsonReq.UpdateBool(L"favorites",false);
    jsonReq.UpdateBool(L"my_items",false);

    // The JSON request body created by the above code:

    // {
    //   "filter": [
    //     {
    //       "$or": [
    //         {
    //           "name": {
    //             "$starts": "A"
    //           }
    //         },
    //         {
    //           "name": {
    //             "$starts": "b"
    //           }
    //         }
    //       ]
    //     }
    //   ],
    //   "max_num": 2,
    //   "offset": 0,
    //   "fields": "id",
    //   "order_by": "date_entered",
    //   "favorites": false,
    //   "my_items": false
    // }

    CkStringBuilderW sbReq;
    jsonReq.EmitSb(sbReq);

    rest.AddHeader(L"Content-Type",L"application/json");

    CkStringBuilderW sbJson;
    success = rest.FullRequestSb(L"POST",L"/rest/v10/Accounts/filter",sbReq,sbJson);
    if (success != true) {
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    if (rest.get_ResponseStatusCode() != 200) {
        wprintf(L"Received error response code: %d\n",rest.get_ResponseStatusCode());
        wprintf(L"Response body:\n");
        wprintf(L"%s\n",sbJson.getAsString());
        return;
    }

    CkJsonObjectW json;
    json.LoadSb(sbJson);

    // The following code parses the JSON response.
    // A sample JSON response is shown below the sample code.
    int next_offset;
    int i;
    int count_i;
    const wchar_t *id = 0;
    const wchar_t *date_modified = 0;
    const wchar_t *v_module = 0;

    next_offset = json.IntOf(L"next_offset");
    i = 0;
    count_i = json.SizeOfArray(L"records");
    while (i < count_i) {
        json.put_I(i);
        id = json.stringOf(L"records[i].id");
        date_modified = json.stringOf(L"records[i].date_modified");
        v_module = json.stringOf(L"records[i]._module");
        i = i + 1;
    }

    // A sample JSON response body that is parsed by the above code:

    // {
    //   "next_offset": 2,
    //   "records": [
    //     {
    //       "id": "f16760a4-3a52-f77d-1522-5703ca28925f",
    //       "date_modified": "2016-04-05T10:23:28-04:00",
    //       "_acl": {
    //         "fields": {}
    //       },
    //       "_module": "Accounts"
    //     },
    //     {
    //       "id": "ec409fbb-2b22-4f32-7fa1-5703caf78dc3",
    //       "date_modified": "2016-04-05T10:23:28-04:00",
    //       "_acl": {
    //         "fields": {}
    //       },
    //       "_module": "Accounts"
    //     }
    //   ]
    // }

    wprintf(L"Example Completed.\n");
    }