How to use Postman to generate e-Tax Invoice & e-Receipt via Leceipt API?

If you want to create e-Tax Invoice & e-Receipt documents through your system. This guide will teach you how to create a simple etax document via Postman with sample code for easy understanding.

You can import the collection using the link below. 

https://www.getpostman.com/collections/e42fe4deea6b7517f7ab



1. Generate API Key

This API key will be used to connect the API to the Leceipt system. The method for generating it is in the link below.

How to generate an API Key: https://www.leceipt.com/docs/etax/api-key 


2. Provide information

Provide important information in order to create documents on Leceipt. You can see examples of information on Github

Customer

Structure

Parameters Require Type Meaning
name yes string Seller name
buildingNumber yes string Building Number
address yes string Address
streetprefix no string Street Prefix
streetName no string Street Name
subDistrictPrefix no string Sub-District Prefix
subDistrictCode yes string Sub-District Code
districtPrefix no string District Prefix
districtCode yes string District Code
provincePrefix no string Province Prefix
provinceCode yes string Province Code
postcode yes string Postcode
branchNumber yes string Branch Number
taxNumberType yes string Tax Number Type
taxId yes string Tax Id
phone no string Phone number
email no string Email
unstructure yes boolean Specify “false” if it is a structure address.

Example

{ 
    "customer": { 
        "name": "Buyer Test Co.,LTD.", 
        "addressLineOne": "999 Moo 999 Sathorn Rd. 99", 
        "addressLineTwo": "Silom BanRak Bangkok", 
        "countryName": "Thailand", 
        "postcode": "10500", 
        "branchNumber": "00000", 
        "taxNumberType": "TXID", 
        "taxId": "1234567890123", 
        "phone": "0812345678", 
        "email": "[email protected]", 
        "unstructure": true 
    } 
} 

Unstructure

Parameters Require Type Meaning
name yes string Seller name
addressLineOne yes string Address Line One
addressLineTwo no string Address Line Two
postcode yes string Postcode
countryName no string Country
branchNumber yes string Branch Number
taxNumberType yes string Tax Number Type
taxId yes string Tax Id
phone no string Phone number
email no string Email
unstructure no string Specify “true” if it is an unstructure address.

Example

{ 
    "customer": { 
        "name": "Buyer Test Co.,LTD.", 
        "buildingNumber": "99",
        "address": "Moo 99",
        "streetName": "Sathorn 99",
        "branchNumber": "00000",
        "subDistrictCode": "100402",
        "districtCode": "1004",
        "provinceCode": "10",
        "postcode": "10500",
        "taxNumberType": "TXID",
        "taxId": "1234567890123", 
        "phone": "0812345678", 
        "email": "[email protected]",
        "unstructure": false
    } 
} 

items

This parameter is an Array. If the document contains multiple items or services, add an Object to this Array manually.

Parameters Require Type Meaning
number yes number Order of goods or services
description yes string Product or service details
quantity yes number Number of products
unitName no string Product unit
price yes number Price of goods or services
discount no number Product or service discounts
percentVat yes number The item’s tax percentage includes, if it’s a tax-exempt item, indicate -1, if it’s a 0% tax item, indicate 0, if it’s a 7% tax item, specify 7.

Example 

{ 
    "items": [ 
        { 
            "number": 1, 
            "description": "Food and beverage", 
            "quantity": 1, 
            "unitName": "EA", 
            "price": 1500, 
            "discount": 0, 
            "percentVat": 0 
        }, 
        { 
            "number": 2, 
            "description": "Food and beverage", 
            "quantity": 1, 
            "unitName": "", 
            "price": 1000, 
            "discount": 0, 
            "percentVat": 7 
        } 
    ] 
} 

refer  

Refer here refers to the reference document. If no documents are issued in lieu of the original This section is not required to be filled out. 

Parameters Require Type Meaning
number yes string
Reference document number
dateBE yes string Date, month, year (B.E.) the document was issued to refer to.
reasonCode yes string Reason Code
specificReason yes (ถ้า reasonCode เป็น TIVC99) string Other reason

