Delphi ActiveX
Delphi ActiveX
Quickbooks Update an Invoice
See more QuickBooks Examples
Demonstrates how to update an invoice using the Quickbooks REST API.Chilkat Delphi ActiveX Downloads
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;
jsonReq: TChilkatJsonObject;
sbRequestBody: TChilkatStringBuilder;
sbResponseBody: TChilkatStringBuilder;
respStatusCode: Integer;
jsonResponse: TChilkatJsonObject;
LineNum: Integer;
Amount: WideString;
SalesItemLineDetailTaxCodeRefValue: WideString;
SalesItemLineDetailItemRefName: WideString;
SalesItemLineDetailItemRefValue: WideString;
Id: WideString;
DetailType: WideString;
DefinitionId: WideString;
invType: WideString;
Name: WideString;
InvoiceTxnDate: WideString;
InvoiceDomain: WideString;
InvoicePrintStatus: WideString;
InvoiceTotalAmt: WideString;
InvoiceDueDate: WideString;
InvoiceApplyTaxAfterDiscount: Integer;
InvoiceDocNumber: WideString;
InvoiceSparse: Integer;
InvoiceCustomerMemoValue: WideString;
InvoiceDeposit: Integer;
InvoiceBalance: WideString;
InvoiceCustomerRefName: WideString;
InvoiceCustomerRefValue: WideString;
InvoiceTxnTaxDetailTotalTax: Integer;
InvoiceSyncToken: WideString;
InvoiceShipAddrCountrySubDivisionCode: WideString;
InvoiceShipAddrCity: WideString;
InvoiceShipAddrPostalCode: WideString;
InvoiceShipAddrId: WideString;
InvoiceShipAddrLine1: WideString;
InvoiceEmailStatus: WideString;
InvoiceBillAddrCountrySubDivisionCode: WideString;
InvoiceBillAddrCity: WideString;
InvoiceBillAddrPostalCode: WideString;
InvoiceBillAddrId: WideString;
InvoiceBillAddrLine1: WideString;
InvoiceMetaDataCreateTime: WideString;
InvoiceMetaDataLastUpdatedTime: WideString;
InvoiceId: WideString;
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);
// Connect to the REST server.
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 code to setup the initial REST connection
// can be done once. After connecting, any number of REST calls can be made.
// If the connection is lost, the next REST method call will automatically
// reconnect if needed.
// --------------------------------------------------------------------------
// Create the following JSON:
// {
// "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"
// },
// "CustomerMemo": {
// "value": "Added customer memo."
// },
// "ShipAddr": {
// "City": "Bayshore",
// "Line1": "4581 Finch St.",
// "PostalCode": "94326",
// "Lat": "INVALID",
// "Long": "INVALID",
// "CountrySubDivisionCode": "CA",
// "Id": "109"
// },
// "LinkedTxn": [
// ],
// "DueDate": "2015-08-23",
// "PrintStatus": "NeedToPrint",
// "EmailStatus": "NotSet",
// "sparse": false,
// "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"
// }
// }
//
// Use the this online tool to generate the code from sample JSON:
// Generate Code to Create JSON
jsonReq := TChilkatJsonObject.Create(Self);
jsonReq.UpdateString('DocNumber','1070');
jsonReq.UpdateString('SyncToken','0');
jsonReq.UpdateString('domain','QBO');
jsonReq.UpdateNumber('Balance','150.0');
jsonReq.UpdateString('BillAddr.City','Bayshore');
jsonReq.UpdateString('BillAddr.Line1','4581 Finch St.');
jsonReq.UpdateString('BillAddr.PostalCode','94326');
jsonReq.UpdateString('BillAddr.Lat','INVALID');
jsonReq.UpdateString('BillAddr.Long','INVALID');
jsonReq.UpdateString('BillAddr.CountrySubDivisionCode','CA');
jsonReq.UpdateString('BillAddr.Id','2');
jsonReq.UpdateString('TxnDate','2015-07-24');
jsonReq.UpdateNumber('TotalAmt','150.0');
jsonReq.UpdateString('CustomerRef.name','Amy''s Bird Sanctuary');
jsonReq.UpdateString('CustomerRef.value','1');
jsonReq.UpdateString('CustomerMemo.value','Added customer memo.');
jsonReq.UpdateString('ShipAddr.City','Bayshore');
jsonReq.UpdateString('ShipAddr.Line1','4581 Finch St.');
jsonReq.UpdateString('ShipAddr.PostalCode','94326');
jsonReq.UpdateString('ShipAddr.Lat','INVALID');
jsonReq.UpdateString('ShipAddr.Long','INVALID');
jsonReq.UpdateString('ShipAddr.CountrySubDivisionCode','CA');
jsonReq.UpdateString('ShipAddr.Id','109');
jsonReq.UpdateNewArray('LinkedTxn');
jsonReq.UpdateString('DueDate','2015-08-23');
jsonReq.UpdateString('PrintStatus','NeedToPrint');
jsonReq.UpdateString('EmailStatus','NotSet');
jsonReq.UpdateBool('sparse',0);
jsonReq.UpdateInt('Line[0].LineNum',1);
jsonReq.UpdateNumber('Line[0].Amount','150.0');
jsonReq.UpdateString('Line[0].SalesItemLineDetail.TaxCodeRef.value','NON');
jsonReq.UpdateString('Line[0].SalesItemLineDetail.ItemRef.name','Services');
jsonReq.UpdateString('Line[0].SalesItemLineDetail.ItemRef.value','1');
jsonReq.UpdateString('Line[0].Id','1');
jsonReq.UpdateString('Line[0].DetailType','SalesItemLineDetail');
jsonReq.UpdateString('Line[1].DetailType','SubTotalLineDetail');
jsonReq.UpdateNumber('Line[1].Amount','150.0');
jsonReq.UpdateNewObject('Line[1].SubTotalLineDetail');
jsonReq.UpdateBool('ApplyTaxAfterDiscount',0);
jsonReq.UpdateString('CustomField[0].DefinitionId','1');
jsonReq.UpdateString('CustomField[0].Type','StringType');
jsonReq.UpdateString('CustomField[0].Name','Crew #');
jsonReq.UpdateString('Id','239');
jsonReq.UpdateInt('TxnTaxDetail.TotalTax',0);
jsonReq.UpdateString('MetaData.CreateTime','2015-07-24T10:35:08-07:00');
jsonReq.UpdateString('MetaData.LastUpdatedTime','2015-07-24T10:35:08-07:00');
sbRequestBody := TChilkatStringBuilder.Create(Self);
jsonReq.EmitSb(sbRequestBody.ControlInterface);
rest.AddHeader('Content-Type','application/json');
rest.AddHeader('Accept','application/json');
rest.AllowHeaderFolding := 0;
sbResponseBody := TChilkatStringBuilder.Create(Self);
success := rest.FullRequestSb('POST','/v3/company/<realmID>/invoice',sbRequestBody.ControlInterface,sbResponseBody.ControlInterface);
if (success <> 1) then
begin
Memo1.Lines.Add(rest.LastErrorText);
Exit;
end;
respStatusCode := rest.ResponseStatusCode;
// Success is indicated by a 200 response status code.
Memo1.Lines.Add('response status code = ' + IntToStr(respStatusCode));
jsonResponse := TChilkatJsonObject.Create(Self);
jsonResponse.LoadSb(sbResponseBody.ControlInterface);
jsonResponse.EmitCompact := 0;
Memo1.Lines.Add(jsonResponse.Emit());
if (rest.ResponseStatusCode <> 200) then
begin
Memo1.Lines.Add('Failed.');
Exit;
end;
// Sample output...
// (See the parsing code below..)
//
// Use the this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
// {
// "Invoice": {
// "TxnDate": "2015-07-24",
// "domain": "QBO",
// "PrintStatus": "NeedToPrint",
// "TotalAmt": 150.0,
// "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": {}
// }
// ],
// "DueDate": "2015-08-23",
// "ApplyTaxAfterDiscount": false,
// "DocNumber": "1070",
// "sparse": false,
// "CustomerMemo": {
// "value": "Added customer memo."
// },
// "Deposit": 0,
// "Balance": 150.0,
// "CustomerRef": {
// "name": "Amy's Bird Sanctuary",
// "value": "1"
// },
// "TxnTaxDetail": {
// "TotalTax": 0
// },
// "SyncToken": "1",
// "LinkedTxn": [
// ],
// "ShipAddr": {
// "CountrySubDivisionCode": "CA",
// "City": "Bayshore",
// "PostalCode": "94326",
// "Id": "118",
// "Line1": "4581 Finch St."
// },
// "EmailStatus": "NotSet",
// "BillAddr": {
// "CountrySubDivisionCode": "CA",
// "City": "Bayshore",
// "PostalCode": "94326",
// "Id": "117",
// "Line1": "4581 Finch St."
// },
// "MetaData": {
// "CreateTime": "2015-07-24T10:35:08-07:00",
// "LastUpdatedTime": "2015-07-24T10:53:39-07:00"
// },
// "CustomField": [
// {
// "DefinitionId": "1",
// "Type": "StringType",
// "Name": "Crew #"
// }
// ],
// "Id": "239"
// },
// "time": "2015-07-24T10:53:39.287-07:00"
// }
//
InvoiceTxnDate := jsonResponse.StringOf('Invoice.TxnDate');
InvoiceDomain := jsonResponse.StringOf('Invoice.domain');
InvoicePrintStatus := jsonResponse.StringOf('Invoice.PrintStatus');
InvoiceTotalAmt := jsonResponse.StringOf('Invoice.TotalAmt');
InvoiceDueDate := jsonResponse.StringOf('Invoice.DueDate');
InvoiceApplyTaxAfterDiscount := jsonResponse.BoolOf('Invoice.ApplyTaxAfterDiscount');
InvoiceDocNumber := jsonResponse.StringOf('Invoice.DocNumber');
InvoiceSparse := jsonResponse.BoolOf('Invoice.sparse');
InvoiceCustomerMemoValue := jsonResponse.StringOf('Invoice.CustomerMemo.value');
InvoiceDeposit := jsonResponse.IntOf('Invoice.Deposit');
InvoiceBalance := jsonResponse.StringOf('Invoice.Balance');
InvoiceCustomerRefName := jsonResponse.StringOf('Invoice.CustomerRef.name');
InvoiceCustomerRefValue := jsonResponse.StringOf('Invoice.CustomerRef.value');
InvoiceTxnTaxDetailTotalTax := jsonResponse.IntOf('Invoice.TxnTaxDetail.TotalTax');
InvoiceSyncToken := jsonResponse.StringOf('Invoice.SyncToken');
InvoiceShipAddrCountrySubDivisionCode := jsonResponse.StringOf('Invoice.ShipAddr.CountrySubDivisionCode');
InvoiceShipAddrCity := jsonResponse.StringOf('Invoice.ShipAddr.City');
InvoiceShipAddrPostalCode := jsonResponse.StringOf('Invoice.ShipAddr.PostalCode');
InvoiceShipAddrId := jsonResponse.StringOf('Invoice.ShipAddr.Id');
InvoiceShipAddrLine1 := jsonResponse.StringOf('Invoice.ShipAddr.Line1');
InvoiceEmailStatus := jsonResponse.StringOf('Invoice.EmailStatus');
InvoiceBillAddrCountrySubDivisionCode := jsonResponse.StringOf('Invoice.BillAddr.CountrySubDivisionCode');
InvoiceBillAddrCity := jsonResponse.StringOf('Invoice.BillAddr.City');
InvoiceBillAddrPostalCode := jsonResponse.StringOf('Invoice.BillAddr.PostalCode');
InvoiceBillAddrId := jsonResponse.StringOf('Invoice.BillAddr.Id');
InvoiceBillAddrLine1 := jsonResponse.StringOf('Invoice.BillAddr.Line1');
InvoiceMetaDataCreateTime := jsonResponse.StringOf('Invoice.MetaData.CreateTime');
InvoiceMetaDataLastUpdatedTime := jsonResponse.StringOf('Invoice.MetaData.LastUpdatedTime');
InvoiceId := jsonResponse.StringOf('Invoice.Id');
time := jsonResponse.StringOf('time');
i := 0;
count_i := jsonResponse.SizeOfArray('Invoice.Line');
while i < count_i do
begin
jsonResponse.I := i;
LineNum := jsonResponse.IntOf('Invoice.Line[i].LineNum');
Amount := jsonResponse.StringOf('Invoice.Line[i].Amount');
SalesItemLineDetailTaxCodeRefValue := jsonResponse.StringOf('Invoice.Line[i].SalesItemLineDetail.TaxCodeRef.value');
SalesItemLineDetailItemRefName := jsonResponse.StringOf('Invoice.Line[i].SalesItemLineDetail.ItemRef.name');
SalesItemLineDetailItemRefValue := jsonResponse.StringOf('Invoice.Line[i].SalesItemLineDetail.ItemRef.value');
Id := jsonResponse.StringOf('Invoice.Line[i].Id');
DetailType := jsonResponse.StringOf('Invoice.Line[i].DetailType');
i := i + 1;
end;
i := 0;
count_i := jsonResponse.SizeOfArray('Invoice.LinkedTxn');
while i < count_i do
begin
jsonResponse.I := i;
i := i + 1;
end;
i := 0;
count_i := jsonResponse.SizeOfArray('Invoice.CustomField');
while i < count_i do
begin
jsonResponse.I := i;
DefinitionId := jsonResponse.StringOf('Invoice.CustomField[i].DefinitionId');
invType := jsonResponse.StringOf('Invoice.CustomField[i].Type');
Name := jsonResponse.StringOf('Invoice.CustomField[i].Name');
i := i + 1;
end;
end;