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.
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.
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:
Store the received user information, particularly the
- 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" ¤cy="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 ).
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. |