ตัวอย่าง 

{ 
    "refer": { 
        "number": "TIV20210300000",
        "dateBE": "18/03/2564",
        "reasonCode": "TIVC01"
    }
} 

data 

Parameters Require Type Meaning
number yes string Receipt/Tax Invoice No.
reference no string เลขที่อ้างอิง
dateBE yes string วัน เดือน ปี (พ.ศ.) ที่ออกใบเสร็จรับเงิน/ใบกำกับภาษี
includeVat no boolean ราคาสินค้าหรือบริการรวม Vat แล้ว includeVat=true, ราคาสินค้าหรือบริการยังไม่รวม Vat includeVat=false (default)
customer yes object รายละเอียดผู้ซื้อสินค้าหรือบริการ
items yes array รายละเอียดสินค้าหรือบริการ
language no string ภาษา (ประกอบด้วย th (ภาษาไทย) (default) กับ en (ภาษาอังกฤษ)
discount no number ส่วนลดรวม
note no string หมายเหตุ ที่ต้องการแสดงในใบเสร็จรับเงิน/ใบกำกับภาษี
receivedBy no string ชื่อผู้รับเงิน
reIssue no boolean หากออกเอกสารแทนใบเดิม ให้ระบุเป็น true หากไม่ ให้ระบุเป็น false (default)
refer yes (ถ้า reIssue เป็น true) object เอกสารอ้างถึง

ตัวอย่าง 

{ 
    "number": "TIV20210300001", 
    "dateBE": "23/03/2564", 
    "includeVat": false, 
    "items": [ 
        { 
            "number": 1, 
            "description": "Food and beverage", 
            "quantity": 1, 
            "unitName": "EA", 
            "price": 1500, 
            "discount": 0, 
            "percentVat": 0 
        }, 
        { 
            "number": 2, 
            "description": "Food and beverage", 
            "quantity": 1, 
            "unitName": "", 
            "price": 1000, 
            "discount": 0, 
            "percentVat": 7 
        } 
    ], 
    "discount": 0, 
    "language": "th", 
    "customer": { 
        "name": "Buyer Test Co.,LTD.", 
        "buildingNumber": "99", 
        "address": "Moo 99", 
        "streetName": "Sathorn 99", 
        "branchNumber": "00000", 
        "subDistrictCode": "100402", 
        "districtCode": "1004", 
        "provinceCode": "10", 
        "postcode": "10500", 
        "taxNumberType": "TXID", 
        "taxId": "1234567890123", 
        "phone": "0812345678", 
        "email": "[email protected]", 
        "unstructure": false 
    }, 
    "note": "Test Notes
", 
    "receivedBy": "Somchai", 
    "reIssue": true, 
    "refer": { 
        "number": "TIV20210300000", 
        "dateBE": "18/03/2564", 
        "reasonCode": "TIVC01" 
    }, 
    "reference": "" 
} 

3. Send Request to Postman

Endpoint: https://api.leceipt.com/etax/documents/receipts-taxinvoices?api-version=2022-07-12

Method: Post

Copy the endpoint above and put it in the Postman, put the API-Key in the Headers and the data in step 2. Put it in the Body and select raw.

Example

Response: 


Once the request has been submitted successfully, the Leceipt system will create a document. Deemed to be completed.

But if you want to download the pdf file, see the next step. 


4. Save FileId for Download

Endpoint: https://api.leceipt.com/etax/jobs/{id} 

Method: Get 

Send a get request to the endpoint above with the id taken from the response in step 3. 

Example

Put this id at the end of the endpoint (don’t put ” around the id). 

Response: 

When you get a response, use fileId in the next step. 


5. Download PDF file

Endpoint: https://api.leceipt.com/etax/files/{fileId}/?api-version=2022-07-12 

Method: Get 

The fileId is taken from the response in clause 4. 

Example

Example

Response: