Chilkat Examples

ChilkatHOMEAndroid™Classic ASPCC++C#Mono C#.NET Core C#C# UWP/WinRTDataFlexDelphi ActiveXDelphi DLLVisual FoxProJavaLianjaMFCObjective-CPerlPHP ActiveXPHP ExtensionPowerBuilderPowerShellPureBasicCkPythonChilkat2-PythonRubySQL ServerSwiftTclUnicode CUnicode C++Visual Basic 6.0VB.NETVB.NET UWP/WinRTVBScriptXojo PluginNode.jsExcel

C++ Examples


ASN.1
Amazon S3
Amazon S3 (new)
Amazon SES
Amazon SNS
Amazon SQS
Async
Azure Cloud Storage
Azure Service Bus
Bounced Email
Box
CSR
CSV
Certificates
Compression
DKIM / DomainKey
DSA
Diffie-Hellman
Digital Signatures
Dropbox
Dynamics CRM
ECC
Email Object
Encryption
FTP
Facebook
Firebase
GeoOp
Google APIs
Google Calendar
Google Cloud Storage
Google Drive
Google Sheets
Gzip
HTML-to-XML/Text
HTTP
HTTP Misc
IMAP
JSON
JSON Web Encryption (JWE)
JSON Web Signatures (JWS)
JSON Web Token (JWT)
Java KeyStore (JKS)

Jira
MHT / HTML Email
MIME
Microsoft Graph
NTLM
OAuth1
OAuth2
OneDrive
OpenSSL
Outlook
PEM
PFX/P12
POP3
PRNG
PayPal
Peoplevox
QuickBooks
REST
REST Misc
RSA Encryption
SCP
SFTP
SMTP
SSH
SSH Key
SSH Tunnel
SharePoint
Shopify
Socket/SSL/TLS
Spider
Stream
Stripe
SugarCRM
Tar Archive
Twitter
VoiceBase
Walmart
WebSocket
XAdES
XML
XML Digital Signatures
XMP
Xero
Zip
curl
eBay

 

 

 

(C++) QuickBooks - Query an Account

Demonstrates how to query the QuickBooks chart of accounts.

Chilkat C/C++ Library Downloads

MS Visual C/C++

Linux/CentOS C/C++

Alpine Linux C/C++

MAC OS X C/C++

armhf/aarch64 C/C++

C++ Builder

iOS C/C++

Android C/C++

Win Mobile 5.0/Pocket PC 2003

Solaris C/C++

FreeBSD C/C++

OpenBSD C/C++

MinGW C/C++

#include <CkJsonObject.h>
#include <CkOAuth1.h>
#include <CkRest.h>
#include <CkStringBuilder.h>
#include <CkDateTime.h>
#include <CkDtObj.h>

