Sample code for 30+ languages & platforms
Delphi ActiveX

SugarCRM Filtering Records

See more SugarCRM Examples

Export records and filter.

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
rest: TChilkatRest;
jsonReq: TChilkatJsonObject;
sbReq: TChilkatStringBuilder;
sbJson: TChilkatStringBuilder;
json: TChilkatJsonObject;
next_offset: Integer;
i: Integer;
count_i: Integer;
id: WideString;
date_modified: WideString;
v_module: WideString;

begin
success := 0;

rest := TChilkatRest.Create(Self);

success := rest.Connect('your.site.domain',443,1,1);
if (success <> 1) then
  begin
    Memo1.Lines.Add(rest.LastErrorText);
    Exit;
  end;

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

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

// 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
// }

sbReq := TChilkatStringBuilder.Create(Self);
jsonReq.EmitSb(sbReq.ControlInterface);

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

sbJson := TChilkatStringBuilder.Create(Self);
success := rest.FullRequestSb('POST','/rest/v10/Accounts/filter',sbReq.ControlInterface,sbJson.ControlInterface);
if (success <> 1) then
  begin
    Memo1.Lines.Add(rest.LastErrorText);
    Exit;
  end;

if (rest.ResponseStatusCode <> 200) then
  begin
    Memo1.Lines.Add('Received error response code: ' + IntToStr(rest.ResponseStatusCode));
    Memo1.Lines.Add('Response body:');
    Memo1.Lines.Add(sbJson.GetAsString());
    Exit;
  end;

json := TChilkatJsonObject.Create(Self);
json.LoadSb(sbJson.ControlInterface);

// The following code parses the JSON response.
// A sample JSON response is shown below the sample code.

next_offset := json.IntOf('next_offset');
i := 0;
count_i := json.SizeOfArray('records');
while i < count_i do
  begin
    json.I := i;
    id := json.StringOf('records[i].id');
    date_modified := json.StringOf('records[i].date_modified');
    v_module := json.StringOf('records[i]._module');
    i := i + 1;
  end;

// 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"
//     }
//   ]
// }

Memo1.Lines.Add('Example Completed.');
end;