Allow user to get their invoice
by invoice number
Resource information
Response format(s)
JSON
Requires authentication?
Yes using API key
Request Header
Name
Value
Content-Type
application/json
x-api-key
S93Hrwp5w7J9kJRBfFgjAcexLTKvLHBY
Returns
Returns invoice item detail
Response
Field
Type
Description
InvoiceNumber
string
Invoice Number
Quantity
decimal(18,6)
Total
decimal(18,6)
Total amount payable
IssuedDate
DateTime
Date time utc format
DueDate
DateTime
Date time utc format
PaidDate
DateTime
Date time utc format
Type
string
Type Of Invoice
TypeDescription
string
SubTotal
decimal(18,6)
Sub Total
TotalFee
decimal(18,6)
Total Fee
TotalReceivable
decimal(18,6)
Total Receivable
CurrenyCode
string
Currency code of Sell Order
CurrencySymbolic
string
TaxPercent
decimal(18,6)
Tax Percentage
TaxAmount
decimal(18,6)
Tax Amount
Status
string
StatusDescription
string
CreatedTime
DateTime
Date time utc format
UpdatedTime
DateTime
Date time utc format
CurrentPage
int
TotalPage
int
TotalRow
int
ItemsPerPage
int
Response Items
Field
Type
Description
DeviceName
string
Name of Device
Vintage
int
CountryCode
string
Quantity
decimal(18,6)
UnitPrice
decimal(18,6)
TotalPrice
decimal(18,6)
Description
string
Request
Status | ||||
---|---|---|---|---|
|
Response
Success:
language | json |
---|
Table of Contents
Table of Contents | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Changelogs
Version | Date | Changes by | Description of change |
V1.0 |
| Tam Tran |
|
Order Resource
InvoiceNumber string Invoice unique number |
Quantity decimal Quantity |
Status object
Client Invoice Status (Unpaid, WaitingForConfirm, Paid, Expired, Cancelled, Refunded, PartialPayment, PartialPaid, PaymentFollowUp, OfflineManual) |
IssuedDate DateTime Isssued Date |
DueDate DateTime Due Date |
PaidDate DateTime Paid Date |
CreatedTime DateTime Invoices created time |
UpdatedTime DateTime Invoices updated time |
CurrencyCode text Current Code (USD, ..) |
FeeCodeNumber text Fee Code Number |
PayerTaxPercentage decimal Payer tax percentage |
PayeeTaxPercentage decimal Payee tax percentage |
Payer:CompanyName text Payer’s company name |
Payer:RegistrationNumber text Payer’s registration number |
Payer:Address text Payer’s address |
Payer:Country text Payer’s country |
Payee:CompanyName text Payer’s company name |
Payee:RegistrationNumber text Payer’s registration number |
Payee:Address text Payer’s address |
Payee:Country text Payer’s country |
MainInvoice:Total decimal Total price in invoice |
MainInvoice:SubTotal decimal Sub Total price in invoice |
MainInvoice:PayeeTaxAmount decimal Payee Tax Amount in primary invoice |
MainInvoice:PayerTaxAmount decimal Payer Tax Amount in primary invoice |
MainInvoice:Items[n]:Quantity decimal Quantity of rec |
MainInvoice:Items[n]:UnitPrice decimal Price |
MainInvoice:Items[n]:TotalPrice decimal Quantity x UnitPrice |
MainInvoice:Items[n]:Description text Description |
MainInvoice:Items[n]:TransactionDate datetime Transaction Date |
MainInvoice:Items[n]:TransactionId text Transaction Id |
MainInvoice:PayerSubTotal text Payer sub total in primary invoice |
MainInvoice:PayeeSubTotal text Payee sub total in primary invoice |
MainInvoice:PayerSubTotalWithTax text Payer sub total include tax in primary invoice |
MainInvoice:PayeeSubTotalWithTax text Payer sub total include tax in primary invoice |
SplitInvoices array Secondary invoice (have same attribute with MainInvoice) |
Code Block | ||
---|---|---|
| ||
{ "InvoiceNumber": "INV-REAR-2024-09-27-00006", "Quantity": 20.000000, "IssuedDate": "2024-09-27T00:00:00.0000000Z", "DueDate": "2024-10-01T15:59:59.9999999Z", "PaidDate": null, "Status": { "Value": "Unpaid", "Description": "Unpaid" }, "CreatedTime": "2024-09-27T16:30:14.693", "UpdatedTime": "2024-09-27T16:30:14.693", "CurrencyCode": "USD", "FeeCodeNumber": null, "PayerTaxPercentage": 0.0000, "PayeeTaxPercentage": 0.0000, "Payer": { "CompanyName": "1234", "RegistrationNumber": "1234", "Address": "zxcvb", "Country": "Åland Islands" }, "Payee": { "CompanyName": "REDEX Pte. Ltd.", "RegistrationNumber": "201834016K", "Address": "Blk 71 Ayer Rajah Crescent", "BankNameCountry": "Oversea-Chinese Banking Corporation Limited","Singapore" }, "PaymentTypeMainInvoice": { "SwiftCode", "Total": 40.00, "PaymentTypeDescriptionSubTotal": "Outside US", 40.00, "PayeeTaxAmount": 0.00, "PayerTaxAmount": 0.00, "CurrencyItems": [ "USD", { "Quantity": 20.000000, "BankAccountNumberUnitPrice": "601278732201",1.50, "ACHRoutingNumberTotalPrice": null30.00, "BankAccountName "Description": "Oversea-Chinese Banking Corporation LimitedSingapore v2024 Solar I-REC (Bid 20 Qty @ USD 1.5000)", "BankAccountType "TransactionDate": "Checking",2024-09-27T08:15:35.4800000Z", "BankAccountTypeDescriptionTransactionId": "Checking",EX2024092708153565670626" }, "SwiftCode": "OCBCSGSGXXX" { "Quantity": 1.000000, "UnitPrice": 10.00, }, "ItemsTotalPrice": [ 10.00, { "DeviceNameDescription": "T-RECSolar VNTSTK3R2",Buyer Processing Fee (Min USD 10.00)", "Vintage "TransactionDate": 2023,"2024-09-27T16:30:14.7000000Z", "CountryCode": "VN", "TransactionId": null } ], "PayerSubTotal": 0, "QuantityPayeeSubTotal": 1040.00, "UnitPricePayerSubTotalWithTax": 100.00, "TotalPricePayeeSubTotalWithTax": 100 40.00 }, "DescriptionSplitInvoices": null } |
API Definition
Status | ||||
---|---|---|---|---|
|
/public/v2/invoices/{invoiceNumber}
Request
Headers
Content-Type |
|
Authorization |
|
Query Parameters
InvoiceNumber - text The Invoice Number of Invoice |
Code Block |
---|
curl --location 'https://uat-api.redex.eco/public/v2/invoices/INV-REAR-2024-09-27-00006' \ --header 'accept: application/json' \ --header 'Authorization: Bearer {{access_token}}' |
Response
Response Body |
Data object collection - Order Resource A collection of objects - Order Resource |
Errors list of error objects Please see "Getting Started - #Error Object" for more details 请查看Getting Started - #Error Object以获得更多信息。 |
Meta pagination resource Return Pagination Resource 返回分页信息 |
StatusCode integer Http Status codes standard. Example http状态码,如200,201,400, 422 |
Message text Response message: Success or error message. 返回成功或错误的信息。 |
Info |
---|
200 Success |
Code Block | ||
---|---|---|
| ||
{ ],"Data": { "InvoiceNumber": "INV-REAPREAR-20232024-0709-1227-0002800006", "Quantity": 10,20.000000, "TotalIssuedDate": 108,"2024-09-27T00:00:00.0000000Z", "IssuedDateDueDate": "20232024-0710-12T0701T15:3459:49.3535469",59.9999999Z", "PaidDate": null, "Status": { "Value": "Unpaid", "Description": "Unpaid" }, "DueDateCreatedTime": "20232024-0709-21T2327T16:5930:5914.9999999693", "PaidDateUpdatedTime": "20232024-0709-12T0727T16:4330:2514.693", "TypeCurrencyCode": "TradingUSD", "TypeDescriptionFeeCodeNumber": null, "PayerTaxPercentage": 0.0000, "PayeeTaxPercentage": 0.0000, "Payer": { "CompanyName": "1234", "RegistrationNumber": "1234", "Address": "zxcvb", "Country": "Åland Islands" }, "Payee": { "CompanyName": "REDEX Pte. Ltd.", "RegistrationNumber": "201834016K", "Address": "Blk 71 Ayer Rajah Crescent", "Country": "Singapore" }, "MainInvoice": { "Total": 40.00, "SubTotal": 100,40.00, "TotalFeePayeeTaxAmount": 0.00, "TotalReceivable": 0, "CreatedTime": "2023-07-12T07:34:49.743", "UpdatedTime": "2023-07-12T07:43:55.193", "PayerTaxAmount": 0.00, "Items": [ { "Quantity": 20.000000, "UnitPrice": 1.50, "TotalPrice": 30.00, "Description": "Singapore v2024 Solar I-REC (Bid 20 Qty @ USD 1.5000)", "TransactionDate": "2024-09-27T08:15:35.4800000Z", "TransactionId": "EX2024092708153565670626" }, { "Quantity": 1.000000, "UnitPrice": 10.00, "TotalPrice": 10.00, "CurrencyCodeDescription": "Buyer Processing Fee (Min USD 10.00)", "CurrencySymbolicTransactionDate": "$",2024-09-27T16:30:14.7000000Z", "TaxPercent"TransactionId": null } ], "PayerSubtotal": 0, "TaxAmount"PayeeSubtotal": 40.00, "PayerSubtotalWithTax": 0.00, "Status": "Paid", "StatusDescription": "Paid", } "StatusCode": 200 "PayeeSubtotalWithTax": 40.00 }, "SplitInvoices": null }, "Meta": null, "Errors": null, "StatusCode": 200, "Message": "Success" } |
Warning |
---|
400 Bad Request |
Code Block | ||
---|---|---|
| ||
{
"Data": null
"StatusCode": 400,
"Errors": null,
"Meta": null,
"Message": "Bad Request"
} |
Warning |
---|
422 Unprocessable Entity |
Code Block | ||
---|---|---|
| ||
{
"Data": null
"StatusCode": 402,
"Errors": null,
"Meta": null,
"Message": "Unprocessable Entity"
} |
Warning |
---|
401 Unauthorized |
Code Block | ||
---|---|---|
| ||
{
"Data": null,
"StatusCode": 401,
"Errors": null,
"Meta": null,
"Message": "Unauthorized"
} |
Warning |
---|
403 Forbidden |
Code Block | ||
---|---|---|
| ||
{ "Data": null, "StatusCode": 403, "Errors": null, "Meta": null, "Message": "Success" } |
Error:
Code Block |
---|
{ Forbidden" } |
Rate limit
Rate Limit Algorithm: Fixed Window
In fixed window rate limiting, a fixed time window (e.g., one minute, one hour) is used to track the number of requests or actions allowed within that window. Requests exceeding the limit are either rejected or throttled until the window resets.
Rate Limiting Overview
Our API employs rate limiting to ensure fair usage and protect the performance and availability of the service. Combination of Global Policy and Operation Policy
Global Policy
Rate Limit: 3000 requests per 5 minute(s)
Renewal Period: 300 second(s)
Key: IP Address
Increment Condition: Any Request
Operation Policy
Rate Limit: 10 requests per 10 seconds(s)
Renewal Period: 10 second(s)
Key:
accound-id
business account Id.Increment Condition: Any Request.
Rate Limit Details
Rate Limit by Key:
Key: This ensures that rate limits are applied uniquely for each business account id.
Request Limit: Each key is allowed to make up to 10 requests per 10 seconds.
Reset Interval: The limit resets every 10 seconds.
Response Headers:
Retry-After: Sent when the rate limit is exceeded, indicating how long to wait before making another request.
Exceeding the Rate Limit
When the rate limit is exceeded, the API will return a 429 Too Many Requests
status code. The response will include a Retry-After
header specifying the number of seconds to wait before making a new request.
Example Response When Rate Limit is Exceeded
Code Block | ||
---|---|---|
| ||
HTTP/1.1 429 Too Many Requests Retry-After: 10 Content-Type: application/json { "Data": null, "Errors": null, "StatusCode": |
429, "Message": " |
Rate limit exceeded", "Meta": null } |