Page History
Versions Compared
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Payment
- The user is provided with wallet details to which payment must be made.
- The user makes a payment in their wallet app and receives a unique transaction number.
- Next, the user enters a unique transaction number in the payment window, after which the transaction is activated.
- Paykassma sends a postback to the merchant's side.
- Funds are credited to the user’s balance on the merchant platform.
Payment window integration (plugin)
Example of a link to open a Upay Manual payment window:
| 
 | 
|---|
| Code Block | 
|---|
| wallet_type=banktransferupay_manual currency_code=LKR Available languages (lang): en, si | 
| Info | 
|---|
| Pay attention to the description of the parameters payment_url_success_id / payment_url_fail_id/ payment_url_pending_id and success_url / fail_url / pending_url. | 
For the description of all the plug-in parameters click here.
API integration
Creating payment
URL: https://api.{server_URL}/api/v1/transaction/create/upay_manual?secret={pluginapi_secret}
At this stage we first accept a request for input through the payment system and in response we will provide the wallet details to which the user should transfer the payment. After the payment is made you will need to send a request to activate the transaction.
Request method:
POST
Format:
JSON
Parameters:
| Name | Type | Required | Max Length | Description | 
| currency | string | yes | 3 | Currency code. | 
| label | string | yes | 190 | The unique identifier (ID) of the user who makes the payment. | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
  'currency': 'LKR',
  'label': 'eligendi'
} | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    "status": "ok",
    "params": {
        "Account number": "066013529665120",
        "Bank name": "Seylan [Mathugama]",
        "Holder name": "K A PALITHA",
        "is_check_amount": null
    }
} | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    'status': 'fail',
    'message': 'MESSAGE'
} | 
Activation request
URL: http://api.{server_URL}/api/v1/possible-transaction?secret={pluginapi_secret}
Request method:
POST
Format:
form-data
Parameters:
| Name | Type | Required | Max Length | Description | 
| currency_code | string | yes | 3 | Currency code (LKR). | 
| wallet_type | string | yes | 190 | upay_manual | 
| label | string | yes | 190 | The unique identifier (ID) of the user who makes the payment. | 
| key1 | string | yes | 16 | Transaction ID received from the use (letters,numbersandhyphens) | 
| screenshot | file | yes | Screenshot of the payment from the user. | |
| amount | int | yes | 256 | Payment amount. | 
| custom_transaction_id | string | yes | 190 | The identifier of the transaction in the Client's system. Must be unique. | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    "status": "success",
    "message": "",
    "code": 20000,
    "data": [],
    "paginate": {
        "offset": 0,
        "total": 1,
        "limit": 1
    }
} | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    'status': 'fail',
    'message': 'MESSAGE'
} | 
Deposit postback
For the general documentation on post backs click here.
Example of a deposit postback for a Upay Manual
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
  "signature": "5d72de994d34e2650e4f8f032f7297f08fc46f49",
  "wallet_type": "upay_manual",
  "amount": 2000,
  "currency_code": "LKR",
  "label": "15169074",
  "converted_amountdirection": {"ingoing",
    "USDcreated_datetime": 6.45,
   "2024-02-29 14:19:15",
  "INRaccess_key": 536"XxdZIDCzwGYvQa28jfTunHekU",
    "EURadditional_data": 5.96,[
   ... ,{
      "USDTactivated_datetime": 6.45297326"2024-02-29 17:19:12",
      "USDTTRC20exchanger_identifier": 0null,
      "USDT20comment": 0"",
  },
    "directionamount": "ingoing2000",
      "createdcurrency_datetimecode": "2024-02-29 14:19:15LKR",
      "accesswallet_keytype": "XxdZIDCzwGYvQa28jfTunHekUupay_manual",
      "additionalstockpiling_dataid": [3454,
    {
      "activatedtransaction_datetimeid": "2024-02-29 17:19:12B3A240229-009236",
      "exchangertransaction_identifiertype": null0,
      "commentplugin_custom_order_id": "30569060",
      "amountwithdrawal_id": "2000"null,
      "currencywithdrawal_codestatus": "LKR"null,
      "walletaccount_typenumber": "upay_manual",
      "stockpilingaccount_idname": 3454"",
      "transactionaccount_idemail": "B3A240229-009236",
      "transactionbank_typedetails": 0,{
        "plugin_custom_order_idbank_code": "30569060",
        "withdrawalbranch_idcode": null,""
      "withdrawal_status": null,}
    }
  "account_number": "",
      "account_name": "",
      "account_email": "",
      "bank_details": {
        "bank_code": "",
        "branch_code": ""
      }
    }
  ]
} | 
| Warning | 
|---|
| The Paykassma server is waiting for a response in json {"status": "ok"} response code 200, otherwise, when receiving a different response, Paykassma will forward the postback with a certain frequency. | 
Withdrawals for users
For the general documentation on the withdrawals of funds click here.
Creating withdrawal
URL: https://api.{server_URL}/v2/withdrawal/create
Request method:
POST
Format:
JSON
Parameters:
Name
Type
Required
Description
int
Additional requirements:
- amount >= The value of the set minimum value;
- amount <= The value of the set maximumvalue.
label
string
yes
The unique identifier (ID) of the user who makes the payment.
yes
Upay Manual wallet number.
Validation:
- Digits: 0-9.
yes
Name of account holder.
yes
is_test
The is_test parameter possible values:
- true - if Withdrawal is test;
- false - if Withdrawal is real.
| ]
} | 
| Warning | 
|---|
| The Paykassma server is waiting for a response in json {"status": "ok"} response code 200, otherwise, when receiving a different response, Paykassma will forward the postback with a certain frequency. | 
Withdrawals for users
For the general documentation on the withdrawals of funds click here.
Creating withdrawal
URL: https://api.{server_URL}/v2/withdrawal/create
Request method:
POST
Format:
JSON
Parameters:
| Name | Type | Required | Description | 
| withdrawal_id | string | yes | Withdrawal ID, if the parameter is not passed, then the system generates withdrawal _id. | 
| payment_system | string | yes | Payment system. | 
| amount | int | required | Additional requirements: 
 | 
