Classic ASP
Classic ASP
Quickbooks Update an Invoice
See more QuickBooks Examples
Demonstrates how to update an invoice using the Quickbooks REST API.Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
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.
set jsonToken = Server.CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile("qa_data/tokens/qb-access-token.json")
set rest = Server.CreateObject("Chilkat.Rest")
' Connect to the REST server.
bTls = 1
port = 443
bAutoReconnect = 1
success = rest.Connect("sandbox-quickbooks.api.intuit.com",port,bTls,bAutoReconnect)
set sbAuth = Server.CreateObject("Chilkat.StringBuilder")
success = sbAuth.Append("Bearer ")
success = 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
set jsonReq = Server.CreateObject("Chilkat.JsonObject")
success = jsonReq.UpdateString("DocNumber","1070")
success = jsonReq.UpdateString("SyncToken","0")
success = jsonReq.UpdateString("domain","QBO")
success = jsonReq.UpdateNumber("Balance","150.0")
success = jsonReq.UpdateString("BillAddr.City","Bayshore")
success = jsonReq.UpdateString("BillAddr.Line1","4581 Finch St.")
success = jsonReq.UpdateString("BillAddr.PostalCode","94326")
success = jsonReq.UpdateString("BillAddr.Lat","INVALID")
success = jsonReq.UpdateString("BillAddr.Long","INVALID")
success = jsonReq.UpdateString("BillAddr.CountrySubDivisionCode","CA")
success = jsonReq.UpdateString("BillAddr.Id","2")
success = jsonReq.UpdateString("TxnDate","2015-07-24")
success = jsonReq.UpdateNumber("TotalAmt","150.0")
success = jsonReq.UpdateString("CustomerRef.name","Amy's Bird Sanctuary")
success = jsonReq.UpdateString("CustomerRef.value","1")
success = jsonReq.UpdateString("CustomerMemo.value","Added customer memo.")
success = jsonReq.UpdateString("ShipAddr.City","Bayshore")
success = jsonReq.UpdateString("ShipAddr.Line1","4581 Finch St.")
success = jsonReq.UpdateString("ShipAddr.PostalCode","94326")
success = jsonReq.UpdateString("ShipAddr.Lat","INVALID")
success = jsonReq.UpdateString("ShipAddr.Long","INVALID")
success = jsonReq.UpdateString("ShipAddr.CountrySubDivisionCode","CA")
success = jsonReq.UpdateString("ShipAddr.Id","109")
success = jsonReq.UpdateNewArray("LinkedTxn")
success = jsonReq.UpdateString("DueDate","2015-08-23")
success = jsonReq.UpdateString("PrintStatus","NeedToPrint")
success = jsonReq.UpdateString("EmailStatus","NotSet")
success = jsonReq.UpdateBool("sparse",0)
success = jsonReq.UpdateInt("Line[0].LineNum",1)
success = jsonReq.UpdateNumber("Line[0].Amount","150.0")
success = jsonReq.UpdateString("Line[0].SalesItemLineDetail.TaxCodeRef.value","NON")
success = jsonReq.UpdateString("Line[0].SalesItemLineDetail.ItemRef.name","Services")
success = jsonReq.UpdateString("Line[0].SalesItemLineDetail.ItemRef.value","1")
success = jsonReq.UpdateString("Line[0].Id","1")
success = jsonReq.UpdateString("Line[0].DetailType","SalesItemLineDetail")
success = jsonReq.UpdateString("Line[1].DetailType","SubTotalLineDetail")
success = jsonReq.UpdateNumber("Line[1].Amount","150.0")
success = jsonReq.UpdateNewObject("Line[1].SubTotalLineDetail")
success = jsonReq.UpdateBool("ApplyTaxAfterDiscount",0)
success = jsonReq.UpdateString("CustomField[0].DefinitionId","1")
success = jsonReq.UpdateString("CustomField[0].Type","StringType")
success = jsonReq.UpdateString("CustomField[0].Name","Crew #")
success = jsonReq.UpdateString("Id","239")
success = jsonReq.UpdateInt("TxnTaxDetail.TotalTax",0)
success = jsonReq.UpdateString("MetaData.CreateTime","2015-07-24T10:35:08-07:00")
success = jsonReq.UpdateString("MetaData.LastUpdatedTime","2015-07-24T10:35:08-07:00")
set sbRequestBody = Server.CreateObject("Chilkat.StringBuilder")
success = jsonReq.EmitSb(sbRequestBody)
success = rest.AddHeader("Content-Type","application/json")
success = rest.AddHeader("Accept","application/json")
rest.AllowHeaderFolding = 0
set sbResponseBody = Server.CreateObject("Chilkat.StringBuilder")
success = rest.FullRequestSb("POST","/v3/company/<realmID>/invoice",sbRequestBody,sbResponseBody)
If (success <> 1) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
respStatusCode = rest.ResponseStatusCode
' Success is indicated by a 200 response status code.
Response.Write "<pre>" & Server.HTMLEncode( "response status code = " & respStatusCode) & "</pre>"
set jsonResponse = Server.CreateObject("Chilkat.JsonObject")
success = jsonResponse.LoadSb(sbResponseBody)
jsonResponse.EmitCompact = 0
Response.Write "<pre>" & Server.HTMLEncode( jsonResponse.Emit()) & "</pre>"
If (rest.ResponseStatusCode <> 200) Then
Response.Write "<pre>" & Server.HTMLEncode( "Failed.") & "</pre>"
Response.End
End If
' 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")
Do While i < count_i
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
Loop
i = 0
count_i = jsonResponse.SizeOfArray("Invoice.LinkedTxn")
Do While i < count_i
jsonResponse.I = i
i = i + 1
Loop
i = 0
count_i = jsonResponse.SizeOfArray("Invoice.CustomField")
Do While i < count_i
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
Loop
%>
</body>
</html>