Sample code for 30+ languages & platforms
Delphi ActiveX

Quickbooks Query an Invoice

See more QuickBooks Examples

Demonstrates how to query for invoices matching a SELECT statement via the Quickbooks REST API.

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;
jsonToken: TChilkatJsonObject;
rest: TChilkatRest;
bTls: Integer;
port: Integer;
bAutoReconnect: Integer;
sbAuth: TChilkatStringBuilder;
sbResponseBody: TChilkatStringBuilder;
respStatusCode: Integer;
json: TChilkatJsonObject;
DocNumber: WideString;
SyncToken: WideString;
domain: WideString;
Balance: WideString;
BillAddrCity: WideString;
BillAddrLine1: WideString;
BillAddrPostalCode: WideString;
BillAddrLat: WideString;
BillAddrLong: WideString;
BillAddrCountrySubDivisionCode: WideString;
BillAddrId: WideString;
TxnDate: WideString;
TotalAmt: WideString;
CustomerRefName: WideString;
CustomerRefValue: WideString;
ShipAddrCity: WideString;
ShipAddrLine1: WideString;
ShipAddrPostalCode: WideString;
ShipAddrLat: WideString;
ShipAddrLong: WideString;
ShipAddrCountrySubDivisionCode: WideString;
ShipAddrId: WideString;
DueDate: WideString;
PrintStatus: WideString;
Deposit: Integer;
sparse: Integer;
EmailStatus: WideString;
ApplyTaxAfterDiscount: Integer;
Id: WideString;
TxnTaxDetailTotalTax: Integer;
MetaDataCreateTime: WideString;
MetaDataLastUpdatedTime: WideString;
j: Integer;
count_j: Integer;
LineNum: Integer;
Amount: WideString;
SalesItemLineDetailTaxCodeRefValue: WideString;
SalesItemLineDetailItemRefName: WideString;
SalesItemLineDetailItemRefValue: WideString;
DetailType: WideString;
DefinitionId: WideString;
invType: WideString;
Name: WideString;
QueryResponseStartPosition: Integer;
QueryResponseTotalCount: Integer;
QueryResponseMaxResults: Integer;
time: WideString;
i: Integer;
count_i: Integer;

begin
success := 0;

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

// First get our previously obtained OAuth2 access token.
jsonToken := TChilkatJsonObject.Create(Self);
success := jsonToken.LoadFile('qa_data/tokens/qb-access-token.json');

rest := TChilkatRest.Create(Self);

bTls := 1;
port := 443;
bAutoReconnect := 1;
success := rest.Connect('sandbox-quickbooks.api.intuit.com',port,bTls,bAutoReconnect);

sbAuth := TChilkatStringBuilder.Create(Self);
sbAuth.Append('Bearer ');
sbAuth.Append(jsonToken.StringOf('access_token'));
rest.Authorization := sbAuth.GetAsString();

// --------------------------------------------------------------------------
// Note: The above REST connection and setup of the AWS credentials
// can be done once.  After connecting, any number of REST calls can be made.
// The "auto reconnect" property passed to rest.Connect indicates that if
// the connection is lost, a REST method call will automatically reconnect
// if needed.
// --------------------------------------------------------------------------

// This is a GET request, so there should be no Content-Type
// This line of code is just to make sure..
rest.RemoveHeader('Content-Type');

rest.AddHeader('Accept','application/json');
rest.AllowHeaderFolding := 0;

// Add a SELECT statement 
rest.AddQueryParam('query','select * from Invoice where id = ''239''');

sbResponseBody := TChilkatStringBuilder.Create(Self);
success := rest.FullRequestNoBodySb('GET','/v3/company/<realmID>/invoice',sbResponseBody.ControlInterface);
if (success <> 1) then
  begin
    Memo1.Lines.Add(rest.LastErrorText);
    Exit;
  end;

respStatusCode := rest.ResponseStatusCode;
if (respStatusCode >= 400) then
  begin
    Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
    Memo1.Lines.Add('Response Header:');
    Memo1.Lines.Add(rest.ResponseHeader);
    Memo1.Lines.Add('Response Body:');
    Memo1.Lines.Add(sbResponseBody.GetAsString());
    Exit;
  end;

