Terminal-2 icon

Manual Key Entry (MKE)

Manually enter card details to make a payment.

Using our Standalone solution?

If the terminal is not integrated with a POS system, see Standalone terminals for instructions to enter the card number by hand.

Manual key entry (MKE) involves manually typing the details from a shopper's card on the payment terminal. You can use this when the payment terminal fails to obtain the card details from the card's chip or magnetic stripe.

There is no liability shift with MKE. This means you are fully liable for fraud chargebacks.

How it works

  1. When the payment terminal cannot read the card details, you start an MKE transaction from your POS app.
  2. The terminal asks the shopper to manually enter their card number and expiry date.
  3. The terminal then asks the shopper to provide their signature on the display.
  4. The transaction continues.

Configure MKE transactions

Because of the increased risk of chargebacks, you need to take action before you can use MKE:

  1. Contact our Support Team and ask them to enable Manual Keyed Entry for you.
  2. Set a maximum transaction amount that the terminal will allow for an MKE transaction:

    1. Log in to your Customer Area.
    2. Optional. Select the merchant account or store where you want to configure settings.
    3. Go to In-person payments > Terminal settings (or select a specific terminal) and select Payment features.
    4. Enter the MKE max amount.
    5. Select Save.

Make an MKE payment

With a Terminal API integration, proceed as follows to force MKE as the card entry mode in your Terminal API payment request:

  1. Make a PaymentRequest specifying a PaymentTransaction object that includes:

    • TransactionConditions.ForceEntryMode: Keyed

    For a complete list of fields you can pass in a payment request and receive in the response, see the PaymentRequest API reference and the PaymentResponse API reference.

    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "SaleToPOIRequest":{
    "MessageHeader":{
    "ProtocolVersion":"3.0",
    "MessageClass":"Service",
    "MessageCategory":"Payment",
    "MessageType":"Request",
    "ServiceID":"037",
    "SaleID":"POSSystemID12345",
    "POIID":"P400Plus-275040702"
    },
    "PaymentRequest":{
    "SaleData":{
    "SaleToAcquirerData":"",
    "SaleTransactionID":{
    "TransactionID":"8377PME_POS",
    "TimeStamp":"2021-01-19T11:03:39.000Z"
    }
    },
    "PaymentTransaction":{
    "AmountsReq":{
    "RequestedAmount":17.50,
    "Currency":"EUR"
    },
    "TransactionConditions":{
    "ForceEntryMode":[
    "Keyed"
    ]
    }
    }
    }
    }
    }
  2. In the response, note that the PaymentResult includes:

    • AuthenticationMethod: SignatureCapture.
    • CapturedSignature: coordinate points of the signature drawn on the terminal display.
    • PaymentInstrumentData.CardData: indicates the EntryMode was Keyed.

    The AdditionalResponse also shows the posEntryMode was MKE.

    MKE response
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "SaleToPOIResponse": {
    "MessageHeader": {...},
    "PaymentResponse": {
    "POIData": {...}
    },
    "PaymentReceipt": [...],
    "PaymentResult": {
    "AmountsResp": {...},
    "AuthenticationMethod": [
    "SignatureCapture"
    ],
    "CapturedSignature": {
    "AreaSize": {
    "X": "100",
    "Y": "FB"
    },
    "SignaturePoint": [
    {
    "X": "2D",
    "Y": "FB"
    },
    {
    "X": "32",
    "Y": "FB"
    },
    ...
    ]
    },
    "OnlineFlag": true,
    "PaymentAcquirerData": {...},
    "PaymentInstrumentData": {
    "CardData": {
    "CardCountryCode": "840",
    "EntryMode": [
    "Keyed"
    ],
    "MaskedPan": "415150 **** 0008",
    "PaymentBrand": "visa",
    "SensitiveCardData": {
    "ExpiryDate": "0330"
    }
    },
    "PaymentInstrumentType": "Card"
    }
    },
    "Response": {
    "AdditionalResponse": "...posEntryMode=MKE...",
    "Result": "Success"
    },
    "SaleData": {
    "SaleTransactionID": {...}
    }
    }
    }
    }

Risk management

You can use our risk management system to minimize fraud by applying risk rules before processing a transaction. Based on your risk settings, every transaction gets a risk score ranging from 0 to 100 and is declined when the risk score reaches 100.

See also