Chilkat Online Tools

PureBasic / Razorpay APIs / Create an Invoice

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

    CkHttp::setCkBasicAuth(http, 1)
    CkHttp::setCkLogin(http, "username")
    CkHttp::setCkPassword(http, "password")

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

    ; The following JSON is sent in the request body.

    ; {
    ;   "type": "invoice",
    ;   "description": "Domestic invoice for Gaurav Kumar.",
    ;   "partial_payment": true,
    ;   "customer": {
    ;     "name": "Gaurav Kumar",
    ;     "contact": "9876543210",
    ;     "email": "gaurav.kumar@example.com",
    ;     "billing_address": {
    ;       "line1": "Ground FLoor, Millennium Tower, 1st Avenue",
    ;       "line2": "1st Avenue",
    ;       "zipcode": "560001",
    ;       "city": "Bangalore",
    ;       "state": "Karnataka",
    ;       "country": "India"
    ;     },
    ;     "shipping_address": {
    ;       "line1": "3rd FLoor, Nakamura Tower, Bomaye Boulevard",
    ;       "line2": "Baker Street",
    ;       "zipcode": "560001",
    ;       "city": "Bangalore",
    ;       "state": "Karnataka",
    ;       "country": "in"
    ;     }
    ;   },
    ;   "line_items": [
    ;     {
    ;       "name": "Crate of sea weed",
    ;       "description": "Crate of sea weed.",
    ;       "amount": 20000,
    ;       "currency": "INR",
    ;       "quantity": 1
    ;     },
    ;     {
    ;       "item_id": "{item_id}"
    ;     }
    ;   ],
    ;   "sms_notify": 1,
    ;   "email_notify": 1,
    ;   "draft": "1",
    ;   "date": 1588076279,
    ;   "expire_by": 1924991999,
    ;   "receipt": "Receipt No. 1",
    ;   "comment": "Fresh sea weed mowed this morning",
    ;   "terms": "No Returns; No Refunds",
    ;   "notes": {
    ;     "notes_key_1": "Tea, Earl Grey, Hot",
    ;     "notes_key_2": "Tea, Earl Grey… decaf."
    ;   }
    ; }

    json.i = CkJsonObject::ckCreate()
    If json.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkJsonObject::ckUpdateString(json,"type","invoice")
    CkJsonObject::ckUpdateString(json,"description","Domestic invoice for Gaurav Kumar.")
    CkJsonObject::ckUpdateBool(json,"partial_payment",1)
    CkJsonObject::ckUpdateString(json,"customer.name","Gaurav Kumar")
    CkJsonObject::ckUpdateString(json,"customer.contact","9876543210")
    CkJsonObject::ckUpdateString(json,"customer.email","gaurav.kumar@example.com")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.line1","Ground FLoor, Millennium Tower, 1st Avenue")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.line2","1st Avenue")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.zipcode","560001")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.city","Bangalore")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.state","Karnataka")
    CkJsonObject::ckUpdateString(json,"customer.billing_address.country","India")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.line1","3rd FLoor, Nakamura Tower, Bomaye Boulevard")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.line2","Baker Street")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.zipcode","560001")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.city","Bangalore")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.state","Karnataka")
    CkJsonObject::ckUpdateString(json,"customer.shipping_address.country","in")
    CkJsonObject::ckUpdateString(json,"line_items[0].name","Crate of sea weed")
    CkJsonObject::ckUpdateString(json,"line_items[0].description","Crate of sea weed.")
    CkJsonObject::ckUpdateInt(json,"line_items[0].amount",20000)
    CkJsonObject::ckUpdateString(json,"line_items[0].currency","INR")
    CkJsonObject::ckUpdateInt(json,"line_items[0].quantity",1)
    CkJsonObject::ckUpdateString(json,"line_items[1].item_id","{item_id}")
    CkJsonObject::ckUpdateInt(json,"sms_notify",1)
    CkJsonObject::ckUpdateInt(json,"email_notify",1)
    CkJsonObject::ckUpdateString(json,"draft","1")
    CkJsonObject::ckUpdateInt(json,"date",1588076279)
    CkJsonObject::ckUpdateInt(json,"expire_by",1924991999)
    CkJsonObject::ckUpdateString(json,"receipt","Receipt No. 1")
    CkJsonObject::ckUpdateString(json,"comment","Fresh sea weed mowed this morning")
    CkJsonObject::ckUpdateString(json,"terms","No Returns; No Refunds")
    CkJsonObject::ckUpdateString(json,"notes.notes_key_1","Tea, Earl Grey, Hot")
    CkJsonObject::ckUpdateString(json,"notes.notes_key_2","Tea, Earl Grey… decaf.")

    CkHttp::ckSetRequestHeader(http,"Content-Type","application/json")

    resp.i = CkHttp::ckPostJson3(http,"https://api.razorpay.com/v1/invoices","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
	-u 'username:password'
	-H "Content-Type: application/json"
	-d '{
    "type": "invoice",
    "description": "Domestic invoice for Gaurav Kumar.",
    "partial_payment": true,
    "customer": {
        "name": "Gaurav Kumar",
        "contact": "9876543210",
        "email": "gaurav.kumar@example.com",
        "billing_address": {
            "line1": "Ground FLoor, Millennium Tower, 1st Avenue",
            "line2": "1st Avenue",
            "zipcode": "560001",
            "city": "Bangalore",
            "state": "Karnataka",
            "country": "India"
        },
        "shipping_address": {
            "line1": "3rd FLoor, Nakamura Tower, Bomaye Boulevard",
            "line2": "Baker Street",
            "zipcode": "560001",
            "city": "Bangalore",
            "state": "Karnataka",
            "country": "in"
        }
    },
    "line_items": [
        {
            "name": "Crate of sea weed",
            "description": "Crate of sea weed.",
            "amount": 20000,
            "currency": "INR",
            "quantity": 1
        },
        {
            "item_id": "{item_id}"
        }
    ],
    "sms_notify": 1,
    "email_notify": 1,
    "draft": "1",
    "date": 1588076279,
    "expire_by": 1924991999,
    "receipt": "Receipt No. 1",
    "comment": "Fresh sea weed mowed this morning",
    "terms": "No Returns; No Refunds",
    "notes": {
        "notes_key_1": "Tea, Earl Grey, Hot",
        "notes_key_2": "Tea, Earl Grey… decaf."
    }
}'
https://api.razorpay.com/v1/invoices

