Sample code for 30+ languages & platforms
Go

Quickbooks Update an Invoice

See more QuickBooks Examples

Demonstrates how to update an invoice using the Quickbooks REST API.

Chilkat Go Downloads

Go
    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.
    jsonToken := chilkat.NewJsonObject()
    success = jsonToken.LoadFile("qa_data/tokens/qb-access-token.json")

    rest := chilkat.NewRest()

    // Connect to the REST server.
    bTls := true
    port := 443
    bAutoReconnect := true
    success = rest.Connect("sandbox-quickbooks.api.intuit.com",port,bTls,bAutoReconnect)

    sbAuth := chilkat.NewStringBuilder()
    sbAuth.Append("Bearer ")
    sbAuth.Append(*jsonToken.StringOf("access_token"))
    rest.SetAuthorization(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 := chilkat.NewJsonObject()
    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",false)
    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",false)
    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 := chilkat.NewStringBuilder()
    jsonReq.EmitSb(sbRequestBody)

    rest.AddHeader("Content-Type","application/json")
    rest.AddHeader("Accept","application/json")
    rest.SetAllowHeaderFolding(false)

    sbResponseBody := chilkat.NewStringBuilder()
    success = rest.FullRequestSb("POST","/v3/company/<realmID>/invoice",sbRequestBody,sbResponseBody)
    if success != true {
        fmt.Println(rest.LastErrorText())
        jsonToken.DisposeJsonObject()
        rest.DisposeRest()
        sbAuth.DisposeStringBuilder()
        jsonReq.DisposeJsonObject()
        sbRequestBody.DisposeStringBuilder()
        sbResponseBody.DisposeStringBuilder()
        return
    }

    respStatusCode := rest.ResponseStatusCode()

    // Success is indicated by a 200 response status code.
    fmt.Println("response status code = ", respStatusCode)

    jsonResponse := chilkat.NewJsonObject()
    jsonResponse.LoadSb(sbResponseBody)
    jsonResponse.SetEmitCompact(false)
    fmt.Println(*jsonResponse.Emit())

    if rest.ResponseStatusCode() != 200 {
        fmt.Println("Failed.")
        jsonToken.DisposeJsonObject()
        rest.DisposeRest()
        sbAuth.DisposeStringBuilder()
        jsonReq.DisposeJsonObject()
        sbRequestBody.DisposeStringBuilder()
        sbResponseBody.DisposeStringBuilder()
        jsonResponse.DisposeJsonObject()
        return
    }

    // 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"
    // }
    // 

    var LineNum int
    var Amount *string = new(string)
    var SalesItemLineDetailTaxCodeRefValue *string = new(string)
SalesItemLineDetailItemRef    var Name *string = new(string)
    var SalesItemLineDetailItemRefValue *string = new(string)
    var Id *string = new(string)
    var DetailType *string = new(string)
Definition    var Id *string = new(string)
    var invType *string = new(string)
    var Name *string = new(string)

    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")
    for i < count_i {
        jsonResponse.SetI(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
    }

    i = 0
    count_i = jsonResponse.SizeOfArray("Invoice.LinkedTxn")
    for i < count_i {
        jsonResponse.SetI(i)
        i = i + 1
    }

    i = 0
    count_i = jsonResponse.SizeOfArray("Invoice.CustomField")
    for i < count_i {
        jsonResponse.SetI(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
    }


    jsonToken.DisposeJsonObject()
    rest.DisposeRest()
    sbAuth.DisposeStringBuilder()
    jsonReq.DisposeJsonObject()
    sbRequestBody.DisposeStringBuilder()
    sbResponseBody.DisposeStringBuilder()
    jsonResponse.DisposeJsonObject()