Integrating CAIBO's Wallet for a Marketplace

I am developing a Marketplace. How to implement CAIBO Wallet ?

This document specifies the workflow and basic functionalities used by marketplaces to process payments with CAIBO's Wallet API. For specific needs, please contact our team at support@caibo.com .

INTRODUCTION
CAIBO is a payment solution which enables marketplaces to easily process third-party payments.

Wallet Master Account Set-up
Your first step is to register your platform and create a sandbox account.
Please request our support team support@caibo.com in order to setup your Master Account.
Once your master account is created, you will have the access to CAIBO’s wallet API and dashboard.

AUTHENTICATION
For Authentication you need to pass verification hash generated using SHA256 algorithm and the secret key shared by us.
Parameters to be included while calculating the hash are different for each API. Kindly refer API docs for more details.

INTEGRATION
Register sellers
1. Create a seller
Users can be:
  • Individual: a natural person
  • Legal: a business, organization, sole trade
User Type can be Individual or Legal .
If user type is legal then entity type can be Business/ Organization/ Public Company/ Private Company/Sole Trader.
Account type has to be Merchant in the request.
Create sellers with the following API call, please refer to our documentation in details regarding createAccount (for individual) & createBusinessAccount (for legal entity).

Sample Request

{
   "token": "OZa6b6SNays37d+UVaWnfqJsuHI5W+i4SawctRtwy4A=",
   "country_code": "44",
   "mobile": "2078137221",
   "custCountry": "England",
   "email": "abclimited@yahoo.com",
   "password": "Test@1234",
   "account_type": "Merchant",
   "user_type": "Legal",
   "entity_type": "Business",
   "business_nature_type": "Retailer",
   "walletOwnerId": "1",
   "platformId": "1",
   "deviceId": "abcd1234",
   "Currency": "GBP",
   "companyDetail": {
      "companyNumber": "12345678",
      "companyName": "ABC Limited",
      "companyWebsite": "www.company.com",
      "companyRegisteredDate": "30/06/2012",
      "taxCountryISO": "GB",
      "taxNumber": "2587419635",
      "directorCount": "2",
      "uboCount": "3",
      "registeredAddress": {
         "postalCode": "SE6 9YU",
         "countryISO": "GB",
         "address": "7",
         "state": "Brick Lane",
         "city": "London"
      }
   },
   "tradingDetail": {
      "tradingName": "ABC Limited",
      "tradingAddress": {
         "postalCode": "DH6 4JN",
         "countryISO": "GB",
         "address": "12 Park Ave",
         "street": "Coxhoe",
         "city": "Durham"
      }
   },
   "contactPerson": {
      "firstName": "Test",
      "lastName": "docs",
      "dob": "30/06/2000"
   },
   "roles": [
      "ubo"
   ],
   "registeredAddress": {
      "postalCode": "401105",
      "countryISO": "IN",
      "address": "xyz",
      "state": "Maharashtra",
      "city": "Mumbai"
   },
   "isTosOfTWAccepted": true,
   "termsConsent": "Terms of Services and privacy policy",
   "emailOtp": "521478",
   "otp": "784963"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "customerId": "189405"
}

Store the received user information, particularly the customerId, as it is required for all user actions

2. Add Business Person
To complete the due diligence requirements for a legal entity, you also need to collect details of business person. Number of business person required depends on your due diligence requirements.
For Example : You may require at least 2 persons with the role of director and one primaryContact of the business. You can add these business person using the addBusinessPerson API.
One of the Business person need to be the Primary Contact. If your business has only 1 Director, you will be able to create only 1 person and the same person can be identified as both a director and a primaryContact.
If any person owns more than 25% in the business, you can set their role as a ubo (ultimate beneficial owner).

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "firstName": "John",
   "lastName": "Doe",
   "dob": "30/06/1990",
   "roles": [
      "director",
      "ubo",
      "primaryContact"
   ],
   "residentialAddress": {
      "postalCode": "SE6 9YU",
      "countryISO": "GB",
      "address": "7",
      "state": "Brick Lane",
      "city": "London"
   },
   "verificationHash": "7d420e0efa467bc32438043cd2a29f26b37e9e30910fdd6aff08bf5f774a018d"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "personid": "12345",
   "customerId": "189405"
}

Store the received information, particularly the personid , as it is required for other actions.

3. Create a seller's e-wallet
Use the customerId to createWallet which enables the user to store e-money. The e-wallet is owned by the respective user.
The e-wallet will be identified by its currency and user can create only 1 e-wallet for each currency. In order to get the list of e-wallets for each customer, you can call the getWalletList API.

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "walletName": "Wallet_GBP",
   "walletCurrency": "GBP",
   "walletId": "",
   "verificationHash": "7d420e0efa467bc32438043cd2a29f26b37e9e30910fdd6aff08bf5f774a018d"
}

Sample Response

{
   "responseCode": "1",
   "status": "SUCCESS"
}

4. Register a seller's bank account
Register the seller’s bank account API to payout the funds from his e-wallet(s).

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "bankName": "SBM",
   "accountNumber": "41406760",
   "accountHolderName": "John Doe ",
   "sortCode": "309457",
   "countryISO": "GB",
   "IBAN": "FR7630004000031234567890143",
   "BIC": "CRLYFRPP",
   "currency": [
      "GBP",
      "USD"
   ],
   "bankAddress": {
      "postalCode": "SE6 9YU",
      "address": "7",
      "street": "Brick Lane",
      "city": "London"
   },
   "isDefault": "N",
   "verificationHash": "7d420e0efa467bc32438043cd2a29f26b37e9e30910fdd6aff08bf5f774a018d"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "bankId": "72345"
}

Store the received information, particularly the bankAccountId, as it is required for other actions. Also you can get the list of Bank Account Details using our listBankAccounts API.

5. Create and submit KYC documents
Seller refers to any individuals or businesses that are selling goods on your platform. Given that you control the entire experience of the sellers on your platform, and Caibo never interacts directly with them, you will need to build flows to collect the necessary information required for performing Due Diligence on the sellers and submit the same on Caibo platform.
List of KYC required for Seller (Merchant) can be configured using Wallet Owner Interface. Example List.

Each Business Person Company Documents
IDENTITY PROOF ARTICLES OF ASSOCIATION
ADDRESS PROOF SHAREHOLDER DECARATION
REGISTRATION PROOF

The documents need to be validated by your compliance team using wallet owner dashboard.
Find more technical information here.

Register Buyers
1. Create a seller
Create a buyer by repeating the seller creation process.
Once again, buyers and sellers can be a natural person (natural user) or a legal entity (legal user).
User Type can be individual or legal.
Account type has to be Customer.

2. Create a buyer's e-wallet
Create a buyers wallet account by using the createWallet API.
The e-wallet will be identified by its currency and user can create only 1 e-wallet for each currency. In order to get the list of e-wallets, you can call the getWalletList API.

3. Register a buyer's bank account
Register the buyer’s bank account to payout the refunds from his e-wallet(s) by repeating the buyer’s e-wallet creation process.

4. Register a buyer's Card Details
Create a card registration token to store reusable and non-sensitive card details (tokens) within CAIBO’s environment. This object is linked to the user with the customerID .
For more details please refer addCard API. Also you can get the list of card details using our listCards API.

Sample Request

{
   "customerId": "189405",
   "cardNumber": "4111110000000021",
   "cardFirstName": "John",
   "cardLastName": "Doe",
   "expiryDate": "02/25",
   "cardType": "VISA CARD",
   "cardNameIdentifier": "john",
   "isDefaultToBeUsed": 1,
   "isEncrypted": "N",
   "verificationHash": "dbcc5c99b33478b684abd0c16b8da1a2b934d765758f7e16d047808df73d1e6c"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "cardId": "262"
}

The registered card may be used multiple times. You need to store the cardId in the response for one click pay-in. Also you can get the list of Card Details using our listCards .

Payment execution (pay-in)
Sellers and buyers have now been registered within our API. The next step is to send funds to a user’s e-wallet.
1. Pay-In by registered card
We recommend using our Direct Load endpoint for a seamless integration and one-click payments.
The API call contains the cardID, currency, amount (in cents), and other additional information as mentioned in the API.

Sample Request