Postman Collection Item JSON

{
  "name": "Create an Invoice",
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "name": "Content-Type",
        "type": "text",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"type\": \"invoice\",\n    \"description\": \"Domestic invoice for Gaurav Kumar.\",\n    \"partial_payment\": true,\n    \"customer\": {\n        \"name\": \"Gaurav Kumar\",\n        \"contact\": \"9876543210\",\n        \"email\": \"gaurav.kumar@example.com\",\n        \"billing_address\": {\n            \"line1\": \"Ground FLoor, Millennium Tower, 1st Avenue\",\n            \"line2\": \"1st Avenue\",\n            \"zipcode\": \"560001\",\n            \"city\": \"Bangalore\",\n            \"state\": \"Karnataka\",\n            \"country\": \"India\"\n        },\n        \"shipping_address\": {\n            \"line1\": \"3rd FLoor, Nakamura Tower, Bomaye Boulevard\",\n            \"line2\": \"Baker Street\",\n            \"zipcode\": \"560001\",\n            \"city\": \"Bangalore\",\n            \"state\": \"Karnataka\",\n            \"country\": \"in\"\n        }\n    },\n    \"line_items\": [\n        {\n            \"name\": \"Crate of sea weed\",\n            \"description\": \"Crate of sea weed.\",\n            \"amount\": 20000,\n            \"currency\": \"INR\",\n            \"quantity\": 1\n        },\n        {\n            \"item_id\": \"{item_id}\"\n        }\n    ],\n    \"sms_notify\": 1,\n    \"email_notify\": 1,\n    \"draft\": \"1\",\n    \"date\": 1588076279,\n    \"expire_by\": 1924991999,\n    \"receipt\": \"Receipt No. 1\",\n    \"comment\": \"Fresh sea weed mowed this morning\",\n    \"terms\": \"No Returns; No Refunds\",\n    \"notes\": {\n        \"notes_key_1\": \"Tea, Earl Grey, Hot\",\n        \"notes_key_2\": \"Tea, Earl Grey… decaf.\"\n    }\n}"
    },
    "url": {
      "raw": "https://api.razorpay.com/v1/invoices",
      "protocol": "https",
      "host": [
        "api",
        "razorpay",
        "com"
      ],
      "path": [
        "v1",
        "invoices"
      ],
      "query": [
        {
          "key": "count",
          "value": "10",
          "disabled": true
        },
        {
          "key": "skip",
          "value": "10",
          "disabled": true
        }
      ]
    },
    "description": "Create an Invoice using the Create an Invoice API.\n\nSome points to note. You can:\n- Create a blank invoice (with no details at all) in draft state.\n- Update it with necessary information.\n- Issue it at a later time with the Issue Invoice API. Only after the invoice is issued, you will get a short URL. Also, only after the invoice is issued, it can be sent to customers and the corresponding payment can be made against it.\n- Use <a href=\"https://razorpay.com/docs/api/items/\" target=\"_blank\">Items APIs</a> to create items which you can later use as a template to create line items in an invoice.\n\nKnow more about the <a href=\"https://razorpay.com/docs/api/invoices/#create-an-invoice\" target=\"_blank\">Create an Invoice API</a>."
  },
  "response": [
  ]
}