| currency_code | string | yes | Currency code. | 
| label | string | yes | The unique identifier (ID) of the user who makes the payment. | 
| account_number | string | yes | The user's bank account number. Validation: 
 | 
| account_name | string | yes | Name of account holder. | 
| bank_details.bank_code | string | yes | The bankfrom the providedlist of banks. 
 | 
| is_test | boolean | yes | The is_test parameter possible values: 
 | 
| signature | string | yes | Signature generated with private_key. | 
| Code Block | ||||
|---|---|---|---|---|
| 
 | ||||
| {
  "withdrawal_id": "test12345678",
  "payment_system": "upay_manual",
  "amount": 4000,
  "currency_code": "LKR",
  "label": "test",
  "account_number": "100670008622",
  "account_name": "AWAKA N V S",
  "bank_details": {
    "bank_code": "Nations Trust Bank"
  },
  "signature": "83722f5c8c963d7f7a6e5bbe0d1f13a4761927c4"
} | 
| Code Block | ||||
|---|---|---|---|---|
| 
 | ||||
| {
  "withdrawal_id": "test12345678",
  "payment_system": "upay_manual",
  "amount": 4000,
  "currency_code": "LKR",
  "label": "test",
  "account_number": "100670008622",
  "account_name": "AWAKA N V S",
  "bank_details": {
    "bank_code": "Nations Trust Bank"
  },
  "signature": "83722f5c8c963d7f7a6e5bbe0d1f13a4761927c4"
} | 
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    "status": "ok",
} | 
| Code Block | ||||
|---|---|---|---|---|
| 
 | ||||