{
   "merchantTransactionId": "TD23243456577",
   "amount": "50.00",
   "currency": "USD",
   "cardId": "262",
   "cardCvv": "123",
   "customerId": "189405",
   "walletOwnerId": "1",
   "transactionType": "LOAD",
   "mobilePlatform": "iOS",
   "paymentMode": "CC",
   "paymentBrand": "VISA",
   "customerEmail": "abclimited@yahoo.com",
   "customerFirstName": "John",
   "customerLastName": "Doe",
   "cardNumber": "4111110000000021",
   "cardExpiryMonth": "12",
   "cardExpiryYear": "2033",
   "customerName": "John Doe",
   "country": "England",
   "city": "Durham",
   "state": "Coxhoe",
   "postcode": "DH6 4JN",
   "street1": "12 Park Ave",
   "verficationHash": "47ec67262f2f05b8a269eaa732d46540ffa56359a94f4a46d8b994c91c0b6381"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "8",
   "amount": "50.00",
   "transactionId": "262067"
}

Once the funds are credited on the buyer’s account, call our purchase API endpoint from the buyer’s account to the seller’s account.

Sample Request

{
   "customerId": "189405",
   "transactionType": "PURCHASE",
   "currency": "GBP",
   "type": "Card",
   "walletOwnerId": "1",
   "products": [
      {
         "vendorId": "275",
         "amount": "10.00",
         "orderDescription": "Product Name"
      },
      {
         "vendorId": "375",
         "amount": "10.00",
         "orderDescription": "Product Name2"
      }
   ],
   "verficationHash": "47ec67262f2f05b8a269eaa732d46540ffa56359a94f4a46d8b994c91c0b6381"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "currency": "GBP",
   "purchase": [
      {
         "purchaseId": "189765",
         "vendorId": "275",
         "amount": "10.00"
      },
      {
         "purchaseId": "189766",
         "vendorId": "375",
         "amount": "10.00"
      }
   ]
}

2. Pay-In using web load SDK
Web load end point returns the payment page URL in return. You should display payment page to the buyer. Once the payment is successful user account get updated.
The API call contains currency, amount (in cents), and additional information as mentioned in the Web load SDK

Sample Request

String params ="
    merchantTransactionId="TD32434553454"
    &amount="50.00"
    &currency="USD"
    &descriptor="TD32434553454"
    &customerId="189405"
    &walletOwnerId="1"
    &verificationHash="8416e8c5cf8cecc7325d19c5b12015863d37f18f2ee9b669c975bf2db2be6125"
    &transactionType="LOAD"
    &mobilePlatform="android/iOS/web"
    &paymentMode="CC"
    &paymentBrand="VISA";

Sample Response

{
   "status": "Success",
   "amount": "50.00",
   "statusdescription": "Transaction Successful"
}

Once the funds are credited on the buyer’s account, call our purchase API endpoint from the buyer’s account to the seller’s account.

3. Pay-In by bank transfer
Bank transfer payments involve buyers sending funds to their account on CAIBO which are then credited to the seller’s account as a separate transaction.
The first step is to get the buyer to make a bank transfer to their account on CAIBO.
Call the Bank Pay-IN API as below.

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "amount": "50.00",
   "verificationHash": "dbcc5c99b33478b684abd0c16b8da1a2b934d765758f7e16d047808df73d1e6c"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "referenceId": "3454545478",
   "bankName": "SBM",
   "accountNumber": "41406760",
   "accountHolderName": "John Doe",
   "sortCode": "309457",
   "IBAN": "FR7630004000031234567890143",
   "BIC": "CRLYFRPP"
}

The API call will return the bank details to which the buyer will need to make a transfer. This also includes a reference which will need to be provided on the bank transfer. You should display these bank details to the buyer instructing them to make a transfer with the reference provided. It is recommended that you highlight to your buyers the importance of sending the transfer with the accurate reference as otherwise the transaction will automatically be returned to the sender. Allowing users to easily copy the reference on your UI is often useful.
Once the funds are credited on the buyer’s account, call our purchase API endpoint from the buyer’s account to the seller’s account.

4. Splitting payments to multiple Seller
Payment can split a buyer to multiple sellers in a single step while calling Purchase API.
Purchase API gives option to send multiple seller details and respective amount.
Please find the below sample request for the same.

Sample Request

