Chilkat Online Tools

DataFlex / New FreshBooks / Create Single Invoice Profile

Back to Collection Items

Use ChilkatAx-9.5.0-win32.pkg

Procedure Test
    Handle hoHttp
    Boolean iSuccess
    Variant vJson
    Handle hoJson
    Variant vResp
    Handle hoResp
    Variant vSbResponseBody
    Handle hoSbResponseBody
    Handle hoJResp
    Integer iRespStatusCode
    String sAccounting_systemid
    String sAddress
    String sAmount
    String sCode
    Boolean iAuto_bill
    String sBill_gateway
    String sCity
    String sInvoice_profileCode
    String sCountry
    String sCreate_date
    String sCurrency_code
    Integer iCustomerid
    String sDescription
    Boolean iDisable
    String sDiscount_totalAmount
    String sDiscount_totalCode
    String sDiscount_value
    Integer iDue_offset_days
    String sExt_archive
    String sFname
    String sFrequency
    Integer iId
    Boolean iInclude_unbilled_time
    String sLanguage
    String sLname
    String sNotes
    Integer iNumberRecurring
    Integer iOccurrences_to_date
    String sOrganization
    Integer iOwnerid
    String sPayment_details
    String sPo_number
    Integer iProfileid
    String sProvince
    Boolean iRequire_auto_bill
    String sRetainer_id
    Boolean iSend_email
    Boolean iSend_gmail
    String sStreet
    String sStreet2
    String sTerms
    String sTotal_accrued_revenue
    String sUpdated
    String sVat_name
    String sVat_number
    Integer iVis_state
    String sTemp1
    Boolean bTemp1

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

    Get Create (RefClass(cComChilkatHttp)) To hoHttp
    If (Not(IsComObjectCreated(hoHttp))) Begin
        Send CreateComObject of hoHttp
    End

    // Use this online tool to generate code from sample JSON: Generate Code to Create JSON

    // The following JSON is sent in the request body.

    // {
    //   "invoice_profile": {
    //     "customerid": 123,
    //     "create_date": "2019-04-25",
    //     "frequency": "m",
    //     "numberRecurring": 3,
    //     "lines": [
    //       {
    //         "name": "Test Item",
    //         "qty": "1",
    //         "unit_cost": {
    //           "amount": "27.00"
    //         }
    //       }
    //     ]
    //   }
    // }

    Get Create (RefClass(cComChilkatJsonObject)) To hoJson
    If (Not(IsComObjectCreated(hoJson))) Begin
        Send CreateComObject of hoJson
    End
    Get ComUpdateInt Of hoJson "invoice_profile.customerid" 123 To iSuccess
    Get ComUpdateString Of hoJson "invoice_profile.create_date" "2019-04-25" To iSuccess
    Get ComUpdateString Of hoJson "invoice_profile.frequency" "m" To iSuccess
    Get ComUpdateInt Of hoJson "invoice_profile.numberRecurring" 3 To iSuccess
    Get ComUpdateString Of hoJson "invoice_profile.lines[0].name" "Test Item" To iSuccess
    Get ComUpdateString Of hoJson "invoice_profile.lines[0].qty" "1" To iSuccess
    Get ComUpdateString Of hoJson "invoice_profile.lines[0].unit_cost.amount" "27.00" To iSuccess

    // Adds the "Authorization: Bearer <access_token>" header.
    Set ComAuthToken Of hoHttp To "<access_token>"
    Send ComSetRequestHeader To hoHttp "Content-Type" "application/json"

    Get pvComObject of hoJson to vJson
    Get ComPostJson3 Of hoHttp "https://api.freshbooks.com/accounting/account/{{accountId}}/invoice_profiles/invoice_profiles" "application/json" vJson To vResp
    If (IsComObject(vResp)) Begin
        Get Create (RefClass(cComChilkatHttpResponse)) To hoResp
        Set pvComObject Of hoResp To vResp
    End
    Get ComLastMethodSuccess Of hoHttp To bTemp1
    If (bTemp1 = False) Begin
        Get ComLastErrorText Of hoHttp To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Get Create (RefClass(cComChilkatStringBuilder)) To hoSbResponseBody
    If (Not(IsComObjectCreated(hoSbResponseBody))) Begin
        Send CreateComObject of hoSbResponseBody
    End
    Get pvComObject of hoSbResponseBody to vSbResponseBody
    Get ComGetBodySb Of hoResp vSbResponseBody To iSuccess

    Get Create (RefClass(cComChilkatJsonObject)) To hoJResp
    If (Not(IsComObjectCreated(hoJResp))) Begin
        Send CreateComObject of hoJResp
    End
    Get pvComObject of hoSbResponseBody to vSbResponseBody
    Get ComLoadSb Of hoJResp vSbResponseBody To iSuccess
    Set ComEmitCompact Of hoJResp To False

    Showln "Response Body:"
    Get ComEmit Of hoJResp To sTemp1
    Showln sTemp1

    Get ComStatusCode Of hoResp To iRespStatusCode
    Showln "Response Status Code = " iRespStatusCode
    If (iRespStatusCode >= 400) Begin
        Showln "Response Header:"
        Get ComHeader Of hoResp To sTemp1
        Showln sTemp1
        Showln "Failed."
        Send Destroy of hoResp
        Procedure_Return
    End

    Send Destroy of hoResp

    // Sample JSON response:
    // (Sample code for parsing the JSON response is shown below)

    // {
    //   "response": {
    //     "result": {
    //       "invoice_profile": {
    //         "accounting_systemid": "wkMd2g",
    //         "address": "",
    //         "amount": {
    //           "amount": "0.00",
    //           "code": "USD"
    //         },
    //         "auto_bill": false,
    //         "bill_gateway": null,
    //         "city": "",
    //         "code": "",
    //         "country": "Canada",
    //         "create_date": "2019-04-25",
    //         "currency_code": "USD",
    //         "customerid": 31006,
    //         "description": "",
    //         "disable": false,
    //         "discount_total": {
    //           "amount": "0.00",
    //           "code": "USD"
    //         },
    //         "discount_value": "0",
    //         "due_offset_days": 0,
    //         "ext_archive": null,
    //         "fname": "Nicolas",
    //         "frequency": "m",
    //         "id": 488,
    //         "include_unbilled_time": false,
    //         "language": "en",
    //         "lname": "one",
    //         "notes": "",
    //         "numberRecurring": 3,
    //         "occurrences_to_date": 0,
    //         "organization": "first company",
    //         "ownerid": 1,
    //         "payment_details": "",
    //         "po_number": null,
    //         "profileid": 488,
    //         "province": "",
    //         "require_auto_bill": false,
    //         "retainer_id": null,
    //         "send_email": true,
    //         "send_gmail": false,
    //         "street": "",
    //         "street2": "",
    //         "terms": null,
    //         "total_accrued_revenue": null,
    //         "updated": "2019-04-24 14:17:14",
    //         "vat_name": "",
    //         "vat_number": "",
    //         "vis_state": 0
    //       }
    //     }
    //   }
    // }

    // Sample code for parsing the JSON response...
    // Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code

    Get ComStringOf Of hoJResp "response.result.invoice_profile.accounting_systemid" To sAccounting_systemid
    Get ComStringOf Of hoJResp "response.result.invoice_profile.address" To sAddress
    Get ComStringOf Of hoJResp "response.result.invoice_profile.amount.amount" To sAmount
    Get ComStringOf Of hoJResp "response.result.invoice_profile.amount.code" To sCode
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.auto_bill" To iAuto_bill
    Get ComStringOf Of hoJResp "response.result.invoice_profile.bill_gateway" To sBill_gateway
    Get ComStringOf Of hoJResp "response.result.invoice_profile.city" To sCity
    Get ComStringOf Of hoJResp "response.result.invoice_profile.code" To sInvoice_profileCode
    Get ComStringOf Of hoJResp "response.result.invoice_profile.country" To sCountry
    Get ComStringOf Of hoJResp "response.result.invoice_profile.create_date" To sCreate_date
    Get ComStringOf Of hoJResp "response.result.invoice_profile.currency_code" To sCurrency_code
    Get ComIntOf Of hoJResp "response.result.invoice_profile.customerid" To iCustomerid
    Get ComStringOf Of hoJResp "response.result.invoice_profile.description" To sDescription
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.disable" To iDisable
    Get ComStringOf Of hoJResp "response.result.invoice_profile.discount_total.amount" To sDiscount_totalAmount
    Get ComStringOf Of hoJResp "response.result.invoice_profile.discount_total.code" To sDiscount_totalCode
    Get ComStringOf Of hoJResp "response.result.invoice_profile.discount_value" To sDiscount_value
    Get ComIntOf Of hoJResp "response.result.invoice_profile.due_offset_days" To iDue_offset_days
    Get ComStringOf Of hoJResp "response.result.invoice_profile.ext_archive" To sExt_archive
    Get ComStringOf Of hoJResp "response.result.invoice_profile.fname" To sFname
    Get ComStringOf Of hoJResp "response.result.invoice_profile.frequency" To sFrequency
    Get ComIntOf Of hoJResp "response.result.invoice_profile.id" To iId
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.include_unbilled_time" To iInclude_unbilled_time
    Get ComStringOf Of hoJResp "response.result.invoice_profile.language" To sLanguage
    Get ComStringOf Of hoJResp "response.result.invoice_profile.lname" To sLname
    Get ComStringOf Of hoJResp "response.result.invoice_profile.notes" To sNotes
    Get ComIntOf Of hoJResp "response.result.invoice_profile.numberRecurring" To iNumberRecurring
    Get ComIntOf Of hoJResp "response.result.invoice_profile.occurrences_to_date" To iOccurrences_to_date
    Get ComStringOf Of hoJResp "response.result.invoice_profile.organization" To sOrganization
    Get ComIntOf Of hoJResp "response.result.invoice_profile.ownerid" To iOwnerid
    Get ComStringOf Of hoJResp "response.result.invoice_profile.payment_details" To sPayment_details
    Get ComStringOf Of hoJResp "response.result.invoice_profile.po_number" To sPo_number
    Get ComIntOf Of hoJResp "response.result.invoice_profile.profileid" To iProfileid
    Get ComStringOf Of hoJResp "response.result.invoice_profile.province" To sProvince
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.require_auto_bill" To iRequire_auto_bill
    Get ComStringOf Of hoJResp "response.result.invoice_profile.retainer_id" To sRetainer_id
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.send_email" To iSend_email
    Get ComBoolOf Of hoJResp "response.result.invoice_profile.send_gmail" To iSend_gmail
    Get ComStringOf Of hoJResp "response.result.invoice_profile.street" To sStreet
    Get ComStringOf Of hoJResp "response.result.invoice_profile.street2" To sStreet2
    Get ComStringOf Of hoJResp "response.result.invoice_profile.terms" To sTerms
    Get ComStringOf Of hoJResp "response.result.invoice_profile.total_accrued_revenue" To sTotal_accrued_revenue
    Get ComStringOf Of hoJResp "response.result.invoice_profile.updated" To sUpdated
    Get ComStringOf Of hoJResp "response.result.invoice_profile.vat_name" To sVat_name
    Get ComStringOf Of hoJResp "response.result.invoice_profile.vat_number" To sVat_number
    Get ComIntOf Of hoJResp "response.result.invoice_profile.vis_state" To iVis_state