| {
    'status': 'fail',
    'message': 'MESSAGE'
} | 
*If, when trying to create a withdrawal request, the amount of account balances in the currency of the request is less than the total amount of new and still incomplete applications, the error message"Insufficient balance" will be displayed (to configure this functionality, contact the TS Paykassma).
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
    "status": "fail",
    "message": {
        "withdrawals_sum_amount": [
            "Insufficient balance"
        ]
    }
} | 
List of currentbanks
| Note | 
|---|
| The user must select a bank only from the provided list. Manual input of the bank name by the user is not allowed. | 
Alliance Finance Company PLC
Amana Bank PLC
Asia Asset Finance PLC
Bank of Ceylon
Bank of China Limited
Bimputh Finance PLC
CBC Finance Limited
Cargills Bank LimitedLOLC Finance PLC
Amana Bank PLC 
Axis Bank LTD 
Bank of Ceylon 
Cargills Bank 
Central Finance PLC 
Citi bank CITI Bank N.A. 
Citizen Development  BankBusiness Finance PLC 
Commercial Bank PLC 
DFCC Bank PLC
Deutsche Bank  AG
Dialog Finance PLC
HDFC (ASIA) 
DFCC Wardhana Bank 
HNB Dialog Finance  PLCPlc 
HSBC
Habib HABIB Bank  LimitedLTD 
Hatton National Bank PLC 
Indian HDFC Bank 
HSBC 
Indian Overseas ICICI Bank LTD 
Kanrich 
LOLC Finance PLC
Lanka Credit Finance LTD
MCB Bank Limited
Mercantile Investments
Merchant Bank PLC
National Development Bank
National Savings Bank
Pan Asia Bank PLC
People Leasing Finance
Peoples Bank
Polgahawela Co-op Bank
Public Bank BerhadLB Finance  Limited
L B Finance PLC
LOLC Development FinancePLC 
Muslim Commercial Bank LTD 
National Development Bank PLC 
National Savings Bank 
Nations Trust Bank 
Pan Asia Bank LTD 
People's Bank 
People's Leasing 
Public Bank Berhard 
Regional Development Bank 
Richard  Piers Pieris Finance 
Sampath Bank PLC 
Sarvodhaya FinanceSanasa Development Bank 
Sarvodaya Development Finance LTD 
Senkadagala Finance PLC 
Seylan Bank  PLCLTD 
Singer Finance  PLC
Siyapatha Finance (Lanka) PLC 
Softologic Finance PLC
Standard Chartered Bank 
State Bank of India 
Softologic Finance PLC
Standard Chartered Bank
State Bank of India
State Mortgage Bank
Union Bank Of Colombo PLC
Vallibel Finance PLC
Sanasa Development Bank
Fintrex Finance LimitedUnion Bank of Colombo PLC 
Union Pay International
Example of a withdrawal postback for a Upay Manuala Upay Manual
| Code Block | ||||||
|---|---|---|---|---|---|---|
| 
 | ||||||
| {
  "signature": "2f9be236d3299256360a928831d92f6cf36871b2",
  "wallet_type": "upay_manual",
  "amount": 3600,
  "currency_code": "LKR",
  "label": "14929202" | ||||||
| Code Block | ||||||
| 
 | ||||||
| {
  "signature": "2f9be236d3299256360a928831d92f6cf36871b2",
  "wallet_type": "upay_manual",
  "amount": 3600,
  "currency_code": "LKR",
  "label": "14929202",
  "converted_amount": {
    "USD": 11.62,
    "INR": 964,
    "EUR": 10.72,
    "IDR": 182716.03,
    . . . ,
    "WAVES": 4.31911999,
    "USDT": 11.62119326,
    "USDTTRC20": 0,
    "USDT20": 0
  },
  "direction": "outgoing",
  "created_datetime": "2024-02-29 11:01:02",
  "access_key": "XxdZIDCzwGYvQa28jfTunHekU",
  "additional_data": [
    {
      "activated_datetime": "",
      "exchanger_identifier": "",
      "comment": "",
      "amount": "3600",
      "currency_code": "LKR",
      "wallet_type": "upay_manual",
      "stockpiling_id": null,
      "transaction_id": "",
      "transaction_type": null,
      "plugin_custom_order_id": "",
      "withdrawal_id": "29599588",
      "withdrawal_status": 1,
      "account_number": "117854929954",
      "account_name": "WNKPerera",
      "account_email": "",
      "bank_details": {
        "bank_code": "Sampath Bank PLC",
        "branch_code": null
      }
    }
  ]
} | 
| Warning | 
|---|
| The Paykassma server is waiting for a response in json {"status": "ok"} response code 200, otherwise, when receiving a different response, Paykassma will forward the postback with a certain frequency. | 
Withdrawal statuses
| ID | Name | Description | 
|---|---|---|
| 1 | SUCCESS PROCESSED | Status for withdrawal when the withdrawal request has been successfully processed. | 
| 5 | ||
| REJECTED | Status for withdrawal when the withdrawal request was rejected. | 
Creating withdrawal request in Paykassma BO
To create a withdrawal request, you need to go to the Withdrawals pagePayments → Withdrawals and perform the following steps
- Press the button "Add withdrawal request". 
- Select payment system from list. 
- Fill in the fields to create the request in the next window(the list of fields is standardized and not all fields are required. To create a request for a specific PS, you should fill in the required fields for this PS).
 Required fields for KBZpay Manual withdrawal:
 - Label (user ID);
 - Amount;
 - Currency;
 - Wallet recipient. 
 4. After payment the withdrawal status will change. 
 Paykassma does not send postback for withdrawals created manually.
| Table of Contents | ||
|---|---|---|
| 
 |