{
   "customerId": "189405",
   "transactionType": "PURCHASE",
   "currency": "GBP",
   "type": "Card",
   "walletOwnerId": "1",
   "products": [
      {
         "vendorId": "275",
         "amount": "10.00",
         "orderDescription": "Product Name"
      },
      {
         "vendorId": "375",
         "amount": "10.00",
         "orderDescription": "Product Name2"
      }
   ],
   "verficationHash": "47ec67262f2f05b8a269eaa732d46540ffa56359a94f4a46d8b994c91c0b6381"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1",
   "currency": "GBP",
   "purchase": [
      {
         "purchaseId": "189765",
         "vendorId": "275",
         "amount": "10.00"
      },
      {
         "purchaseId": "189766",
         "vendorId": "375",
         "amount": "10.00"
      }
   ]
}

The registered card may be used multiple times. You need to store the cardId in the response for one click pay-in. Also you can get the list of Card Details using our listCards .

Funds Management
As a marketplace, you may manage funds between buyers and sellers.
1. Refund
CAIBO gives the possibility to refund payments, either partially or totally.
Create one or several transfer refunds to allow the buyers to purchase different products.
Alternatively, refund the credit card payment (transfer refund then pay-in refund ).
  • Transfer refund : reimbursement to a user e-wallet
  • Pay-in refund : reimbursement to a user card
Create a refund using the transactionId returned during purchase.

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "amount": "10.00",
   "currency": "GBP",
   "transactionId": "189765",
   "transactionType": "TRANSFER",
   "verificationHash": "dbcc5c99b33478b684abd0c16b8da1a2b934d765758f7e16d047808df73d1e6c"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1"
}

Create PayIn Refund using pay in transactionId returned during direct load or web load.

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "amount": "10.00",
   "currency": "GBP",
   "transactionId": "189765",
   "type": "PAYIN",
   "verificationHash": "dbcc5c99b33478b684abd0c16b8da1a2b934d765758f7e16d047808df73d1e6c"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1"
}

2. Transfer funds between buyers and sellers
A transfer request allows you to move funds from one e-wallet to another. In the marketplace flow, funds will be transferred from the buyer’s e-wallet to the seller’s using transfer API.

Sample Request

{
   "amount": "50",
   "to_cust_id": "427",
   "from_cust_id": "189405",
   "comment": "personal",
   "walletOwnerId": "1",
   "fromCurrencyCode": "USD",
   "accountType": "Wallet",
   "walletId": "123",
   "verificationHash": "c5c87ac4cc094858fd635c1f010fa2254620ac667b8f6684416c78a96c0ce2e4"
}

Sample Response

{
   "to_cust_name": "XYZ",
   "amount": "50.00",
   "responseCode": 1
}

3. Pay-out to the seller's bank account
The last step of the marketplace transaction flow is the bankPayout .

Sample Request

{
   "customerId": "189405",
   "walletOwnerId": "1",
   "amount": "10.00",
   "fromCurrency": "GBP",
   "bankId": "189765",
   "verificationHash": "dbcc5c99b33478b684abd0c16b8da1a2b934d765758f7e16d047808df73d1e6c"
}

Sample Response

{
   "status": "SUCCESS",
   "responseCode": "1"
}

GLOSSARY

MARKETPLACE Online platform where products and services are exchanged by third parties. Transactions are processed by the platform. (You)
USER Natural person (natural user) or a legal person (legal user).
SELLER User selling a product or a service.
BUYER User buying a product or a service.
ENTITY TYPE Business type if the user is a legal user. Can be Business/ Organization/ Public Company/ Private Company/Sole Trader.
BUSINESS PERSON Business person linked to legal user. Can be Director, UBO , primary Contact .
E-WALLET Digital wallet on which electronic money is stored.
PAYIN / LOAD Deposit of funds by a user on an e-wallet.
TRANSFER Movement of funds from one e-wallet to another.
PAYOUT Withdrawal of funds from an e-wallet to a end-user’s bank account.
FEE Commission calculated and collected by the marketplace.
FEE E-WALLET E-wallet owned by the marketplace to collect fees.
REFUND Reimbursement to a user.
KYC (Know your customer) Verification process of your users’ identity, part of European anti-money laundering regulation.
WALLET OWNER ID ID of the platform operator in CAIBO environment.
CUSTOMER ID ID of the end-user in CAIBO environment.
TRANSACTION ID ID of any load / pay-in /purchase / transfer done by user.
Copyright © Caibo 2025 . All Rights Reserved