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:

  1. 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
  2. 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
  3. 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

  1. Add-on Card
  2. 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.

658

Add on 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:

  1. Add a card on file directly - specify the card details in the API call.
  2. 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.
  3. Add a card on file as part of a top-up - directly (same as (1))
  4. 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

The following parameters can be configured:

PropertyProperty Value
Property namepublic.tenant.{tenant ID}
tenantNamexxxxxx
merchantNamexxxxxx
titlexxxxxx
capLabelLabel when setting CAP - e.g. 4-digit passcode
capDigitNumber of digits for CAP - e.g. 4
isCapNumOnlyAllow only numbers for CAP - e.g. true
paymentTypePayment 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)
secondaryButtonColourtransparent
secondaryButtonTextColour#0083C2 (Colour)
buttonDisabledColor#FFFFFF (Colour)
alignmentOfCardHorizontalhorizontal
inputRadius100px
borderRadius5px
mobileNumberRegex
bankEFTAccountNumber
pnpInstructionSMSTemplateId
pnpDepositRangeRange of accepted values for PnP payments - .e.g. 50-3000
pnpAmountRoundingThe logic for rounding PnP payments to whole numbers - default HALF_UP
errorCodesSandbox - public.tenant.card-payments-pwa-sandbox.ukheshe.rocks.errorcodes

Production - public.tenant.card-payments-pwa.ukheshe.co.za.errorcodes
imageBase64data:image/png;base64 (Logo is added to an image to Base64 convert)
virtualCardTemplateBase64data:image/png;base64 (Logo is added to an image to Base64 convert)
successIconBase64data:image/png;base64 (Logo is added to an image to Base64 convert)
lockIconBase64data:image/png;base64 (Logo is added to an image to Base64 convert)
cardCSSpublic.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:

PropertyProperty Value
termsAndConditionspublic.tenant.{tenantID}.cardui.tnc
footerBackgroundColor# 007834
footerTextColor# 000000
partnerLogopublicly accessible image
securePaymentByLogopublicly 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:

AttributeDescription
mcc.whitelista white list of approved merchant category codes.
mcc.blacklista blacklist of merchant category codes that should be denied. A common example here is denying gambling-related transactions.
mcc.whitelistRegexA white list regular expression of approved merchant category codes.
mcc.blacklistRegexA blacklist of regular expressions of merchant category codes that should be denied.
mid.whitelistA white list of approved merchant IDs.
mid.blacklistA blacklist of merchant IDs that should be denied.
mid.whitelistRegexA white list of regular expressions of approved merchant IDs.
mid.blacklistRegexA 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:

AttributesDescription
allowInternationalTransactionsControls whether international transactions are allowed on the card. True or false.
internationalMarkUpFeesAdditional fee charged for international card transactions
contactlessLimitThe 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.
SubProgramCodeForVirtualCardPostilion program card for issued virtual cards
SubProgramCodeForPhysicalCardPostilion program card for issued physical cards
alwaysCreateCardControls 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
feesReversalAllowedControls 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
AttributesDescription
fees.amount.config.{transaction_type}.{domestic/international}Fees charged for different transaction types and for domestic and international transactions
postilion.{transaction_type}.{domestic/international}.debitCardMonthlyTransactionLimitMonthly transaction limit per transaction type
postilion.{transaction_type}.{domestic/international}.debitCardPerTransactionLimitPer transaction limit per transaction type
postilion.{transaction_type}.{domestic/international}.debitCardDailyTransactionLimitDaily transaction limit per transaction type
postilion.{transaction_type}.{domestic/international}.debitCardDailyTransactionVelocityLimitDaily velocity limit per transaction type
debit.decline.transaction.feeFees 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:

AttributesDescription
source.wallet.config.postilion.refWallet 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:

  1. Eclipse will generate a unique card on file ID - this is Eclipse's proprietary tokenisation
  2. If scheme tokenisation is enabled on the tenant the scheme token provider is called to request a scheme token
  3. The returned token is securely stored as part of the card on file metadata on Eclipse
  4. Eclipse returns the card on file ID as well as the scheme reference to the tenant

When initiating a payment with a tokenised card:

  1. Tenant initiates payment and passes in the Eclipse card on file ID of tokenised card
  2. Eclipse uses the stored scheme token to request a cryptogram from the scheme token provider
  3. 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.
  4. 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"
}