void ChilkatSample(void)
    {
    //  This example assumes the Chilkat API to have been previously unlocked.
    //  See Global Unlock Sample for sample code.

    //  This example also assumes an OAuth1 access token was previously fetched.
    //  and saved in a JSON file.  See the Chilkat online examples at example-code.com
    //  for Quickbooks OAuth1 examples (in the Quickbooks and OAuth1 categories)
    // 

    //  First get our previously obtained access token.
    CkJsonObject jsonToken;
    bool success = jsonToken.LoadFile("qa_data/tokens/quickbooks.json");

    CkOAuth1 oauth1;
    oauth1.put_ConsumerKey("QUICKBOOKS_CONSUMER_KEY");
    oauth1.put_ConsumerSecret("QUICKBOOKS_CONSUMER_SECRET");
    oauth1.put_Token(jsonToken.stringOf("oauth_token"));
    oauth1.put_TokenSecret(jsonToken.stringOf("oauth_token_secret"));

    CkRest rest;

    //  Connect using TLS.
    //  A single REST object, once connected, can be used for many Quickbooks REST API calls.
    //  The auto-reconnect indicates that if the already-established HTTPS connection is closed,
    //  then it will be automatically re-established as needed.
    bool bAutoReconnect = true;
    success = rest.Connect("sandbox-quickbooks.api.intuit.com",443,true,bAutoReconnect);
    if (success != true) {
        std::cout << rest.lastErrorText() << "\r\n";
        return;
    }

    rest.SetAuthOAuth1(oauth1,false);

    //  The company ID is the realmId
    CkStringBuilder sbPath;
    sbPath.Append("/v3/company/<companyID>/query");
    int numReplacements = sbPath.Replace("<companyID>",jsonToken.stringOf("realmId"));

    rest.AddHeader("Accept","application/json");
    rest.put_AllowHeaderFolding(false);

    const char *query = "select * from Account where Metadata.CreateTime > '2014-12-31'";
    rest.AddQueryParam("query",query);

    const char *responseBody = rest.fullRequestNoBody("GET",sbPath.getAsString());
    if (rest.get_LastMethodSuccess() != true) {
        std::cout << rest.lastErrorText() << "\r\n";
        return;
    }

    //  We should expect a 200 response if successful.
    if (rest.get_ResponseStatusCode() != 200) {
        std::cout << "Request Header: " << "\r\n";
        std::cout << rest.lastRequestHeader() << "\r\n";
        std::cout << "----" << "\r\n";
        std::cout << "Response StatusCode = " << rest.get_ResponseStatusCode() << "\r\n";
        std::cout << "Response StatusLine: " << rest.responseStatusText() << "\r\n";
        std::cout << "Response Header:" << "\r\n";
        std::cout << rest.responseHeader() << "\r\n";
        std::cout << responseBody << "\r\n";
        return;
    }

    //  Load the JSON response into a JSON object for parsing.
    //  A sample JSON response is shown below.
    CkJsonObject json;
    json.Load(responseBody);

    //  These will be used for parsing date/time strings..
    CkDateTime dtime;
    bool bLocalTime = true;
    CkDtObj *dt = 0;

    //  Iterate over each account returned.
    int numAccounts = json.SizeOfArray("QueryResponse.Account");
    int i = 0;
    while (i < numAccounts) {

        json.put_I(i);
        std::cout << "Name: " << json.stringOf("QueryResponse.Account[i].Name") << "\r\n";
        std::cout << "Id: " << json.stringOf("QueryResponse.Account[i].Id") << "\r\n";

        //  Load the CreateTime into a CkDateTime...
        dtime.SetFromTimestamp(json.stringOf("QueryResponse.Account[i].MetaData.CreateTime"));
        dt = dtime.GetDtObj(bLocalTime);
        std::cout << dt->get_Month() << "/" << dt->get_Day() << "/" << dt->get_Year() << "  " << dt->get_Hour()
             << ":" << dt->get_Minute() << "\r\n";
        delete dt;

        std::cout << "----" << "\r\n";
        i = i + 1;
    }

    std::cout << "Success." << "\r\n";

    //  ------------------------------------------------------
    //  The JSON response looks like this:

    //  {
//   "QueryResponse": {
//     "Account": [
    //        {
//         "Name": "Accounts Payable (A/P)",
    //          "SubAccount": false,
    //          "FullyQualifiedName": "Accounts Payable (A/P)",
    //          "Active": true,
    //          "Classification": "Liability",
    //          "AccountType": "Accounts Payable",
    //          "AccountSubType": "AccountsPayable",
    //          "CurrentBalance": -1602.67,
    //          "CurrentBalanceWithSubAccounts": -1602.67,
    //          "CurrencyRef": {
//           "value": "USD",
    //            "name": "United States Dollar"
    //          },
    //          "domain": "QBO",
    //          "sparse": false,
    //          "Id": "33",
    //          "SyncToken": "0",
    //          "MetaData": {
//           "CreateTime": "2016-09-10T10:12:02-07:00",
    //            "LastUpdatedTime": "2016-09-17T13:10:36-07:00"
    //          }
    //        },
    //        {
//         "Name": "Accounts Receivable (A/R)",
    //          "SubAccount": false,
    //          "FullyQualifiedName": "Accounts Receivable (A/R)",
    //          "Active": true,
    //          "Classification": "Asset",
    //          "AccountType": "Accounts Receivable",
    //          "AccountSubType": "AccountsReceivable",
    //          "CurrentBalance": 5281.52,
    //          "CurrentBalanceWithSubAccounts": 5281.52,
    //          "CurrencyRef": {
//           "value": "USD",
    //            "name": "United States Dollar"
    //          },
    //          "domain": "QBO",
    //          "sparse": false,
    //          "Id": "84",
    //          "SyncToken": "0",
    //          "MetaData": {
//           "CreateTime": "2016-09-14T14:49:29-07:00",
    //            "LastUpdatedTime": "2016-09-17T13:16:17-07:00"
    //          }
    //        },
    //        {
//         "Name": "Advertising",
    //          "SubAccount": false,
    //          "FullyQualifiedName": "Advertising",
    //          "Active": true,
    //          "Classification": "Expense",
    //          "AccountType": "Expense",
    //          "AccountSubType": "AdvertisingPromotional",
    //          "CurrentBalance": 0,
    //          "CurrentBalanceWithSubAccounts": 0,
    //          "CurrencyRef": {
//           "value": "USD",
    //            "name": "United States Dollar"
    //          },
    //          "domain": "QBO",
    //          "sparse": false,
    //          "Id": "7",
    //          "SyncToken": "0",
    //          "MetaData": {
//           "CreateTime": "2016-09-09T14:42:07-07:00",
    //            "LastUpdatedTime": "2016-09-09T14:42:07-07:00"
    //          }
    //        },
    //  ...
    //    "time": "2016-10-24T15:35:25.067-07:00"
    //  }
    }

 

© 2000-2016 Chilkat Software, Inc. All Rights Reserved.