Card Use Cases
This section focuses on card issuing and management within Eclipse, including how cards are created, activated, and maintained throughout their lifecycle. It also covers scenarios where a tenant securely stores a customer’s card details for future use (Card-on-File). The use cases explain how cards can be issued, linked to customers, and used for both physical and digital transactions, as well as how stored card details support seamless repeat payments. For each scenario, the guide outlines the relevant APIs, required configurations, and the technical steps needed to integrate card issuing and Card-on-File functionality into your applications.
Card Management
Card Enabled Wallet Type and Wallet configurations
EFT Corporation-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 |
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}
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"status": "CANCELLED",
"reason": "DAMAGED"
}
Unstop a Card
A customer's card may be Unstopped by the customer, organisation or tenant. It can not 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 ”
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
{
"status": "ACTIVE",
"reason": "UNBLOCKED"
}
Enable / Disable Card E-Commerce Transactions
A customer may enable or disable e-commerce transactions on a card if supported by the card 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}
{
"cardRules": {
"ecommerceTransactionsEnabled": true
}
}
Enable / Disable Card International Transactions
A customer can enable or disable international transactions on a card if supported by the card program.
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}
{
"cardRules": {
"internationalTransactionsEnabled": true
}
}
Do a Physical Card Replacement
A customer can replace an existing physical card.
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
- 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
A customer can replace an existing virtual card.
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
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"status": "ACTIVE",
"walletId": 1089
}
Do not populate any of the primaryPhysicalCardIdentifier fields. Instead, use the Wallet ID of the primary (virtual) card wallet you want the replacement card to be linked to.
Cancel Card Enabled Wallet (Card Wallet)
If a card wallet is closed or cancelled, all cards linked to it—whether primary, supplementary, or add-on—will be cancelled automatically. This is different from cancelling an individual card. When a single card (primary, supplementary, or add-on) is cancelled, only that card is affected; the other cards in the wallet remain active.
A card wallet can only be cancelled if its balance is zero. Customers are advised to transfer any remaining funds from the card wallet to their digital wallet before proceeding with the cancellation.
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}
{
"status": "CANCELLED",
}
Pin Management
Physical Card PIN Set/Change
Customers can set or change their pins on issued cards.
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}
{
"pin":"1234"
}
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}/pin-sets
{
"pin":"1234"
}
Non-PCI-compliant tenants
For tenants that are not PCI-compliant, the pin-sets API can be used in two ways:
SMS
When pinDeliveryMechanism
is set to SMS
in the request body and no PIN is provided, Eclipse will generate a random 4-digit PIN and send it via SMS to the phone number stored on the customer profile.
LINK
When pinDeliveryMechanism
is set to LINK
in the request body, Eclipse will return a captive portal link in the completionUrl
field of the response. Tenants can display this URL in a webview, allowing customers to enter their PIN in a PCI-compliant captive portal hosted by Eclipse.
In this flow, the customer must also enter their Card Access Password (CAP). For details on setting the CAP see Set/Change Card Access Password (CAP).
Note
If a CAP is required in the sandbox environment the SMS will not be sent, but a generic password ‘cap123’ can be used.
Physical Card PIN Counter Reset
The PIN attempt counter tracks how many times a customer has entered the wrong PIN when making payments. Once the allowed number of attempts is reached, the card may be blocked from further transactions. Resetting the counter restores the customer’s ability to use the card with the correct PIN.
Prerequisites
- Valid JWT
- CardID
- The customer must be authenticated before allowing a PIN change request.
Reset PIN
Set the pinRetryCounter field to 0:
PUT /eclipse-conductor/rest/v1/tenants/{tenantId}/cards/{cardId}
{
"pinRetryCounter":0
}
Set/Change Card Access Password (CAP)
To view sensitive card details, a user must be authenticated in one of two ways:
- By using a JWT issued to the user from the logged-in IP address, or
- By providing a valid Card Access Password (CAP) without a JWT.
There are two methods for setting the CAP:
1. Generate random CAP
Make an API call to create a CAP for the user (only needed once per customer) - set the identity field to "CAP":
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/identities
{
"identity":"CAP"
}
Eclipse will generate a random CAP and SMS it to the customer's phone number on the profile.
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}
When the provided URL is opened, an OTP is sent to the user’s registered mobile number. The user is then asked to enter a new Card Access Password (CAP) along with the OTP. If the OTP is valid, the CAP is set successfully. If the OTP is invalid, an error is returned.
3. Reset the CAP Password through the Captive Portal
If the user has the cardId, tenantId, customerId, and a valid CAP, they can reset the Card Access Password by sending the following request:
GET {baseUrl}/payments-portal/card-ui?interactionType=resetCap&tenantId={tenantId}&userId={userId}&cardId={cardId}&landingURL={URL}
When the provided URL is opened, an OTP is sent to the user’s registered mobile number. The user is then asked to enter a new Card Access Password (CAP) along with the OTP. If the OTP is valid, the CAP is set successfully. If the OTP is invalid, an error is returned.
Landing URL
Specify the landing URL to direct the customer after completing the process, taking into account breakout points in all captive portal flows, such as "Cancel and go back" or "Done."
The landing URL can also be set as &landingURL without a redirect URL. This configuration enables 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}
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 Card
Add On Cards
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
Example for a physical add-on card:
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"physicalCardIdentifier": {
"cardId": 347,
"packId": "0PRG17USD0000028622",
"pan": "2307660000148442"
},
"status": "ACTIVE",
"walletId": 1089
}
Example for a virtual add-on card:
POST /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards
{
"cardRules": {
"ecommerceTransactionsEnabled": true,
"internationalTransactionsEnabled": true
},
"operationType": "ADDON_CARD",
"status": "ACTIVE",
"walletId": 1089
}
Supplementary Cards
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-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.
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.
Add Card on file:
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.
Note
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
Add Card on file:
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.
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"
}
4. Get a Card on file with a Cryptogram
A cryptogram value is returned when the Get Card-on-File API is called with the query parameter fields=cryptogram
.
Prerequisites
- Valid JWT with access to read the wallet.
- Tenant ID
- Customer ID
- Card on file ID
- Query parameter fields set to cryptogram
GET /eclipse-conductor/rest/v1/tenants/{tenantId}/customers/{customerId}/cards-on-file/{cardsOnFileId}?fields=cryptogram
{
"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 |
These configurations can also be managed through the Admin Portal at an Organisation level:

Captive portal configuration in the Admin Portal
Run the Captive Portal/Card UI in an iFrame
Prerequisites
- Tenant config captive.portal.config.baseUrl set to:
Callback status messages have been implemented in the Captive Portal to support the iFrame functionality. Below are the callback status messages that will be triggered to the parent (iFrame). These need to be managed through the client website which has been integrated to the captive portal.
To control the interaction of redirecting the iFrame the landingUrl needs to be excluded from the journey request, the redirection by the channel will then be dependent on the status provided to the callbackUrl.
Statuses:
Status | Description |
---|---|
'CANCELLED' | Terminate the journey |
'ERROR_PERM' | Permanent failure scenarios |
'ERROR_TEMP' | Temporary error scenarios |
'PENDING' | Pending scenarios |
'SUCCESSFUL' | Successful scenarios |
'TIMEOUT' | Timeout scenarios |
The captive portal includes multiple journeys, and each journey will return the appropriate callback status message to the parent.
Journeys:
- paymentLink
- makePayment
- pnpCashDeposit
- eftPayment
- add-cof
- createCap
- resetCap
- viewVirtualCard
Example of the callback status message:
{
"eftCaptivePortalCallbackResponse":{
"type": "", //Journey type
"status": "" //Callback status
}
}
Example branded screens
Pin set

View card
Payment link (hosted checkout)

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 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.
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++
Example POST Batch 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"
}
Card Expiry Alert
Eclipse sends email notifications to customers whose ACTIVE cards are nearing their expiry date. This process is automated and is configured to check and send notifications monthly, based on specific configuration properties below.
Attributes | Description |
---|---|
expireWithinMonth | The months prior to expiration for card expiry alerts. |
cardExpiryNotificationEnabled | Activation of the card expiry alerts, set to true to activate. |
Updated 14 days ago