Note
Note about deprecation of TLS1.0 and TLS1.1
As we mentioned in our previous blog posts, we’re no longer supporting TLS1.0 and TLS1.1 starting June 1st, 2022. We’ll only support TLS1.2 or higher going forward. Refer to our blog for more details:
The QuickBooks Online Accounting API is based on the REST framework. Here’s a quick guide for relevant REST features, operations, formats, and attributes.
See the our current baseURLs </app/developer/qbo/docs/get-started/create-a-request>_.
Operation | URI |
---|---|
Create and update | POST baseURL/v3/company/realmId/resourceName |
Read (single-entity) | GET baseURL/v3/company/realmId/resourceName/entityID |
Read (multi-entity) | GET baseURL/v3/company/realmId/query?query=selectStmt |
Delete | POST baseURL/v3/company/realmId/resourceName?operation=delete |
Component | Description |
---|---|
baseURL | Initial path to the URI. The Base URL section contains the list of available paths. |
resourceName | The name of the API entity you’re performing the operation for (i.e a customer, invoice, transaction, etc.) |
entityID | The ID identifying the specific instance of the API entity. |
These are the common HTTP header fields for requests.
Field name | Description | Required |
---|---|---|
Accept |
The acceptable Individual entity references in the API Explorer note the supported content types. |
Optional |
Accept-Encoding |
The The desired content-coding in the response. This is set by the request library in use if that library supports compression. In most cases, you should set a parameter in your network library indicating you want responses to be compressed, rather than setting the header manually. This can significantly improve the perceived performance of your app, and dramatically reduces the size of response data. |
Optional |
Authorization |
The authentication credentials for HTTP authentication. This header is required for all requests. It represents the end-user’s permission to let your app share access to their QuickBooks Online company data. Learn how to implement OAuth 2.0 and create this value. |
Required |
Content-Length |
Length of the message (without the headers) according to RFC 2616. This header is used for POST operations. | Optional |
Content-Type |
The MIME type of the request body. This header is used for POST operations. Use application/json for all API interactions. |
Required for POST operations |
Host |
The domain name of the server for the request. This is set by the request library in use. See Base URLs for valid values. | Optional |
See an example POST request
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | POST /v3/company/12345678/invoice HTTP/1.1 Host: quickbooks.api.intuit.com Accept: application/json Content-Type: application/json Authorization: Bearer eyJlbmMiOiJ**************xPfzFFw Host: quickbooks.api.intuit.com ​{ "Line": [ { "Amount": 100.00, "DetailType": "SalesItemLineDetail", "SalesItemLineDetail": { "ItemRef": { "value": "1", "name": "Services" } } } ], "CustomerRef": { "value": "1" } } |
These are common HTTP header fields for responses from our servers.
Field name | Description |
---|---|
Cache-Control |
Specifies directives that must be obeyed by all caching mechanisms along the request-response chain. |
Connection |
Control options for the current connection and list of hop-by-hop response fields. |
Content-Type |
Defines the MIME type of the response. |
Date |
Gives the date and time for service responses. Defined by RFC 7131 date/time format. |
Expires |
Gives the date/time when the response is considered stale. |
intuit_tid |
Indicates errors or issues. Tip: If you see this value in the response, log it. It will help our support team quickly identify the issue. |
Keep-Alive |
Indicates of the HTTPS channel can be kept “alive†(open) to improve performance on subsequent requests. This is managed by the underlying networking library of the language. |
QBO-Version |
Specifies the version of our services that processed the request. |
Server |
Specifies the server handling the request. Tip: If there’s ever an issue, our support staff can quickly determine whether there are issues with a specific server. |
Strict-Transport-Security |
A HSTS Policy informing the HTTP client how long to cache the HTTPS only policy, and whether this policy applies to subdomains. |
Transfer-Encoding |
Specifies the encoding used to safely transfer the API response data to the app making the API call for the given entity. Current methods: chunked , compress , deflate , gzip , identity . |
Vary |
Tells downstream proxies how to match future request headers. This decides if the cached response can be used, rather than requesting a fresh one from the origin server. |
Via |
Informs the client if the response was sent through any proxies. |
See an example response
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | Cache-Control: max-age=0, no-cache, no-store, must-revalidate, private Connection: keep-alive Content-Type: application/json;charset=UTF-8 Date: Thu, 07 Jan 2016 17:19:22 GMT Expires: 0 intuit_tid: gw-756b01cf-3fe0-4414-a2a2-321dd2287b7b Keep-Alive: timeout=5 QBO-Version: 1512.462 Server: nginx/1.8.0 Strict-Transport-Security: max-age=15552000 Transfer-Encoding: chunked Vary: Accept-Encoding Via: 1.1 ipp-gateway-ap05 { "Invoice": { ... }, "time": "2016-01-07T09:19:21.923-08:00" } |
Here are detailed definitions of common IDs and data fields used throughout our API.
Any value supplied in a read-only attribute is transient and will be silently overwritten by QuickBooks data services. No error is returned. Learn more about updating read only attributes.
US versions of QuickBooks Online support ISO-8859-1 (extended ASCII) character encoding.
Non-US versions of QuickBooks Online support UTF-8 character encoding.
The basic format is <date>T<time><UTC offset>
Timestamps returned in QuickBooks Online Accounting API response payloads and webhooks notifications are in “DateTime†format. This conforms to the iCal date/time format, as defined in RFC 2445.
Field name | Description |
date |
The UTC date follows the format *YYYY-MM-DD. |
time |
The UTC time follows the format HH:MM:SS. |
UTC offset |
The UTC offset to apply for time zone correction follows the format +/-HH:MM. |
Here’s an example timestamp:
2015-07-24T10:33:39-07:00
This represents 03:33:39 on 24 July 2015, in a time zone west of UTC by 07:00 hours.
Server | QuickBooks Online API endpoints | Batch endpoint |
---|---|---|
Sandbox servers |
|
|
Production servers |
|
|
The current version of the QuickBooks Online Accounting API supports minor versions.
This lets you access incremental changes and continue using specific versions of API entities so you don’t break existing apps. Here’s how to access minor versions.