PureBasic / New FreshBooks / Single Checkout Link
Back to Collection Items
IncludeFile "CkJsonObject.pb"
IncludeFile "CkHttp.pb"
IncludeFile "CkHttpResponse.pb"
Procedure ChilkatExample()
; This example assumes the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
http.i = CkHttp::ckCreate()
If http.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success.i
; Use this online tool to generate code from sample JSON: Generate Code to Create JSON
; The following JSON is sent in the request body.
; {
; "item_id": "147778",
; "amount": "100",
; "currency": "CAD",
; "note": "Thank you for your Business",
; "is_active": true,
; "send_admin_receipt": true,
; "created_at": "2020-06-26",
; "taxes": [
; {
; "name": "HST",
; "amount": 13
; }
; ],
; "item_name": "The Best Doorknob"
; }
json.i = CkJsonObject::ckCreate()
If json.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkJsonObject::ckUpdateString(json,"item_id","147778")
CkJsonObject::ckUpdateString(json,"amount","100")
CkJsonObject::ckUpdateString(json,"currency","CAD")
CkJsonObject::ckUpdateString(json,"note","Thank you for your Business")
CkJsonObject::ckUpdateBool(json,"is_active",1)
CkJsonObject::ckUpdateBool(json,"send_admin_receipt",1)
CkJsonObject::ckUpdateString(json,"created_at","2020-06-26")
CkJsonObject::ckUpdateString(json,"taxes[0].name","HST")
CkJsonObject::ckUpdateInt(json,"taxes[0].amount",13)
CkJsonObject::ckUpdateString(json,"item_name","The Best Doorknob")
CkHttp::ckSetRequestHeader(http,"Authorization","Bearer")
resp.i = CkHttp::ckPostJson3(http,"https://api.freshbooks.com/payments/account/{{accountid}}/checkout-links","application/json",json)
If CkHttp::ckLastMethodSuccess(http) = 0
Debug CkHttp::ckLastErrorText(http)
CkHttp::ckDispose(http)
CkJsonObject::ckDispose(json)
ProcedureReturn
EndIf
Debug Str(CkHttpResponse::ckStatusCode(resp))
Debug CkHttpResponse::ckBodyStr(resp)
CkHttpResponse::ckDispose(resp)
CkHttp::ckDispose(http)
CkJsonObject::ckDispose(json)
ProcedureReturn
EndProcedure
Curl Command
curl -X POST
-H "Authorization: Bearer"
-d '{
"item_id": "147778",
"amount": "100",
"currency": "CAD",
"note": "Thank you for your Business",
"is_active": true,
"send_admin_receipt": true,
"created_at": "2020-06-26",
"taxes": [{"name":"HST","amount":13}],
"item_name": "The Best Doorknob"
}'
https://api.freshbooks.com/payments/account/{{accountid}}/checkout-links
Postman Collection Item JSON
{
"name": "Single Checkout Link",
"request": {
"auth": {
"type": "noauth"
},
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer",
"type": "text",
"disabled": true
}
],
"body": {
"mode": "raw",
"raw": "{\n \"item_id\": \"147778\",\n \"amount\": \"100\",\n \"currency\": \"CAD\",\n \"note\": \"Thank you for your Business\",\n \"is_active\": true,\n \"send_admin_receipt\": true,\n \"created_at\": \"2020-06-26\",\n \"taxes\": [{\"name\":\"HST\",\"amount\":13}],\n \"item_name\": \"The Best Doorknob\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "https://api.freshbooks.com/payments/account/{{accountid}}/checkout-links",
"protocol": "https",
"host": [
"api",
"freshbooks",
"com"
],
"path": [
"payments",
"account",
"{{accountid}}",
"checkout-links"
]
}
},
"response": [
]
}