Android™
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
// 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."
}
}