Card Use Cases
Stop a Card
A customer's card may be stopped by the customer, organisation or tenant. It should be stopped immediately if the card is assumed to be lost or stolen.
Prerequisites
- Valid JWT
- Card ID
Stop Card
Request to stop the card
Change the card status to “LOST, STOLEN, DAMAGED, COUNTERFEIT, REPLACED ”
PUT/eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
Unstop a Card
A customer's card may be Unstopped by the customer, organisation or tenant. It can’t be unstopped if the status is stolen or counterfeit.
Prerequisites
- Valid JWT
- Card ID
Step 1 – UnStop Card
Request to stop the card
Change the wallet status to “Active ”
MISSING CODE
Enable / Disable Card E-Commerce Transactions
A customer card may enable or disable e-commerce transactions (only if supported by the program)
Prerequisites
- Valid JWT
- Card ID
Enable / Disable E-commerce on Card
Request to enable/disable.
Change the ecommerceTransactionEnabled card rule to True / False
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
Enable / Disable Card International Transactions
A customer's card may enable or disable international transactions (only if supported by the program).
Note: In South Africa, any international transactions must be reported against either an Organisation or Customer, not a Tenant.
Prerequisites
- Valid JWT
- Card IDS
Enable / Disable International
Request to enable/disable.
Change the internationalTransactionsEnabled card rule to True / False
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
Do a Physical Card Replacement
To replace a card for a customer when required.
Prerequisites
- If the card replacement is for a card that is still in an active state, you should stop the active card e.g. replace a card that is soon to expire.
- Valid JWT
Create Card
Register and link the card using the Create Card
This refers to the following API in Swagger:
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards
You must populate one of the primaryPhysicalCardIdentifier fields with the replacement card details:packID, Pan or QR Code. You also need to specify the cardId of the card you are replacing.
Use the Wallet ID of the primary card (virtual card) wallet you wish to replace.
Do a Virtual Card Replacement
To replace a virtual card for a customer when required
Prerequisites
- If the card replacement is for a card that is still in an active state, you should stop the active card. e.g. replace a card that is soon to expire.
- Valid JWT
Create Card
Create the card using the Create Card
This refers to the following API in Swagger:
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards
You must NOT populate one of the primaryPhysicalCardIndentifier fields.
Use the Wallet ID of the primary card (virtual card) wallet you wish to link the replacement card to
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"status": "ACTIVE",
"walletId": 1089
}
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
Set/Change Card Access Password (CAP)
Prerequisites
- A customer must be set up with a phone number and a card already created.
- Valid JWT
For a user to view sensitive card details either a JWT issued to the user can be used from the IP address that is logged in, or a valid Card Access Password (CAP) should be passed with no JWT. There are 2 ways to set the CAP:
1. Generate random CAP
Make an API call to create a CAP for the user (only needed once per customer)
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/identities
Here you post the identity as simply "CAP" (Card access password), with no password field required.
{"identity":"CAP"}
Eclipse will generate a random 6-letter CAP and SMS it to the customer's phone number on the profile with some generic wording like "Your password to access your virtual card details is xxxxxx. Please keep it safe as you will need it whenever you look up your card details". If the customer already has a CAP then a new one will be generated.
Note
On Sandbox the SMS will not be sent, but a generic password ‘cap123’ can be used.
2. Set CAP through the Captive Portal
If a user has the cardId, tenantId and customerId they can explicitly set the CAP using the following request.
GET {baseUrl}/payments-portal/card-ui?interactionType=createCap&userId={userId}&cardId={cardId}&tenantId={tenantId}&landingURL={URL}
e.g. in sandbox:
GET https://card-payments-pwa-sandbox.ukheshe.rocks/payments-portal/card-ui?interactionType=createCap&userId={userId}&cardId={cardId}&tenantId={tenantId}&landingURL={URL}
Upon accessing the provided URL, users will receive an OTP on their registered mobile number. The user is then prompted to enter both a new CAP and the received OTP. If the entered OTP is valid, the CAP will be successfully set. However, in the case of an invalid OTP, the user will encounter an error.
3. Reset the CAP Password through the Captive Portal
If a user has the cardId, tenantId, customerId and a CAP, they can reset the CAP password using the following request.
GET {baseUrl}/payments-portal/card-ui?interactionType=resetCap&tenantId={tenantId}&userId={userId}&cardId={cardId}&landingURL={URL}
e.g. in sandbox:
GET https://card-payments-pwa-sandbox.ukheshe.rocks/payments-portal/card-ui?interactionType=resetCap&tenantId={tenantId}&userId={userId}&cardId={cardId}&landingURL={URL}
When a user accesses the provided URL, a confirmation prompt will be presented. Subsequently, the user will receive a One-Time Password (OTP) on their registered mobile number. To proceed, the user is required to input both the received OTP and a new CAP. If the entered OTP is valid, the CAP will be successfully reset. However, if the OTP is invalid, an error message will be displayed to the user.
Note
landingUrl: Navigation Endpoint
Specify the landing URL to direct the customer upon completion of the process, considering breakout points in all mentioned captive portal journeys, including options like "Cancel and go back" and "Done."
The landing URL can also be configured as &landingURL without a redirect URL. This configuration unlocks all available options within the journey.
Retrieve Card Details for Customer
There are 3 ways in which sensitive card details can be retrieved:
- Card details can be retrieved directly if the call is made with the end user JWT and from the IP address of the logged-in device
- Card details can be retrieved directly if the call is made without a JWT, but a Card Access Password (CAP) is provided and the call is made from the IP address of the logged-in device the details can be retrieved
- Card details can be retrieved through a captive web portal if a Card Access Password (CAP) is provided
1. Retrieve Card Details for Customer (API)
Prerequisites
- A customer must be set up, with a card already created. Have a cardId ready.
- The JWT of the customer
- API Call originating from the IP address of the logged-in device
Step 1 - Retrieve Card details
The user gets their card details from the app using the user JWT:
GET /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}?masked=false
2. Retrieve Card Details for Customers with CAP (API)
Ability to retrieve full card details for a customer.
Prerequisites
- A customer must be set up, with a card already created. Have a cardId ready.
- API Call originating from the IP address of the logged-in device
Step 1 – Create a CAP (Card Access Password)
Step 2 - User enters CAP, then Retrieve Card
The user gets their card details from the app without needing a JWT but the app asks them to enter the CAP they received by SMS to access their card details:
GET /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}?masked=false&cap=xxxxxx
Note
The call to get unmasked card details must come directly from the customers personal device. It must not be made from the tenant's backend unless the backend is PCI/DSS compliant.
3. Retrieve Card Details for Customers (Captive Portal Flow)
Step 1 – Create a CAP (Card Access Password)
Step 2 – View Card
- Prerequisites
- tenantId
- userId
- cardId
- CAP
Users can view his/her cards using the following request:
GET {baseUrl}/payments-portal/card-ui?interactionType=viewVirtualCard&tenantId={tenantId}&userId={userId}&cardId={cardId}&landingURL={URL}
e.g. in sandbox:
GET https://card-payments-pwa-sandbox.ukheshe.rocks/payments-portal/card-ui?interactionType=viewVirtualCard&tenantId={tenantId}&userId={userId}&cardId={cardId}&landingURL={URL}
Users need to enter the above URL in the browser then enter the valid CAP and the card data will be displayed.
Add On and Supplementary Cards
- Add-on Card
- Supplementary Card
Add-on and supplementary cards are additional cards issued against primary physical or virtual cards and form a secondary or supplementary card to each wallet.
Add-on and supplementary cards will have the same limits applied as the primary card.
Add On Cards
Add-on Card
An add-on card is used to issue an additional card that is linked to the primary cardholder's wallet but is associated with a different cardholder. e.g. card used by a spouse.
In the API request, the new cardholder Customer ID and the primary device Wallet ID are required. If it is a physical card, the new PackID or QR is also required.
Prerequisites
- The primary card must be Active.
- The secondary cardholder must be registered in Eclipse as an active user and passed KYC
- Valid JWT
POST https://eclipse-java-sandbox.ukheshe.rocks/eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards
Physical Add-On Card Request Payload**
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"physicalCardIdentifier": {
"cardId": 347,
"packId": "0PRG17USD0000028622",
"pan": "2307660000148442"
},
"status": "ACTIVE",
"walletId": 1089
}
Virtual Add-On Card Request Payload
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"status": "ACTIVE",
"walletId": 1089
}
Supplementary Cards
Supplementary Physical Card
A supplementary card is an additional card, linked to the same wallet and primary cardholder. i.e. the same cardholder information as the primary card.
When requesting a supplementary card, the Wallet ID of the primary card is required and is used in the linking of the two (primary and supplementary) cards. If the supplementary card is a physical card, the PackID or QR code needs to be included in the API request.
All supplementary cards are treated independently of the primary card. Therefore the status of the primary card does not impact the status of the supplementary card.
All Debit Programs and all programs issuing supplementary cards should have the following two attributes configured on the card wallet type
SubProgramCodeForPhysicalCard = Physical Program Code configured on the CMS
SubProgramCodeForVirtualCard = Virtual Program Code configured on the CMS
Prerequisites
- The primary card must be Active.
- Valid JWT
- Physical Add On Card Request Payload
POST https://eclipse-java-sandbox.ukheshe.rocks/eclipse-conductor/rest/v1/tenants/{tenantId}/wallets/{walletId}/cards
When a Wallet is locked, all associated cards, Supplementary cards and Add-On cards are stopped. If the wallet is then unlocked, all the associated cards remain locked and must be individually unlocked. This is to avoid the unlocking of a card that may need to remain locked.
Physical Card PIN Set/Change
To set or change a PIN on a Physical Card.
Prerequisites
- A valid JWT
- A card issued to a customer
- The CardID of the card is set
The customer must be authenticated before setting or changing a PIN.
PCI-compliant tenants
PCI-compliant tenants can set card pins directly using either of these APIs - the pin is explicitly set in the request body:
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}/pin-sets
Non-PCI-compliant tenants
For non-PCI-compliant tenants, the pin-sets API can be used in 2 ways:
SMS: If pinDeliveryMechanism is set to SMS in the request body and no pin is provided then Eclipse will randomly generate a 4-digit pin and SMS it to the phone number present on the customer profile.
LINK: If pinDeliveryMechanism is set to LINK in the request body then Eclipse will return a captive portal link in the completionUrl field of the response. Tenants can present this URL in a webview for customers to enter their PIN in a captive portal that is part of the Eclipse PCI-compliant environment. In this scenario the customer needs to input their Card Access Password (CAP); for details on setting the CAP see Retrieve Card Details for Customer.
Note
If a CAP is required in the sandbox environment the SMS will not be sent, but a generic password ‘cap123’ can be used.
There may be additional out of band requirements to authenticate the customer, depending on the program configuration.
Physical Card PIN Counter Reset
To reset a Card PIN counter if it has previously been exceeded.
Prerequisites
- Valid JWT
- CardID
- The customer must have been thoroughly authenticated before allowing a PIN change request.
Step 1 – Reset PIN
Allow the tenant to reset their card PIN
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
Pass a 0 in pinRetryCounter to reset the counter
Note, that there may be additional out-of-band requirements to authenticate the customer, depending on the program configuration
Card-on-File Management
Card-on-file is when a business securely stores its customer’s card payment details, with the cardholder’s consent. Payment data storage comes along with PCI-DSS considerations and therefore businesses that would like to leverage card-on-file need to be compliant.
The cardholder can then reuse the securely stored card details for future payments (e.g. wallet top-ups in the context of Eclipse) thereby having a seamless checkout experience.
Eclipse provides the following options (which are PCI-DSS compliant) for card-on-file management:
- Add a card on file directly - specify the card details in the API call.
- Add a card on file but use a captive portal - specify callback URL in the API call - tenant system does not need to be PCI compliant.
- Add a card on file as part of a top-up - directly (same as (1))
- Add a card on file as part of a top-up - using the captive portal (same as (2))
1. Add Card Details Directly
This method allows users to save their card details by capturing the following information:
- Alias
- CardData (pan, CVV, expiry)
Prerequisites
- Valid JWT with access to read the wallet.
- The tenant must be PCI compliant.
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards-on-file
{
"cardData": {
"cvv": "562",
"pan": "4242424242424242",
"expiry": "0536",
"cardholderName": "Mikel Arteta"
},
"alias": "Card-42"
}
{
"cardOnFileId": "590f63a8-909f-4c67-88f8-2a21986789e4"
}
Refer to the Initiate Adding A Card On File documentation for full details.
NB
The selected tenant must be end-end PCI-DSS compliant to pass card data directly.
2. Add a card on file via the captive portal
The second alternative method for storing card payment details is to pass a callback URL on the endpoint below. With this option, you don't need to populate any of the card details but only the callback URL to the captive portal.
When the request is sent, the system will return a completion URL (as shown in the sample JSON response below) which can be navigated to - you need to iFrame navigate to this URL to populate the card details i.e. PAN, CVV & expiry date.
Prerequisites
- Valid JWT with access to read the wallet.
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards-on-file
{
"alias": "demo",
"callbackUrl": "http://google.com"
}
{
"completionUrl": "https://eclipse-java-sandbox.ukheshe.rocks/t/c6wJ8",
"cardOnFileId": "edb452d3-a47b-4e5c-880d-3fe84c5b1649"
}
Refer to the screenshot below showing an example of a captive UI screen where users can capture their card details.
3. Add a card on file as part of a top-up
The user-provided card details will be saved for use in future transactions that is after a successful wallet top-up by card transaction. This approach follows the same process flow as outlined in the first option i.e. add card details directly.
Prerequisites
- Valid JWT with access to read the wallet.
- wallet ID.
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/wallets/{walletId}/topups
{
"topupCardData": {
"expiry": "1125",
"pan": "4242424242424242",
"cardholderName": "CLAYT",
"accountType": "Debit",
"cvv": "123"
},
"amount": 500,
"externalUniqueId": "ref890889",
"type": "ZA_MASTERPASS_CARD"
}
5. Get a Card on file with a Cryptogram
Cryptogram value will be provided when get card of file Api will be used with Query parameter fields=cryptogram.
Prerequisites
- Valid JWT with access to read the wallet.
- Tenant ID
- Customer ID
- Card on file ID
- Query parameter (fields=cryptogram)
GET: /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards-on-file/{card-on-file-id
{
"alias": "zttydgbovO",
"cardOnFileId": "16174808-15a7-4c9e-886d-9d84584cfb02",
"last4Digits": "2999",
"expires": "2025-12-01T00:00:00.000Z",
"status": "ACTIVE",
"schemeTokenType": "VISA",
"schemeToken": "17f551c1cbgyuhhjc143ab1f7425bcd002",
"schemeTokenStatus": "ACTIVE",
"cardArtUrl": "https://cardsonfile-content-public.s3-eu-west-1.amazonaws.com/22af01f2bdf445e497895d502dd1f1ae-digitalCardArt.pdf",
"bin": "489537",
"cryptogram": "AwAAAAAAPuEtjg4Am00eAtgqsAAAA="
}
Customization of Eclipse Hosted and Captive Portal UI
Eclipse offers hosted pages for many scenarios:
- Card viewing and card management in a captive portal within the Eclipse PCI environment. This caters for the scenario where tenants are not PCI compliant and therefore can not serve this sensitive data.
- Hosted checkout for easy e-commerce integration.
- Hosted AWS Liveness for easy integration of AWS liveness into a tenant's KYC process.
For all of these hosted pages, the user interface can be customised according to a tenant's logo & colour scheme. This customization can be implemented by configuring a global property for the tenant.
Prerequisites
- Tenant config captive.portal.config.baseUrl set to:
- wallet ID.
The following parameters can be configured:
Property | Property Value |
---|---|
Property name | public.tenant.{tenant ID} |
tenantName | xxxxxx |
merchantName | xxxxxx |
title | xxxxxx |
capLabel | Label when setting CAP - e.g. 4-digit passcode |
capDigit | Number of digits for CAP - e.g. 4 |
isCapNumOnly | Allow only numbers for CAP - e.g. true |
paymentType | Payment types for Hosted checkout - e.g. mastercard,ozow,pnpcash |
primaryBackgroundColour | #FFFFFF (Colour) |
primaryColour | #0083C2 (Colour) |
primaryTextColour | #FFFFFF (Colour) |
primaryButtonColour | #0083C2 (Colour) |
secondaryColor | #FFFFFF (Colour) |
primaryButtonTextColour | #FFFFFF (Colour) |
secondaryButtonColour | transparent |
secondaryButtonTextColour | #0083C2 (Colour) |
buttonDisabledColor | #FFFFFF (Colour) |
alignmentOfCardHorizontal | horizontal |
inputRadius | 100px |
borderRadius | 5px |
mobileNumberRegex | |
bankEFTAccountNumber | |
pnpInstructionSMSTemplateId | |
pnpDepositRange | Range of accepted values for PnP payments - .e.g. 50-3000 |
pnpAmountRounding | The logic for rounding PnP payments to whole numbers - default HALF_UP |
errorCodes | Sandbox - public.tenant.card-payments-pwa-sandbox.ukheshe.rocks.errorcodes Production - public.tenant.card-payments-pwa.ukheshe.co.za.errorcodes |
imageBase64 | data:image/png;base64 (Logo is added to an image to Base64 convert) |
virtualCardTemplateBase64 | data:image/png;base64 (Logo is added to an image to Base64 convert) |
successIconBase64 | data:image/png;base64 (Logo is added to an image to Base64 convert) |
lockIconBase64 | data:image/png;base64 (Logo is added to an image to Base64 convert) |
cardCSS | public.tenant.{tenantID}.card.css - this defines the CSS for displaying custom cards |
Example cardCSS public property: public.tenant.{tenantID}.card.css:
{
"alignmentOfCardHorizontal": "true",
"cardBackground": {
"backgroundImage": "url()",
"height": "191px",
"width": "300px",
"borderRadius": "8px",
"backgroundSize": "cover"
},
"gridCardNumber": {
"letterSpacing": "3px",
"display": "flex",
"gap": "8px",
"marginLeft": "4%",
"marginTop": "26%"
},
"gridValidThru": {
"display": "flex",
"gap": "4px",
"marginTop": "8%",
"marginLeft": "6%"
},
"gridCvv": {
"display": "flex",
"gap": "4px",
"marginTop": "-8.7%",
"marginLeft": "34%"
},
"typoCardNumber": {
"fontSize": "12px",
"fontWeight": "500",
"padding": "0px 6px",
"border": "1pxsolid",
"borderRadius": "2px",
"color": "#ffffff",
"cursor":"pointer"
},
"copyDivStyle": {
"display": "flex",
"justifyContent": "center",
"alignItems": "center"
},
"typoValidThruAndCvv": {
"fontSize": "10px",
"fontWeight": "500",
"padding": "0px 6px",
"border": "1pxsolid",
"borderRadius": "2px",
"color": "#ffffff",
"cursor":"pointer"
}
}
Property to configure termsAndConditions on the card-ui captive portal: public.tenant.{tenantid}.cardui.tnc
The following parameters can be configured:
Property | Property Value |
---|---|
termsAndConditions | public.tenant.{tenantID}.cardui.tnc |
footerBackgroundColor | # 007834 |
footerTextColor | # 000000 |
partnerLogo | publicly accessible image |
securePaymentByLogo | publicly accessible image |
Cancel Card Enabled Wallet(Card Wallet)
If we close/cancel the wallet of the card, all the associate cards of that wallet (primary, supplementary or add-on card) will be cancelled automatically. Cancelling a card wallet is a little different than cancelling a card. If we only cancel/stop the card (primary, supplementary or add-on) it will only cancel that particular card but the other cards associated with that wallet will remain unchanged.
Customers can only cancel a card wallet if it has zero balance. We recommend that customers should transfer the entire amount from the card wallet to the digital wallet before cancelling the card wallet.
Prerequisites
- The card wallet available balance should be zero.
- Valid JWT
Step 1 – Cancel the card wallet
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/wallets/{walletId}
MCC and MID logic to deny or allow transactions
A common requirement for card payment processing is to be able to deny or allow transactions based on Merchant Category Code (MCC) and Merchant ID access and deny lists. Eclipse supports a wide degree of flexibility in configuring this behaviour so tenants have fine-tuned control over their transactions.
The following wallet-type attributes determine the logic to deny or access a card transaction:
Attribute | Description |
---|---|
mcc.whitelist | a white list of approved merchant category codes. |
mcc.blacklist | a blacklist of merchant category codes that should be denied. A common example here is denying gambling-related transactions. |
mcc.whitelistRegex | A white list regular expression of approved merchant category codes. |
mcc.blacklistRegex | A blacklist of regular expressions of merchant category codes that should be denied. |
mid.whitelist | A white list of approved merchant IDs. |
mid.blacklist | A blacklist of merchant IDs that should be denied. |
mid.whitelistRegex | A white list of regular expressions of approved merchant IDs. |
mid.blacklistRegex | A blacklist of regular expression of merchant IDs that should be denied. |
Typically customers will have different logic they want to apply, for example:
- Allow everything unless present on a blacklist
- Deny everything unless present on a whitelist
- Allow everything unless present on a blacklist and then the whitelist can override the blacklist
- Deny everything unless present on a whitelist and then the blacklist can override the whitelist
To cater for this wide range of logic tenants can apply different logic by setting the wallet type attribute: mcc.mid.logic. This refers to a global property mcc.mid.logic.{logic_name} e.g. if mcc.mid.logic=Simple then global property mcc.mid.logic.Simple will be used. These properties define Javassist which determines whether or not the transaction should be allowed.
Below is simple example logic that allows everything unless present on a blacklist. This would typically be the default behaviour with a MccBlacklist defined with MCC 7995 (Gambling) blacklisted.
public boolean isAllowed(String mcc, String mid,
Boolean inMccWhitelist, Boolean inMccBlacklist,
Boolean inMidWhitelist, Boolean inMidBlacklist,
Boolean matchesMccWhitelistRegex, Boolean matchesMccBlacklistRegex,
Boolean matchesMidWhitelistRegex, Boolean matchesMidBlacklistRegex) {
return (inMccBlacklist == null || Boolean.FALSE.equals(inMccBlacklist)) && (inMidBlacklist == null || Boolean.FALSE.equals(inMidBlacklist));
}
Below is an example logic that denies everything unless present on a whitelist and then the blacklist can override the whitelist (if no whitelists present then the transaction is allowed). This would typically cover the gift card or industry card (e.g. fuel) use cases.
public boolean complexBlacklistsPriorityOverWhitelists(String mcc, String mid,
Boolean inMccWhitelist, Boolean inMccBlacklist,
Boolean inMidWhitelist, Boolean inMidBlacklist,
Boolean matchesMccWhitelistRegex, Boolean matchesMccBlacklistRegex,
Boolean matchesMidWhitelistRegex, Boolean matchesMidBlacklistRegex) {
if (Boolean.TRUE.equals(inMccBlacklist) || Boolean.TRUE.equals(inMidBlacklist)) return false; //present in either blacklist
if (Boolean.TRUE.equals(inMccWhitelist) || Boolean.TRUE.equals(inMidWhitelist)) return true; //present in either whitelist
if (inMccWhitelist == null && inMidWhitelist == null) return true; //no whitelists
return false;
}
Card Enabled Wallet Type and Wallet configurations
Ukheshe-issued cards have a wide range of customisation settings that can be applied at a global wallet type level as well as an individual wallet instance level allowing customers to selectively customise their card experience. The following settings can be customised:
Attributes | Description |
---|---|
allowInternationalTransactions | Controls whether international transactions are allowed on the card. True or false. |
internationalMarkUpFees | Additional fee charged for international card transactions |
contactlessLimit | The limit under which contactless or tap transactions are enabled. By default, this is set to 500. To disable contactless transactions this can be set to 0. |
SubProgramCodeForVirtualCard | Postilion program card for issued virtual cards |
SubProgramCodeForPhysicalCard | Postilion program card for issued physical cards |
alwaysCreateCard | Controls whether a card will be issued against a wallet when created. Can either be set as true or false. False means a card will need to be manually added to the wallet after creation |
feesReversalAllowed | Controls whether a fee can be reversed, set as either true or false |
Fee and limit specific configs
Fees and limits can be configured for a range of transaction types:
- pur: Purchase
- cwd: ATM
- pra: Pre-Auth
- pwc: Purchase with Cashback
- chb: Cashback
- cad: Cash Advanced
- bai: ATM Balance Enquiry
Attributes | Description |
---|---|
fees.amount.config.{transaction_type}.{domestic/international} | Fees charged for different transaction types and for domestic and international transactions |
postilion.{transaction_type}.{domestic/international}.debitCardMonthlyTransactionLimit | Monthly transaction limit per transaction type |
postilion.{transaction_type}.{domestic/international}.debitCardPerTransactionLimit | Per transaction limit per transaction type |
postilion.{transaction_type}.{domestic/international}.debitCardDailyTransactionLimit | Daily transaction limit per transaction type |
postilion.{transaction_type}.{domestic/international}.debitCardDailyTransactionVelocityLimit | Daily velocity limit per transaction type |
debit.decline.transaction.fee | Fees are charged for different transaction types when a decline occurs |
Note:
Transaction Limits must be set as individual Wallet Type Configuration Parameters. The limits can not exceed any limit that may be set at the Wallet Type level or Tenant level.
All corresponding transaction types require a configuration to be set for the destination wallet and fees wallet to credit when transactions are successful:
Attributes | Description |
---|---|
source.wallet.config.postilion.ref | Wallet to debit when a refund (REF) is done |
destination.wallet.config.postilion.{transaction_type} | Wallet to credit when a transaction is successful |
fees.wallet.config.postilion.{transaction_type} | Wallet to credit with fees when a transaction is done |
Card Tokenisation
Card tokenisation is the process of replacing a card’s primary account number (PAN) with a unique alternate card number, or "token". Tokens can be used for mobile point-of-sale transactions, in-app purchases or online purchases.
Tokenisation reduces fraud related to digital payments by making transactions more secure by including a dynamic component with each transaction. It takes the security of a physical EMV chip and applies it to non-card environments including proximity, mobile and internet payments.
Merchants benefit from more secure transactions, as well as faster checkout experiences, new payment acceptance options and more ways to sell.
Eclipse supports the following methods of tokenisation:
- Eclipse proprietary tokenisation - when storing a card on file, the PAN is stored and referenced using a unique card on file ID
- Visa Token Service (VTS) - this utilises Visa's tokenisation service to tokenise Visa cards
- Mastercard Digital Enablement Service (MDES) - this utilises Mastercard's tokenisation service to tokenise Mastercard cards
Card schemes encourage the use of scheme tokenisation and some services, for example, Visa QR payments, mandate that scheme tokenisation (Visa or Mastercard) be used for transactions.
How does it work?
When storing a card on file:
- Eclipse will generate a unique card on file ID - this is Eclipse's proprietary tokenisation
- If scheme tokenisation is enabled on the tenant the scheme token provider is called to request a scheme token
- The returned token is securely stored as part of the card on file metadata on Eclipse
- Eclipse returns the card on file ID as well as the scheme reference to the tenant
When initiating a payment with a tokenised card:
- Tenant initiates payment and passes in the Eclipse card on file ID of tokenised card
- Eclipse uses the stored scheme token to request a cryptogram from the scheme token provider
- Eclipse processes the payment using the scheme token and cryptogram response - this step is dependent on the payment type - e.g. card processing, QR acquiring, etc.
- Ultimately the acquiring bank calls the scheme token provider to detokenise the scheme token for the payment
Pre-requisites:
- Tenant config enableVisaTokenization set to true to enable Visa Token Services
- Tenant config enableMastercardTokenization set to true to enable Mastercard Digital Enablement Services
- Tenant config m4mTokenizationAuthenticationValue set
- Tenant config vtsClientAppID set
For example, for API calls to store a card on file please refer to the card on file management section.
For example, API calls to initiate a payment using a tokenised card refer to the card-specific payment use cases e.g. Payment of EMVCO QR.
API enablement for card production file creation
User can initiate a card production file by using a POST request with the updated batch API, which allows responses to be returned as a file with file=true or in JSON format with file=false.
configure the email template by setting the global property
- Name: mustache.email.postilion.card.file.creation
- Value:
#From: ++comms.email.address++
#To: {{data.email}}
#Subject: Card production file creation for tenant ID {{data.tenantId}}
++email.top++
card Program ID: {{data.cardProgramId}} <br>
Bin: {{data.bin}} <br>
Amount: {{data.amount}} <br>
Tenant ID: {{data.tenantId}} <br>
Type: {{data.type}} <br>
Sub Type: {{data.subType}} <br>
++email.bottom++
POST Batch API
API :POST/eclipse-conductor/rest/v1/global/batches
{
"info": "{\"cardProgramId\": 25, \"bin\": 76261892981, \"amount\": 500000}",
"subType": "PHYSICAL",
"tenantId": 688,
"type": "POSTILION_CARDS",
"email": "[email protected]",
"callbackUrl": "http://testserver.ukheshe.rocks/blank.html"
}
{
"tenantId": 688,
"subType": "POSTILION_CARDS",
"info": "{\"cardProgramId\": 25, \"bin\": 76261892981, \"amount\": 500000}",
"email": "[email protected]",
"callbackUrl": "http://testserver.ukheshe.rocks/blank.html"
}
Updated about 1 month ago