Sample code for 30+ languages & platforms
Android™

Quickbooks Query an Invoice

See more QuickBooks Examples

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

Chilkat Android™ Downloads

Android™
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;

import android.app.Activity;
import com.chilkatsoft.*;

import android.widget.TextView;
import android.os.Bundle;

public class SimpleActivity extends Activity {

  private static final String TAG = "Chilkat";

  // Called when the activity is first created.
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    boolean success = false;

    // 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.
    CkJsonObject jsonToken = new CkJsonObject();
    success = jsonToken.LoadFile("qa_data/tokens/qb-access-token.json");

    CkRest rest = new CkRest();

    boolean bTls = true;
    int port = 443;
    boolean bAutoReconnect = true;
    success = rest.Connect("sandbox-quickbooks.api.intuit.com",port,bTls,bAutoReconnect);

    CkStringBuilder sbAuth = new CkStringBuilder();
    sbAuth.Append("Bearer ");
    sbAuth.Append(jsonToken.stringOf("access_token"));
    rest.put_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.put_AllowHeaderFolding(false);

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

    CkStringBuilder sbResponseBody = new CkStringBuilder();
    success = rest.FullRequestNoBodySb("GET","/v3/company/<realmID>/invoice",sbResponseBody);
    if (success != true) {
        Log.i(TAG, rest.lastErrorText());
        return;
        }

    int respStatusCode = rest.get_ResponseStatusCode();
    if (respStatusCode >= 400) {
        Log.i(TAG, "Response Status Code = " + String.valueOf(respStatusCode));
        Log.i(TAG, "Response Header:");
        Log.i(TAG, rest.responseHeader());
        Log.i(TAG, "Response Body:");
        Log.i(TAG, sbResponseBody.getAsString());
        return;
        }

    // Success is indicated by a 200 response status.
    Log.i(TAG, "response status code = " + String.valueOf(respStatusCode));

    CkJsonObject json = new CkJsonObject();
    json.LoadSb(sbResponseBody);
    json.put_EmitCompact(false);
    Log.i(TAG, 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"
    // }

    String DocNumber;
    String SyncToken;
    String domain;
    String Balance;
    String BillAddrCity;
    String BillAddrLine1;
    String BillAddrPostalCode;
    String BillAddrLat;
    String BillAddrLong;
    String BillAddrCountrySubDivisionCode;
    String BillAddrId;
    String TxnDate;
    String TotalAmt;
    String CustomerRefName;
    String CustomerRefValue;
    String ShipAddrCity;
    String ShipAddrLine1;
    String ShipAddrPostalCode;
    String ShipAddrLat;
    String ShipAddrLong;
    String ShipAddrCountrySubDivisionCode;
    String ShipAddrId;
    String DueDate;
    String PrintStatus;
    int Deposit;
    boolean sparse;
    String EmailStatus;
    boolean ApplyTaxAfterDiscount;
    String Id;
    int TxnTaxDetailTotalTax;
    String MetaDataCreateTime;
    String MetaDataLastUpdatedTime;
    int j;
    int count_j;
    int LineNum;
    String Amount;
    String SalesItemLineDetailTaxCodeRefValue;
    String SalesItemLineDetailItemRefName;
    String SalesItemLineDetailItemRefValue;
    String DetailType;
    String DefinitionId;
    String invType;
    String Name;

    int QueryResponseStartPosition = json.IntOf("QueryResponse.startPosition");
    int QueryResponseTotalCount = json.IntOf("QueryResponse.totalCount");
    int QueryResponseMaxResults = json.IntOf("QueryResponse.maxResults");
    String time = json.stringOf("time");
    int i = 0;
    int count_i = json.SizeOfArray("QueryResponse.Invoice");
    while (i < count_i) {
        json.put_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) {
            json.put_J(j);
            j = j + 1;
            }

        j = 0;
        count_j = json.SizeOfArray("QueryResponse.Invoice[i].Line");
        while (j < count_j) {
            json.put_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;
            }

        j = 0;
        count_j = json.SizeOfArray("QueryResponse.Invoice[i].CustomField");
        while (j < count_j) {
            json.put_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;
            }

        i = i + 1;
        }


  }

  static {
      System.loadLibrary("chilkat");

      // Note: If the incorrect library name is passed to System.loadLibrary,
      // then you will see the following error message at application startup:
      //"The application <your-application-name> has stopped unexpectedly. Please try again."
  }
}