Back to Collection Items
' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
Dim http As New Chilkat.Http
Dim success As Boolean
' Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = "<access_token>"
Dim sbResponseBody As New Chilkat.StringBuilder
success = http.QuickGetSb("https://api.freshbooks.com/accounting/account/{{accountId}}/reports/accounting/accounts_aging",sbResponseBody)
If (success = False) Then
Debug.WriteLine(http.LastErrorText)
Exit Sub
End If
Dim jResp As New Chilkat.JsonObject
jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = False
Debug.WriteLine("Response Body:")
Debug.WriteLine(jResp.Emit())
Dim respStatusCode As Integer = http.LastStatus
Debug.WriteLine("Response Status Code = " & respStatusCode)
If (respStatusCode >= 400) Then
Debug.WriteLine("Response Header:")
Debug.WriteLine(http.LastHeader)
Debug.WriteLine("Failed.")
Exit Sub
End If
' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)
' {
' "response": {
' "result": {
' "accounts_aging": {
' "accounts": [
' {
' "0-30": {
' "amount": "3830.00",
' "code": "USD"
' },
' "31-60": {
' "amount": "0.00",
' "code": "USD"
' },
' "61-90": {
' "amount": "0.00",
' "code": "USD"
' },
' "91+": {
' "amount": "0.00",
' "code": "USD"
' },
' "email": "first@company.com",
' "fname": "Nicolas",
' "lname": "one",
' "organization": "first company",
' "total": {
' "amount": "3830.00",
' "code": "USD"
' },
' "userid": 31006
' },
' {
' "0-30": {
' "amount": "50.00",
' "code": "USD"
' },
' "31-60": {
' "amount": "0.00",
' "code": "USD"
' },
' "61-90": {
' "amount": "0.00",
' "code": "USD"
' },
' "91+": {
' "amount": "0.00",
' "code": "USD"
' },
' "email": "mwesthofer5i@imdb.com",
' "fname": "Myrta",
' "lname": "Westhofer",
' "organization": "Prosacco Group",
' "total": {
' "amount": "50.00",
' "code": "USD"
' },
' "userid": 32080
' },
' {
' "0-30": {
' "amount": "398.48",
' "code": "USD"
' },
' "31-60": {
' "amount": "0.00",
' "code": "USD"
' },
' "61-90": {
' "amount": "0.00",
' "code": "USD"
' },
' "91+": {
' "amount": "0.00",
' "code": "USD"
' },
' "email": "api.freshbooks@gmail.com",
' "fname": "Ryan",
' "lname": "Marr",
' "organization": "Ryan Marr",
' "total": {
' "amount": "398.48",
' "code": "USD"
' },
' "userid": 75162
' }
' ],
' "company_name": "Postman Sandbox",
' "currency_code": "USD",
' "download_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhY2NvdW50aWQiOiJ3a01kMmciLCJ1c2VyaWQiOjMxMDA0LCJjb250YWN0aWQiOi0xLCJsZXZlbCI6LTIwLCJ0eXBlIjoicmVwb3J0Iiwib2JqZWN0aWQiOiJhY2NvdW50c19hZ2luZyIsInBhcmFtcyI6eyJlbmRfZGF0ZSI6IjIwMTktMDUtMDgiLCJjdXJyZW5jeV9jb2RlIjoiVVNEIn0sImlhdCI6MTU1NzM0NjM4OCwiZXhwIjoxNTU5OTM4Mzg4fQ.Usasm7HQKxakFm5gFDAYMez__vLM5_VETtWdvdqJMeQ",
' "end_date": "2019-05-08",
' "totals": {
' "0-30": {
' "amount": "4278.48",
' "code": "USD"
' },
' "31-60": {
' "amount": "0.00",
' "code": "USD"
' },
' "61-90": {
' "amount": "0.00",
' "code": "USD"
' },
' "91+": {
' "amount": "0.00",
' "code": "USD"
' },
' "total": {
' "amount": "4278.48",
' "code": "USD"
' }
' }
' }
' }
' }
' }
' Sample code for parsing the JSON response...
' Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code
Dim v_0_30Amount As String
Dim v_0_30Code As String
Dim email As String
Dim fname As String
Dim lname As String
Dim organization As String
Dim totalAmount As String
Dim totalCode As String
Dim userid As Integer
Dim Company_name As String = jResp.StringOf("response.result.accounts_aging.company_name")
Dim Currency_code As String = jResp.StringOf("response.result.accounts_aging.currency_code")
Dim Download_token As String = jResp.StringOf("response.result.accounts_aging.download_token")
Dim End_date As String = jResp.StringOf("response.result.accounts_aging.end_date")
Dim Amount As String = jResp.StringOf("response.result.accounts_aging.totals.0-30.amount")
Dim Code As String = jResp.StringOf("response.result.accounts_aging.totals.0-30.code")
Dim v_31_60Amount As String = jResp.StringOf("response.result.accounts_aging.totals.31-60.amount")
Dim v_31_60Code As String = jResp.StringOf("response.result.accounts_aging.totals.31-60.code")
Dim v_61_90Amount As String = jResp.StringOf("response.result.accounts_aging.totals.61-90.amount")
Dim v_61_90Code As String = jResp.StringOf("response.result.accounts_aging.totals.61-90.code")
Dim v_91Amount As String = jResp.StringOf("response.result.accounts_aging.totals.91+.amount")
Dim v_91Code As String = jResp.StringOf("response.result.accounts_aging.totals.91+.code")
Dim TotalAmount As String = jResp.StringOf("response.result.accounts_aging.totals.total.amount")
Dim TotalCode As String = jResp.StringOf("response.result.accounts_aging.totals.total.code")
Dim i As Integer = 0
Dim count_i As Integer = jResp.SizeOfArray("response.result.accounts_aging.accounts")
While i < count_i
jResp.I = i
v_0_30Amount = jResp.StringOf("response.result.accounts_aging.accounts[i].0-30.amount")
v_0_30Code = jResp.StringOf("response.result.accounts_aging.accounts[i].0-30.code")
v_31_60Amount = jResp.StringOf("response.result.accounts_aging.accounts[i].31-60.amount")
v_31_60Code = jResp.StringOf("response.result.accounts_aging.accounts[i].31-60.code")
v_61_90Amount = jResp.StringOf("response.result.accounts_aging.accounts[i].61-90.amount")
v_61_90Code = jResp.StringOf("response.result.accounts_aging.accounts[i].61-90.code")
v_91Amount = jResp.StringOf("response.result.accounts_aging.accounts[i].91+.amount")
v_91Code = jResp.StringOf("response.result.accounts_aging.accounts[i].91+.code")
email = jResp.StringOf("response.result.accounts_aging.accounts[i].email")
fname = jResp.StringOf("response.result.accounts_aging.accounts[i].fname")
lname = jResp.StringOf("response.result.accounts_aging.accounts[i].lname")
organization = jResp.StringOf("response.result.accounts_aging.accounts[i].organization")
totalAmount = jResp.StringOf("response.result.accounts_aging.accounts[i].total.amount")
totalCode = jResp.StringOf("response.result.accounts_aging.accounts[i].total.code")
userid = jResp.IntOf("response.result.accounts_aging.accounts[i].userid")
i = i + 1
End While
Curl Command
curl -X GET
-H "Authorization: Bearer <access_token>"
https://api.freshbooks.com/accounting/account/{{accountId}}/reports/accounting/accounts_aging
Postman Collection Item JSON
{
"name": "Accounts Aging",
"request": {
"method": "GET",
"header": [
],
"url": {
"raw": "https://api.freshbooks.com/accounting/account/{{accountId}}/reports/accounting/accounts_aging",
"protocol": "https",
"host": [
"api",
"freshbooks",
"com"
],
"path": [
"accounting",
"account",
"{{accountId}}",
"reports",
"accounting",
"accounts_aging"
],
"query": [
{
"key": "start_date",
"value": "2019-01-01",
"description": "created during or after the given date i.e. `2019-01-01`",
"disabled": true
},
{
"key": "currency_code",
"value": "USD",
"description": "reports using the given currency as primary currency i.e. `\"USD\"`",
"disabled": true
}
]
}
},
"response": [
{
"name": "Accounts Aging",
"originalRequest": {
"method": "GET",
"header": [
],
"url": {
"raw": "https://api.freshbooks.com/accounting/account/{{accountId}}/reports/accounting/accounts_aging",
"protocol": "https",
"host": [
"api",
"freshbooks",
"com"
],
"path": [
"accounting",
"account",
"{{accountId}}",
"reports",
"accounting",
"accounts_aging"
],
"query": [
{
"key": "start_date",
"value": "2019-01-01",
"description": "created during or after the given date i.e. `2019-01-01`",
"disabled": true
},
{
"key": "currency_code",
"value": "USD",
"description": "reports using the given currency as primary currency i.e. `\"USD\"`",
"disabled": true
}
]
}
},
"status": "OK",
"code": 200,
"_postman_previewlanguage": "json",
"header": [
{
"key": "Server",
"value": "nginx"
},
{
"key": "Content-Type",
"value": "application/json"
},
{
"key": "X-NewRelic-App-Data",
"value": "PxQBWV5TCBABVlVSAwEOVlcTGhE1AwE2QgNWEVlbQFtcCxYnRA9QFg1ZWU4DFVdfRgFPCkNFR0gWVEZcEBIQWFEBWw1NVkBbXQJLBEEOQRYXFBtRSlMWAghXWFEBAgJRUAgOAlReWlccTwlOGg4MU1cHCVJSUgsAAgUPBwNBFFVRCBIHag=="
},
{
"key": "X-RateLimit-Limit",
"value": "20"
},
{
"key": "X-RateLimit-Remaining",
"value": "0"
},
{
"key": "X-RateLimit-Reset",
"value": "1557346447"
},
{
"key": "Retry-After",
"value": "58"
},
{
"key": "Access-Control-Allow-Origin",
"value": "*"
},
{
"key": "Expires",
"value": "Tue, 08 May 2018 20:13:08 GMT"
},
{
"key": "Cache-Control",
"value": "no-cache"
},
{
"key": "Content-Encoding",
"value": "gzip"
},
{
"key": "Via",
"value": "1.1 google"
},
{
"key": "Via",
"value": "1.1 varnish"
},
{
"key": "Accept-Ranges",
"value": "bytes"
},
{
"key": "Accept-Ranges",
"value": "bytes"
},
{
"key": "Age",
"value": "0"
},
{
"key": "Age",
"value": "0"
},
{
"key": "Transfer-Encoding",
"value": "chunked"
},
{
"key": "Date",
"value": "Wed, 08 May 2019 20:13:08 GMT"
},
{
"key": "Connection",
"value": "keep-alive"
},
{
"key": "X-Served-By",
"value": "cache-mdw17361-MDW"
},
{
"key": "X-Cache",
"value": "MISS"
},
{
"key": "X-Cache-Hits",
"value": "0"
},
{
"key": "Vary",
"value": "Accept-Encoding"
},
{
"key": "Country",
"value": "CA"
},
{
"key": "Strict-Transport-Security",
"value": "max-age=31536000; includeSubDomains; preload"
}
],
"cookie": [
],
"body": "{\n \"response\": {\n \"result\": {\n \"accounts_aging\": {\n \"accounts\": [\n {\n \"0-30\": {\n \"amount\": \"3830.00\",\n \"code\": \"USD\"\n },\n \"31-60\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"61-90\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"91+\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"email\": \"first@company.com\",\n \"fname\": \"Nicolas\",\n \"lname\": \"one\",\n \"organization\": \"first company\",\n \"total\": {\n \"amount\": \"3830.00\",\n \"code\": \"USD\"\n },\n \"userid\": 31006\n },\n {\n \"0-30\": {\n \"amount\": \"50.00\",\n \"code\": \"USD\"\n },\n \"31-60\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"61-90\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"91+\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"email\": \"mwesthofer5i@imdb.com\",\n \"fname\": \"Myrta\",\n \"lname\": \"Westhofer\",\n \"organization\": \"Prosacco Group\",\n \"total\": {\n \"amount\": \"50.00\",\n \"code\": \"USD\"\n },\n \"userid\": 32080\n },\n {\n \"0-30\": {\n \"amount\": \"398.48\",\n \"code\": \"USD\"\n },\n \"31-60\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"61-90\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"91+\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"email\": \"api.freshbooks@gmail.com\",\n \"fname\": \"Ryan\",\n \"lname\": \"Marr\",\n \"organization\": \"Ryan Marr\",\n \"total\": {\n \"amount\": \"398.48\",\n \"code\": \"USD\"\n },\n \"userid\": 75162\n }\n ],\n \"company_name\": \"Postman Sandbox\",\n \"currency_code\": \"USD\",\n \"download_token\": \"eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhY2NvdW50aWQiOiJ3a01kMmciLCJ1c2VyaWQiOjMxMDA0LCJjb250YWN0aWQiOi0xLCJsZXZlbCI6LTIwLCJ0eXBlIjoicmVwb3J0Iiwib2JqZWN0aWQiOiJhY2NvdW50c19hZ2luZyIsInBhcmFtcyI6eyJlbmRfZGF0ZSI6IjIwMTktMDUtMDgiLCJjdXJyZW5jeV9jb2RlIjoiVVNEIn0sImlhdCI6MTU1NzM0NjM4OCwiZXhwIjoxNTU5OTM4Mzg4fQ.Usasm7HQKxakFm5gFDAYMez__vLM5_VETtWdvdqJMeQ\",\n \"end_date\": \"2019-05-08\",\n \"totals\": {\n \"0-30\": {\n \"amount\": \"4278.48\",\n \"code\": \"USD\"\n },\n \"31-60\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"61-90\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"91+\": {\n \"amount\": \"0.00\",\n \"code\": \"USD\"\n },\n \"total\": {\n \"amount\": \"4278.48\",\n \"code\": \"USD\"\n }\n }\n }\n }\n }\n}"
}
]
}