End_Procedure

Curl Command

curl -X POST
	-H "Authorization: Bearer <access_token>"
	-H "Content-Type: application/json"
	-d '{
  "invoice_profile": {
    "customerid": {{customerId}},
    "create_date": "2019-04-25",
    "frequency": "m", 
    "numberRecurring": 3,
    "lines": [
      {
        "name": "Test Item",
        "qty": "1",
        "unit_cost": {
          "amount": "27.00"
        }
      }
     ]
   }
 }'
https://api.freshbooks.com/accounting/account/{{accountId}}/invoice_profiles/invoice_profiles

Postman Collection Item JSON

{
  "name": "Create Single Invoice Profile",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "let jsonData = JSON.parse(responseBody);",
          "pm.environment.set(\"customerId\", jsonData.response.result.invoice_profile[0].customerid);"
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "value": "application/json",
        "type": "text"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n  \"invoice_profile\": {\n    \"customerid\": {{customerId}},\n    \"create_date\": \"2019-04-25\",\n    \"frequency\": \"m\", \n    \"numberRecurring\": 3,\n    \"lines\": [\n      {\n        \"name\": \"Test Item\",\n        \"qty\": \"1\",\n        \"unit_cost\": {\n          \"amount\": \"27.00\"\n        }\n      }\n     ]\n   }\n }\n"
    },
    "url": {
      "raw": "https://api.freshbooks.com/accounting/account/{{accountId}}/invoice_profiles/invoice_profiles",
      "protocol": "https",
      "host": [
        "api",
        "freshbooks",
        "com"
      ],
      "path": [
        "accounting",
        "account",
        "{{accountId}}",
        "invoice_profiles",
        "invoice_profiles"
      ]
    },
    "description": "Creates a monthly recurring invoice that sends 3 invoices in total."
  },
  "response": [
    {
      "name": "Create Single Invoice Profile - Invalid Date",
      "originalRequest": {
        "method": "POST",
        "header": [
          {
            "key": "Content-Type",
            "value": "application/json",
            "type": "text"
          }
        ],
        "body": {
          "mode": "raw",
          "raw": "{\n  \"invoice_profile\": {\n    \"customerid\": {{customerId}},\n    \"create_date\": \"2019-04-20\",\n    \"frequency\": \"m\", \n    \"numberRecurring\": 3\n   }\n }"
        },
        "url": {
          "raw": "https://api.freshbooks.com/accounting/account/{{accountId}}/invoice_profiles/invoice_profiles",
          "protocol": "https",
          "host": [
            "api",
            "freshbooks",
            "com"
          ],
          "path": [
            "accounting",
            "account",
            "{{accountId}}",
            "invoice_profiles",
            "invoice_profiles"
          ]
        }
      },
      "status": "UNPROCESSABLE ENTITY",
      "code": 422,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Server",
          "value": "nginx"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        },
        {
          "key": "X-NewRelic-App-Data",
          "value": "PxQBWV5TCBABVlVSAwEOVlcTGhE1AwE2QgNWEVlbQFtcCxYnRA9QFg1ZWU4DFVdfRgFPCkNFR0gNX0BcCwUGPUAQVwRRVFFBCQxXF14IUAcURFgHDw9dQBJIUU4HHwZXUAIPC1ZRWlYGUw5UAQEGHgJWAU0TUgEAAgYGU1IFCgVVU1EGAhMbAAVdRVY/"
        },
        {
          "key": "Access-Control-Allow-Origin",
          "value": "*"
        },
        {
          "key": "Via",
          "value": "1.1 google"
        },
        {
          "key": "Via",
          "value": "1.1 varnish"
        },
        {
          "key": "Content-Length",
          "value": "303"
        },
        {
          "key": "Accept-Ranges",
          "value": "bytes"
        },
        {
          "key": "Date",
          "value": "Wed, 24 Apr 2019 18:16:19 GMT"
        },
        {
          "key": "Connection",
          "value": "keep-alive"
        },
        {
          "key": "X-Served-By",
          "value": "cache-mdw17369-MDW"
        },
        {
          "key": "X-Cache",
          "value": "MISS"
        },
        {
          "key": "X-Cache-Hits",
          "value": "0"
        },
        {
          "key": "Country",
          "value": "CA"
        },
        {
          "key": "Strict-Transport-Security",
          "value": "max-age=31536000; includeSubDomains; preload"
        }
      ],
      "cookie": [
      ],
      "body": "{\n    \"response\": {\n        \"errors\": [\n            {\n                \"errno\": 16003,\n                \"field\": \"create_date\",\n                \"message\": \"'Create Date' is an invalid value: The date for a new recurring profile must be today or later.\",\n                \"object\": \"invoice_profile\",\n                \"value\": \"2019-04-20\"\n            }\n        ]\n    }\n}"
    },
    {
      "name": "Create Single Invoice Profile",
      "originalRequest": {
        "method": "POST",
        "header": [
          {
            "key": "Content-Type",
            "value": "application/json",
            "type": "text"
          }
        ],
        "body": {
          "mode": "raw",
          "raw": "{\n  \"invoice_profile\": {\n    \"customerid\": {{customerId}},\n    \"create_date\": \"2019-04-25\",\n    \"frequency\": \"m\", \n    \"numberRecurring\": 3\n   }\n }"
        },
        "url": {
          "raw": "https://api.freshbooks.com/accounting/account/{{accountId}}/invoice_profiles/invoice_profiles",
          "protocol": "https",
          "host": [
            "api",
            "freshbooks",
            "com"
          ],
          "path": [
            "accounting",
            "account",
            "{{accountId}}",
            "invoice_profiles",
            "invoice_profiles"
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Server",
          "value": "nginx"
        },
        {
          "key": "Content-Type",
          "value": "application/json"
        },
        {
          "key": "X-NewRelic-App-Data",
          "value": "PxQBWV5TCBABVlVSAwEOVlcTGhE1AwE2QgNWEVlbQFtcCxYnRA9QFg1ZWU4DFVdfRgFPCkNFR0gNX0BcCwUGPUAQVwRRVFFBCQxXF14IUAcURFgHDw9dQBJIUU4HHwZfXAICBlRQUlMGUQtRCAgMHgJWAU0TVARRBlVWVV5VDVcEAQQGBBMbAAVdRVY/"
        },
        {
          "key": "Access-Control-Allow-Origin",
          "value": "*"
        },
        {
          "key": "Expires",
          "value": "Tue, 24 Apr 2018 18:17:14 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": "Transfer-Encoding",
          "value": "chunked"
        },
        {
          "key": "Accept-Ranges",
          "value": "bytes"
        },
        {
          "key": "Date",
          "value": "Wed, 24 Apr 2019 18:17:14 GMT"
        },
        {
          "key": "Connection",
          "value": "keep-alive"
        },
        {
          "key": "X-Served-By",
          "value": "cache-mdw17369-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            \"invoice_profile\": {\n                \"accounting_systemid\": \"wkMd2g\",\n                \"address\": \"\",\n                \"amount\": {\n                    \"amount\": \"0.00\",\n                    \"code\": \"USD\"\n                },\n                \"auto_bill\": false,\n                \"bill_gateway\": null,\n                \"city\": \"\",\n                \"code\": \"\",\n                \"country\": \"Canada\",\n                \"create_date\": \"2019-04-25\",\n                \"currency_code\": \"USD\",\n                \"customerid\": 31006,\n                \"description\": \"\",\n                \"disable\": false,\n                \"discount_total\": {\n                    \"amount\": \"0.00\",\n                    \"code\": \"USD\"\n                },\n                \"discount_value\": \"0\",\n                \"due_offset_days\": 0,\n                \"ext_archive\": null,\n                \"fname\": \"Nicolas\",\n                \"frequency\": \"m\",\n                \"id\": 488,\n                \"include_unbilled_time\": false,\n                \"language\": \"en\",\n                \"lname\": \"one\",\n                \"notes\": \"\",\n                \"numberRecurring\": 3,\n                \"occurrences_to_date\": 0,\n                \"organization\": \"first company\",\n                \"ownerid\": 1,\n                \"payment_details\": \"\",\n                \"po_number\": null,\n                \"profileid\": 488,\n                \"province\": \"\",\n                \"require_auto_bill\": false,\n                \"retainer_id\": null,\n                \"send_email\": true,\n                \"send_gmail\": false,\n                \"street\": \"\",\n                \"street2\": \"\",\n                \"terms\": null,\n                \"total_accrued_revenue\": null,\n                \"updated\": \"2019-04-24 14:17:14\",\n                \"vat_name\": \"\",\n                \"vat_number\": \"\",\n                \"vis_state\": 0\n            }\n        }\n    }\n}"
    }
  ]
}