flutter_pinelabs
This project provides interface to access the Pinelabs API. Using the android implementation of pinelabs device rather than the hybrid application approach. It's an honest attempt to provide a simple and easy to use interface to access the pinelabs API.
Pinelabs Request and Response
doTransaction
As stated by pinelabs.
This API will be called when the Billing App completes the product selection and is ready to accept payment from the customer. Billing App will add all required tender options in its App, and call this API with specific tender such as Sale, Prepaid redeem etc.
This API can also be used for Load, Activation, Void transaction, etc. refer Transaction Types for complete list of transactions supported.
This API takes the following parameters:
transactionType
: Which can be any option from the enum TransactionType. Currently supports cash, card, upi and bharatqr.billingRefNo
: This is the reference number that is generated by the Billing App. This is used to identify the transaction. It can be null.paymentAmount
: This is the amount that is to be paid. This is in the currency of the Billing App.overrideHeader
: This is the header that is to be used for the transaction. This is used to override the header that is configured while initializing the flutter_pinelabs. This can be null only if header was provided during initialization.mobileNumberForEChargeSlip
: Mobile number on which eChargeSlip can be sent. This feature must be enabled by pinelabs before this can be used. This can be null.
// Snippet to implement doTransaction
final response = await _flutterPinelabsPlugin.doTransaction(
transactionType: TransactionType.cash,
billingRefNo: '12345',
paymentAmount: 32.52,
overrideHeader: HeaderModel(
applicationId: 'your application id issued by pinelabs.',
methodId: '1001',
versionNo: '1.0',
userId: 'logged in user id. nullable',
),
mobileNumberForEChargeSlip: '9876543210',
);
/// provides ResponseModel in return which contains the response from the pinelabs device.
setState(() {
_responseMessage = response?.responseMsg ?? '';
});
A ResponseModel is returned in response to the doTransaction call. Which will store:
header
: This is the header that is returned by pinelabs.responseCode
: This is the response code that is returned by pinelabs. 0 when success other codes are mentioned in pinelabs official docs.responseMsg
: This is the response message that is returned by pinelabs.rawResponse
: Json string that is returned by pinelabs. The above values are extracted from this string and stored in the ResponseModel.
Request to the device in json format when the above method is called will be as follows:
{
"Header": {
"ApplicationId": "your application id issued by pinelabs.",
"UserId": "1",
"MethodId": "1001",
"VersionNo": "1.0"
},
"Detail": {
"TransactionType": "4001",
"BillingRefNo": "12345",
"PaymentAmount": "32.52",
"MobileNumberForEChargeSlip": "9876543210"
}
}
sendRequest
sendRequest method is used to send json request to the device directly without any manipulation. You can use this method to pass the json and receive json response from the device.
// Snippet to implement sendRequest
final response = await _flutterPinelabsPlugin.sendRequest(
requestJson: '{"Header":{"ApplicationId":"your application id issued by pinelabs.","UserId":"1","MethodId":"1001","VersionNo":"1.0"},"Detail":{"TransactionType":"4001","BillingRefNo":"12345","PaymentAmount":"32.52","MobileNumberForEChargeSlip":"9876543210"}}');
/// provides ResponseModel in return which contains the response from the pinelabs device.
setState(() {
_responseMessage = response["Response"]["ResponseMsg"];
});
printData
This method will be called when billing App wants to print paper-receipt on Plutus Smart Device.
This method takes 2 parameters:
overrideHeader
: this parameter is used to override the header provided when FlutterPinelabs was initialized. If it is null, header from initialisation is used.printRequest
: Print request contains all the data that needs to be printed. (currently only printing text is tested)
Additional Notes:
Failure Response from the device when timedout:
{
"Header": {
"ApplicationId": "something",
"MethodId": "1001",
"UserId": "1",
"VersionNo": "1.0"
},
"Response": {
"AppVersion": "638",
"ParameterJson": "parameter",
"ResponseCode": 7,
"ResponseMsg": "Something went wrong!"
}
}
Failer Response from the device when back pressed:
{
"Header": {
"ApplicationId": "something",
"MethodId": "1001",
"UserId": "1",
"VersionNo": "1.0"
},
"Response": {
"AppVersion": "638",
"ParameterJson": "parameter",
"ResponseCode": 7,
"ResponseMsg": "Card reading Error"
}
}
Success Reponse from the device:
{
"Detail": {
"AcquirerName": "ICICI BANK",
"AcquiringBankCode": "02",
"ApprovalCode": "00",
"AuthAmoutPaise": "9999000",
"BatchNumber": 4,
"BillingRefNo": "TXN12345678",
"CardEntryMode": "CARD_CHIP",
"CardNumber": "************abcd",
"CardType": "VISA",
"CardholderName": "Some Person",
"ExpiryDate": "XXXX",
"HostResponse": "APPROVED",
"InvoiceNumber": 1,
"LoyaltyPointsAwarded": 0,
"MerchantAddress": "JANAKPURI",
"MerchantCity": "NEW DELHI DEL ",
"MerchantId": " ",
"MerchantName": "LOVE COMMUNICATION",
"PlutusTransactionLogID": "4295187240",
"PlutusVersion": "Plutus v2.12 MT ICICI BANK",
"PosEntryMode": 2,
"PrintCardholderName": 1,
"Remark": "PROCESSED",
"RetrievalReferenceNumber": "000000000020",
"TerminalId": "30365626",
"TransactionDate": "06132022",
"TransactionTime": "150726",
"TransactionType": 4001
},
"Header": {
"ApplicationId": "something",
"MethodId": "1001",
"UserId": "1",
"VersionNo": "1.0"
},
"Response": {
"AppVersion": "638",
"ParameterJson": "parameter",
"ResponseCode": 0,
"ResponseMsg": "APPROVED"
}
}
getUpiStatus
This method can be used to fetch the status of a given upi transaction. Provide transactionId and amount of the UPI payment whose status needs to be checked.
Future Scope:
Implement remaining methods such as:
x
Print Data
Settlement
Get Terminal Info
Connect Bluetooth
Disconnect Bluetooth
Scan QR Code/Barcode
Single/Multi Scan QR/Barcode Code from Camera