Generate IRN Bulk#
Generate IRN(s) API supports creation of bulk e-invoices, as opposed to its basic counterpart. Create e-invoice in bulk is an asynchronous API, hence will give a task ID in response.
Given a task ID, you could fetch the task status using Status API. In order to download the result, you would need to use Download API.
Along with generation of IRNs, optionally you will be able to generate PDF and send emails to the either self or counter parties.
Route
/enriched/einv/{flynn-version}/{irp}/invoices
- active ‘flynn-version’: v1.0
- method: POST
URL Parameters#
Name | Description | Type |
---|---|---|
flynn-version | version of the API for example, v1.0 |
string |
irp | IRP Provider as per GST registration for e-invoicing | enum (ni1, ni2) |
Headers#
All headers as mentioned in the Enriched E-Invoice API introduction.
Tip
The only valid values for the header keys Content-Type
and accept
must have to be application/json
.
Request#
Body consists of two sections, “payload” and “meta”.
payload
contains actual E-invoice documents (invoice, credit note or debit note) information for which IRN that has to be generated in a list.
meta
section of the request body consists of meta information for the call i.e., whether to generate PDF or list of email recipients to whom email will be send on successful IRN generation.
The schema of the payload is guided by the NIC portal. Please check the published documentation.
Sample Request Body - with Generate PDF as true, and a list of emails to send the PDF to
{
"payload": [
{
"Version": "1.1",
"Irn": "",
"TranDtls": {
"TaxSch": "GST",
"SupTyp": "B2B",
"RegRev": "N",
"IgstOnIntra": "N"
},
"DocDtls": {
"Typ": "INV",
"No": "Z13F34C3906B148E",
"Dt": "27/10/2020"
},
"SellerDtls": {
"Gstin": "24AAAPI3182M002",
"LglNm": "Acme Widgets Private Limited",
"Addr1": "2345",
"Loc": "Uttar Pradesh",
"Pin": 382424,
"Stcd": "24"
},
"BuyerDtls": {
"Gstin": "27ACBPN2353E1ZX",
"LglNm": "Long Term Enterprises LLP",
"Pos": "27",
"Addr1": "1234",
"Loc": "Pune",
"Pin": 400049,
"Stcd": "27"
},
"ValDtls": {
"AssVal": 0,
"CgstVal": 0,
"SgstVal": 222,
"IgstVal": 0,
"TotInvVal": 0
},
"DispDtls": {
"Nm": "Acme Widgets Private Limited",
"Addr1": "112",
"Addr2": "Acme Building",
"Loc": "ABC",
"Pin": 382424,
"Stcd": "24"
},
"ShipDtls": {
"Gstin": "27ACBPN2353E1ZX",
"LglNm": "Acme Widgets Private Limited",
"TrdNm": "Acme Widgets Private Limited",
"Addr1": "112",
"Addr2": "Acme Building",
"Loc": "ABC",
"Pin": 400049,
"Stcd": "27"
},
"PayDtls": {
"Nm": "Acme Widgets Private Limited",
"Mode": "Cash",
"PayTerm": "100",
"PayInstr": "100",
"CrTrn": "100",
"DirDr": "100",
"CrDay": 100,
"PaymtDue": 900,
"PaidAmt": 100
},
"RefDtls": {
"InvRm": "Remarks",
"DocPerdDtls": {
"InvStDt": "01/09/2020",
"InvEndDt": "01/09/2020"
}
},
"ExpDtls": {
"ShipBNo": "shpbill123",
"ShipBDt": "01/09/2020",
"Port": "INYNL6",
"RefClm": "N",
"ForCur": "INR",
"CntCode": "IN",
"ExpDuty": 0
},
"ItemList": [
{
"SlNo": "1",
"PrdDesc": "Acme product",
"IsServc": "N",
"HsnCd": "33052000",
"UnitPrice": 1631.36,
"TotAmt": 897.8,
"AssAmt": 500.0,
"GstRt": 18.0,
"TotItemVal": 0.0,
"Qty": 0,
"FreeQty": 30.0,
"Unit": "OTH",
"Discount": 48940.8,
"PreTaxVal": 0.0,
"SgstAmt": 0.0,
"CgstAmt": 0.0,
"IgstAmt": 100.0,
"CesRt": 0.0,
"CesAmt": 0.0,
"StateCesRt": 0,
"StateCesAmt": 0,
"StateCesNonAdvlAmt": 0,
"CesNonAdvlAmt": 0.0,
"OthChrg": 0.0
},
{
"SlNo": "2",
"PrdDesc": "Acme product",
"IsServc": "N",
"HsnCd": "33052000",
"UnitPrice": 1631.36,
"TotAmt": 897.8,
"AssAmt": 500.0,
"GstRt": 18.0,
"TotItemVal": 0.0,
"Qty": 0,
"FreeQty": 30.0,
"Unit": "OTH",
"Discount": 48940.8,
"PreTaxVal": 0.0,
"SgstAmt": 0.0,
"CgstAmt": 0.0,
"IgstAmt": 100.0,
"CesRt": 0.0,
"CesAmt": 0.0,
"StateCesRt": 0,
"StateCesAmt": 0,
"StateCesNonAdvlAmt": 0,
"CesNonAdvlAmt": 0.0,
"OthChrg": 0.0
}
]
}
],
"meta": {
"generatePdf": "Y",
"emailRecipientList": [
"accounts@yourcompany.com"
]
}
}
Response#
200
:#
Successful response will an async task-id
.
Using this task-id
you will be able to fetch the status of the request.
Sample Response Body
{
"data": {
"task-id": "d139aedf-395a-4b6d-a76c-bb2c9bf83098"
}
}
Download API Response:#
Download API response is unique for each API.
Example
{
"data": [
{
"status": true,
"details": "{"AckDt":"2020-08-27 18:28:00","AckNo":122010011139775,"EwbDt":"2020-08-27 18:28:00","EwbNo":201008685293,"EwbValidTill":"2020-08-28 23:59:00","Irn":"f648b3d528bb5e5de18793dd7dcd4587d36ee225ab400a9afadc7f8ebe80908b","Remarks":null,"SignedInvoice":"eyJhbGciOiJSUzI1NiIsImtpZCI6IjExNUY0NDI2NjE3QTc5MzhCRTFCQTA2REJFRTkxQTQyNzU4NEVEQUIiLCJ0eXAiOiJKV1QiLCJ4NXQiOiJFVjlFSm1GNmVUaS1HNkJ0dnVrYVFuV0U3YXMifQ.eyJkYXRhIjoie1wiQWNrTm9cIjoxMjIwMTAwMTExMzk3NzUsXCJBY2tEdFwiOlwiMjAyMC0wOC0yNyAxODoyODowMFwiLFwiSXJuXCI6XCJmNjQ4YjNkNTI4YmI1ZTVkZTE4NzkzZGQ3ZGNkNDU4N2QzNmVlMjI1YWI0MDBhOWFmYWRjN2Y4ZWJlODA5MDhiXCIsXCJWZXJzaW9uXCI6XCIxLjAxXCIsXCJUcmFuRHRsc1wiOntcIlRheFNjaFwiOlwiR1NUXCIsXCJTdXBUeXBcIjpcIkRFWFBcIixcIlJlZ1JldlwiOlwiTlwifSxcIkRvY0R0bHNcIjp7XCJUeXBcIjpcIklOVlwiLFwiTm9cIjpcIk45NzI5MDI3NTk3ODk0MDFcIixcIkR0XCI6XCIyNy8wOC8yMDIwXCJ9LFwiU2VsbGVyRHRsc1wiOntcIkdzdGluXCI6XCIyN0FBQVBJMzE4Mk0wMDJcIixcIkxnbE5tXCI6XCJBY21lIFdpZGdldHMgUHJpdmF0ZSBMaW1pdGVkXCIsXCJBZGRyMVwiOlwiMjM0NVwiLFwiTG9jXCI6XCJVdHRhciBQcmFkZXNoXCIsXCJQaW5cIjo0MDAwNDksXCJTdGNkXCI6XCIyN1wifSxcIkJ1eWVyRHRsc1wiOntcIkdzdGluXCI6XCIyNEFBQVBJMzE4Mk0wMDJcIixcIkxnbE5tXCI6XCJMb25nIFRlcm0gRW50ZXJwcmlzZXMgTExQXCIsXCJQb3NcIjpcIjI0XCIsXCJBZGRyMVwiOlwiMTIzNFwiLFwiTG9jXCI6XCJQdW5lXCIsXCJQaW5cIjozODIxNzAsXCJTdGNkXCI6XCIyNFwifSxcIkRpc3BEdGxzXCI6e1wiTm1cIjpcIkFjbWUgV2lkZ2V0cyBQcml2YXRlIExpbWl0ZWRcIixcIkFkZHIxXCI6XCIxMTJcIixcIkFkZHIyXCI6XCJBY21lIEJ1aWxkaW5nXCIsXCJMb2NcIjpcIkFCQ1wiLFwiUGluXCI6NDAwMDQ5LFwiU3RjZFwiOlwiMjdcIn0sXCJTaGlwRHRsc1wiOntcIkdzdGluXCI6XCIyN0FBQVBJMzE4Mk0wMDJcIixcIkxnbE5tXCI6XCJBY21lIFdpZGdldHMgUHJpdmF0ZSBMaW1pdGVkXCIsXCJUcmRObVwiOlwiQWNtZSBXaWRnZXRzIFByaXZhdGUgTGltaXRlZFwiLFwiQWRkcjFcIjpcIjExMlwiLFwiQWRkcjJcIjpcIkFjbWUgQnVpbGRpbmdcIixcIkxvY1wiOlwiQUJDXCIsXCJQaW5cIjo0MDAwNDksXCJTdGNkXCI6XCIyN1wifSxcIkl0ZW1MaXN0XCI6W3tcIkl0ZW1Ob1wiOjEsXCJTbE5vXCI6XCIxXCIsXCJJc1NlcnZjXCI6XCJOXCIsXCJQcmREZXNjXCI6XCJBY21lIHByb2R1Y3RcIixcIkhzbkNkXCI6XCIxMDAxXCIsXCJRdHlcIjoxLFwiVW5pdFwiOlwiQkFHXCIsXCJVbml0UHJpY2VcIjoyNTAwMDAwLFwiVG90QW10XCI6MjUwMDAwMCxcIkRpc2NvdW50XCI6MCxcIkFzc0FtdFwiOjI1MDAwMDAsXCJHc3RSdFwiOjE4LFwiSWdzdEFtdFwiOjQ1MDAwMCxcIkNnc3RBbXRcIjowLFwiU2dzdEFtdFwiOjAsXCJUb3RJdGVtVmFsXCI6Mjk1MDAwMH1dLFwiVmFsRHRsc1wiOntcIkFzc1ZhbFwiOjI1MDAwMDAsXCJDZ3N0VmFsXCI6MCxcIlNnc3RWYWxcIjowLFwiSWdzdFZhbFwiOjQ1MDAwMCxcIlRvdEludlZhbFwiOjI5NTAwMDB9LFwiUGF5RHRsc1wiOntcIk5tXCI6XCJBY21lIFdpZGdldHMgUHJpdmF0ZSBMaW1pdGVkXCIsXCJNb2RlXCI6XCJDYXNoXCIsXCJQYXlUZXJtXCI6XCIxMDBcIixcIlBheUluc3RyXCI6XCIxMDBcIixcIkNyVHJuXCI6XCIxMDBcIixcIkRpckRyXCI6XCIxMDBcIixcIkNyRGF5XCI6MTAwLFwiUGFpZEFtdFwiOjEwMCxcIlBheW10RHVlXCI6OTAwfSxcIlJlZkR0bHNcIjp7XCJJbnZSbVwiOlwiUmVtYXJrc1wiLFwiRG9jUGVyZER0bHNcIjp7XCJJbnZTdER0XCI6XCIwMS8wNy8yMDIwXCIsXCJJbnZFbmREdFwiOlwiMDEvMDcvMjAyMFwifX0sXCJFeHBEdGxzXCI6e1wiU2hpcEJOb1wiOlwic2hwYmlsbDEyM1wiLFwiU2hpcEJEdFwiOlwiMDEvMDcvMjAyMFwiLFwiUG9ydFwiOlwiSU5WMTIzXCIsXCJSZWZDbG1cIjpcIk5cIixcIkZvckN1clwiOlwiSU5SXCIsXCJDbnRDb2RlXCI6XCJJTlwiLFwiRXhwRHV0eVwiOjB9LFwiRXdiRHRsc1wiOntcIlRyYW5zSWRcIjpcIjI3QUFBUEkzMTgyTTAwMlwiLFwiVHJhbnNOYW1lXCI6XCJEcml2ZXJcIixcIlRyYW5zTW9kZVwiOlwiMVwiLFwiRGlzdGFuY2VcIjo1LFwiVHJhbnNEb2NOb1wiOlwiMjAvMjJcIixcIlZlaE5vXCI6XCJLQTUxRVMxMTIyXCIsXCJWZWhUeXBlXCI6XCJPXCJ9fSIsImlzcyI6Ik5JQyJ9.JriAB18OpCut8caZjh2kAKSceLPVwmDONquN5YvU6st3IG3BQepjuGgoChMN3-fUHELp9GYK21GhR1cE83jY2jGB2TADj5CW48HSCe4FVqxlAnbGCsd9G805ROC9FcK29H_8fUP5Y_VZFdbXPKTYivgrxSld-FhFZ3pQw9-21C8LxWuVIezPhNCsfGg8KgrdRu2U7KqpeBcdqnkVcfeE3oaSgVq_l-2bQvgobPvetanc3ur2B0bCbrvn9Fu7XZjKUdJTiNuVtC3K1aMLdVilvf5t4eO3h-Oijx9vSJXYkN90wDrHW2lVXt4hCBEeW0jwLtzP7wnTZ-lBm3J7tz2b7g","SignedQRCode":"eyJhbGciOiJSUzI1NiIsImtpZCI6IjExNUY0NDI2NjE3QTc5MzhCRTFCQTA2REJFRTkxQTQyNzU4NEVEQUIiLCJ0eXAiOiJKV1QiLCJ4NXQiOiJFVjlFSm1GNmVUaS1HNkJ0dnVrYVFuV0U3YXMifQ.eyJkYXRhIjoie1wiU2VsbGVyR3N0aW5cIjpcIjI3QUFBUEkzMTgyTTAwMlwiLFwiQnV5ZXJHc3RpblwiOlwiMjRBQUFQSTMxODJNMDAyXCIsXCJEb2NOb1wiOlwiTjk3MjkwMjc1OTc4OTQwMVwiLFwiRG9jVHlwXCI6XCJJTlZcIixcIkRvY0R0XCI6XCIyNy8wOC8yMDIwXCIsXCJUb3RJbnZWYWxcIjoyOTUwMDAwLFwiSXRlbUNudFwiOjEsXCJNYWluSHNuQ29kZVwiOlwiMTAwMVwiLFwiSXJuXCI6XCJmNjQ4YjNkNTI4YmI1ZTVkZTE4NzkzZGQ3ZGNkNDU4N2QzNmVlMjI1YWI0MDBhOWFmYWRjN2Y4ZWJlODA5MDhiXCJ9IiwiaXNzIjoiTklDIn0.HgppxgAWdMqiB4hjX8qinf0id7CEna8dXq2VRZ8VQryee32ICT2OlMN6wd4vv5Bh7bD2AZZed7do8hhyqqvsFE_TeIWnElv1a80JbEjHyFg2lbvPm8nkjQDSgPX8_w39uHgt2PH0mDm_NNvNh7ps5VmGjqxoUpDP8lT7aLfQ_J-8HrKhU2dOQ6amBimf_JLg28Fhsd2U5asGzGn_cx-9WKFIu0VSLgAQ5hj7yGQlprPibrNVWNojcArjreM-YY5SFy_aA-Qp_2zn5vzQod0b8qcvyiHGVlrFFSZi4q4ffQaFNGVlS6wJep6I9Pgqh5w-SpiYgcWSYk-D0MhjqAUFTg","Status":"ACT"}",
"pdf": "e278b407391b2b26d5b69781a523b332171e9a000ffef45002673ad131add0cd.pdf"
},
{
"status": false,
"error": {
"message": "err-irp-returned-error",
"type": "irp",
"args": {
"details": [
{
"ErrorCode": "2150",
"ErrorMessage": "Duplicate IRN"
}
],
"data": null
}
}
}
]
}
data
key will contain the list of responses for the respective list of documents requested for generating e-invoices.
Each successful item of the list contains, two key - status
and details
.
For successful generation of IRN status
will be True
and details
will contain response as per the ‘E-Invoice API Documentation’ published by NIC.
In the error scenario value of the status
key will be False
and error
will contain error details.
List order will be maintained in the json response.
Notes#
IRP - nic is deprecated. Instead of it please use ni1 or ni2