// Success is indicated by a 200 response status.
Memo1.Lines.Add('response status code = ' + IntToStr(respStatusCode));

json := TChilkatJsonObject.Create(Self);
json.LoadSb(sbResponseBody.ControlInterface);
json.EmitCompact := 0;
Memo1.Lines.Add(json.Emit());

// Sample output:
// Use the this online tool to generate parsing code from sample JSON: 
// Generate Parsing Code from JSON

// {
//   "QueryResponse": {
//     "startPosition": 1, 
//     "totalCount": 1, 
//     "maxResults": 1, 
//     "Invoice": [
//       {
//         "DocNumber": "1070", 
//         "SyncToken": "0", 
//         "domain": "QBO", 
//         "Balance": 150.0, 
//         "BillAddr": {
//           "City": "Bayshore", 
//           "Line1": "4581 Finch St.", 
//           "PostalCode": "94326", 
//           "Lat": "INVALID", 
//           "Long": "INVALID", 
//           "CountrySubDivisionCode": "CA", 
//           "Id": "2"
//         }, 
//         "TxnDate": "2015-07-24", 
//         "TotalAmt": 150.0, 
//         "CustomerRef": {
//           "name": "Amy's Bird Sanctuary", 
//           "value": "1"
//         }, 
//         "ShipAddr": {
//           "City": "Bayshore", 
//           "Line1": "4581 Finch St.", 
//           "PostalCode": "94326", 
//           "Lat": "INVALID", 
//           "Long": "INVALID", 
//           "CountrySubDivisionCode": "CA", 
//           "Id": "109"
//         }, 
//         "LinkedTxn": [], 
//         "DueDate": "2015-08-23", 
//         "PrintStatus": "NeedToPrint", 
//         "Deposit": 0, 
//         "sparse": false, 
//         "EmailStatus": "NotSet", 
//         "Line": [
//           {
//             "LineNum": 1, 
//             "Amount": 150.0, 
//             "SalesItemLineDetail": {
//               "TaxCodeRef": {
//                 "value": "NON"
//               }, 
//               "ItemRef": {
//                 "name": "Services", 
//                 "value": "1"
//               }
//             }, 
//             "Id": "1", 
//             "DetailType": "SalesItemLineDetail"
//           }, 
//           {
//             "DetailType": "SubTotalLineDetail", 
//             "Amount": 150.0, 
//             "SubTotalLineDetail": {}
//           }
//         ], 
//         "ApplyTaxAfterDiscount": false, 
//         "CustomField": [
//           {
//             "DefinitionId": "1", 
//             "Type": "StringType", 
//             "Name": "Crew #"
//           }
//         ], 
//         "Id": "239", 
//         "TxnTaxDetail": {
//           "TotalTax": 0
//         }, 
//         "MetaData": {
//           "CreateTime": "2015-07-24T10:35:08-07:00", 
//           "LastUpdatedTime": "2015-07-24T10:35:08-07:00"
//         }
//       }
//     ]
//   }, 
//   "time": "2015-07-24T10:38:50.01-07:00"
// }

QueryResponseStartPosition := json.IntOf('QueryResponse.startPosition');
QueryResponseTotalCount := json.IntOf('QueryResponse.totalCount');
QueryResponseMaxResults := json.IntOf('QueryResponse.maxResults');
time := json.StringOf('time');
i := 0;
count_i := json.SizeOfArray('QueryResponse.Invoice');
while i < count_i do
  begin
    json.I := i;
    DocNumber := json.StringOf('QueryResponse.Invoice[i].DocNumber');
    SyncToken := json.StringOf('QueryResponse.Invoice[i].SyncToken');
    domain := json.StringOf('QueryResponse.Invoice[i].domain');
    Balance := json.StringOf('QueryResponse.Invoice[i].Balance');
    BillAddrCity := json.StringOf('QueryResponse.Invoice[i].BillAddr.City');
    BillAddrLine1 := json.StringOf('QueryResponse.Invoice[i].BillAddr.Line1');
    BillAddrPostalCode := json.StringOf('QueryResponse.Invoice[i].BillAddr.PostalCode');
    BillAddrLat := json.StringOf('QueryResponse.Invoice[i].BillAddr.Lat');
    BillAddrLong := json.StringOf('QueryResponse.Invoice[i].BillAddr.Long');
    BillAddrCountrySubDivisionCode := json.StringOf('QueryResponse.Invoice[i].BillAddr.CountrySubDivisionCode');
    BillAddrId := json.StringOf('QueryResponse.Invoice[i].BillAddr.Id');
    TxnDate := json.StringOf('QueryResponse.Invoice[i].TxnDate');
    TotalAmt := json.StringOf('QueryResponse.Invoice[i].TotalAmt');
    CustomerRefName := json.StringOf('QueryResponse.Invoice[i].CustomerRef.name');
    CustomerRefValue := json.StringOf('QueryResponse.Invoice[i].CustomerRef.value');
    ShipAddrCity := json.StringOf('QueryResponse.Invoice[i].ShipAddr.City');
    ShipAddrLine1 := json.StringOf('QueryResponse.Invoice[i].ShipAddr.Line1');
    ShipAddrPostalCode := json.StringOf('QueryResponse.Invoice[i].ShipAddr.PostalCode');
    ShipAddrLat := json.StringOf('QueryResponse.Invoice[i].ShipAddr.Lat');
    ShipAddrLong := json.StringOf('QueryResponse.Invoice[i].ShipAddr.Long');
    ShipAddrCountrySubDivisionCode := json.StringOf('QueryResponse.Invoice[i].ShipAddr.CountrySubDivisionCode');
    ShipAddrId := json.StringOf('QueryResponse.Invoice[i].ShipAddr.Id');
    DueDate := json.StringOf('QueryResponse.Invoice[i].DueDate');
    PrintStatus := json.StringOf('QueryResponse.Invoice[i].PrintStatus');
    Deposit := json.IntOf('QueryResponse.Invoice[i].Deposit');
    sparse := json.BoolOf('QueryResponse.Invoice[i].sparse');
    EmailStatus := json.StringOf('QueryResponse.Invoice[i].EmailStatus');
    ApplyTaxAfterDiscount := json.BoolOf('QueryResponse.Invoice[i].ApplyTaxAfterDiscount');
    Id := json.StringOf('QueryResponse.Invoice[i].Id');
    TxnTaxDetailTotalTax := json.IntOf('QueryResponse.Invoice[i].TxnTaxDetail.TotalTax');
    MetaDataCreateTime := json.StringOf('QueryResponse.Invoice[i].MetaData.CreateTime');
    MetaDataLastUpdatedTime := json.StringOf('QueryResponse.Invoice[i].MetaData.LastUpdatedTime');
    j := 0;
    count_j := json.SizeOfArray('QueryResponse.Invoice[i].LinkedTxn');
    while j < count_j do
      begin
        json.J := j;
        j := j + 1;
      end;

    j := 0;
    count_j := json.SizeOfArray('QueryResponse.Invoice[i].Line');
    while j < count_j do
      begin
        json.J := j;
        LineNum := json.IntOf('QueryResponse.Invoice[i].Line[j].LineNum');
        Amount := json.StringOf('QueryResponse.Invoice[i].Line[j].Amount');
        SalesItemLineDetailTaxCodeRefValue := json.StringOf('QueryResponse.Invoice[i].Line[j].SalesItemLineDetail.TaxCodeRef.value');
        SalesItemLineDetailItemRefName := json.StringOf('QueryResponse.Invoice[i].Line[j].SalesItemLineDetail.ItemRef.name');
        SalesItemLineDetailItemRefValue := json.StringOf('QueryResponse.Invoice[i].Line[j].SalesItemLineDetail.ItemRef.value');
        Id := json.StringOf('QueryResponse.Invoice[i].Line[j].Id');
        DetailType := json.StringOf('QueryResponse.Invoice[i].Line[j].DetailType');
        j := j + 1;
      end;

    j := 0;
    count_j := json.SizeOfArray('QueryResponse.Invoice[i].CustomField');
    while j < count_j do
      begin
        json.J := j;
        DefinitionId := json.StringOf('QueryResponse.Invoice[i].CustomField[j].DefinitionId');
        invType := json.StringOf('QueryResponse.Invoice[i].CustomField[j].Type');
        Name := json.StringOf('QueryResponse.Invoice[i].CustomField[j].Name');
        j := j + 1;
      end;

    i := i + 1;
  end;
end;