Your APIs for us
We can send following information to your API endpoints:
- 3DS OTP code, so you can handle delivery to the user yourself via SMS, Push or other channel.
- Notification about outcome of KYC process.
- Transaction request, so you can keep users balance on your end and accept or reject transactions their transactions (we call this "External Balance").
- Simple notification about transactions.
To make this work, you need to expose an API according to relevant section of this documentation.
To use external balance you must have Banking License or Payment Institution License. Additionally if you don't directly own BIN range, total sum of transactions of your users will be limited by deposit called "Master Balance".
Security
To set secured server-server connection between our services Verestro requires a similar connection as in the case of client to Verestro communication based on the x509 certificate, more about this model here.
In the first step, Verestro will send to the client a CSR for the dev and production environments, more details here.
The next step is for the client to sign the CSR and send the certificate back to Verestro along with the base URL for the methods listed below. Verestro will authorize itself with each request with a certificate, which should be checked on the client side.
Additional data encryption & integration
Some requests and responses contain sensitive data, to additionally secure the connection we require JSON Web Encryption (JWE).
normal
|
encrypted
|
|||
---|---|---|---|---|
Example of request with sensitive data |
|
|
||
Example ofresponse with sensitive data |
|
|
Idempotency Key
With some requests additional header X-Idempotency-Key could be send. This header contain unique random id allowing to identify single request.
If client send this header, operation should be triggered only once and for any further request with this key, response should be identical - in most cases, returned from cache.
example headers:
X-Idempotency-Key: 20e87975-dbfb-4c95-b239-169516c0b707
JWE configuration
connection we need from you enc and alg from JWE parameters. Acceptable values are:
- Algorithm used by Verestro to encipher content of message (enc) - A256GCM,
- Algorithm used by Verestro to encipher encryption key (alg) - RSA-OAEP-256,
- Algorithm needed from you to encipher content of message (enc) - A256GCM,
- Allowed algorithms for key encryption (alg) - RSA-OAEP-256 or RSA-OAEP.
Recommended JWE libraries for various programming languages:
Request:
To process encrypted message you need to perform a few additional steps on top of standard message processing:
- Verestro add headlines:
- Public-Key through which you can encrypt response to us (if needed),
- Encrypted-Request headline confirming message encryption; value true or false,
- Expose endpoint with your Public Key - you will find a similar endpoint in our technical documentation, GET /secure/public_key
- Use Verestro Public Key to create JWE and transfer data in payload,
Response:
When the response contains sensitive data that requires encryption, use Verestro public key encryption available here GET /secure/public_key
Additional information:
- In case of errors (i.e. validation errors) you will receive unencrypted response,
-
ENCRYPTION_REQUIRED,
-
INVALID_PUBLIC_KEY,
-
INVALID_PAYLOAD,
-
CANT_DECRYPT_PAYLOAD.
-
Example request:
Correct request
|
Sent request (incorrect)
|
Received by CMS Antaca (after decipher action with private key)
|
---|---|---|
{"card_no" : 1337} |
{"payload" : "eyJhbGciOiJSU0EtT0FFUC0yNTYiLCJlbmMiOiJBMjU2R0NNIn0.rdUrW12XCZQgLFDJ-2zAHWYYnaAanctceE1-Y6yJUplX0B2dLu-bvYOEJ83KxxUs-ZjA41R4PmAVilx1cTF4pv-7CZR0_ki85XRATBYF2-MvZdcC81fHy2QPU_ZsAEWAW00a1wKJmuEsgPB2m1aLZ7oK4fC1hciep4PyAtuWQRYHjhNb-UDT41_gDKTbnSGTwheL7S0mAJ_HsKfnZFHYUrM77UcxQGZKnH7Mzqvndf9THiMo0-3MWliYFDAm1bqN2_KTIoBNCprYjFnyIXPCjib73bjWX_P2ip5Ul84cngbQmFVzc7o91JrpJvYou1INS7zL4XKLFcADN4nZ_9ePWsm5_kX5SOMyUyEhOC9gusrLNAJ0MHaIFHni8WqnMAWM3_MC4OQDYetKax5bnHK6x42_5eFaf6ZmzmioKny5aGm-4Vo8TEu691FmPxglhyenWlMhvBvf6ZeVsy58Ofr0mi3TXjwYbAyas7m6sncxZu1FhEJ4da6gtNjmjuKdikOOntu8V71QQ07nczNqfGlUv0RcUc9uKJq5je4b9BEbK9WuQcroxmALqC4HTt1xhICHrVUA0d_t3fglhS2n7wNaKKCFq70ZWIrpdTaBd35kdVQOEjZgCavSjbZOzgOzcEqS6P2Blm7bZ7ZZBmnfk8y8M4m0xWoQNTmLC6nqz9bSbME.UEryKNClDxQZpyWu.6Lw_5CcZ9HiVxHfi_XTAFw.pYbQ6tdmQYe1kiPonm1GhA"} |
{"card_no" : 1337} |
Example response:
Correct response
|
Sent response by CMS Antaca
|
Received by you
|
---|---|---|
{"card_no" : 1338} |
{"payload" : "eyJhbGciOiJSU0EtT0FFUC0yNTYiLCJlbmMiOiJBMjU2R0NNIn0.iPmvEKtMAMrrEiR89vlwsL77ZfqxXrcMiy-bx3z6_7HAo__aQzBpMVDtLyj3kTHYWxen8bhPuVyebXyaIHL20sekFzcIFFzvaGoyQYU6zOK8tPv81tgixQe8SDnEr5v9VWBfiHxtPvqlpQIig2is5ynBkyqjdpQWEagR3MpqpATGl7f-omG82Jq0OwZByWI8I6P89hczwgK37F-MUnQDxcRUM3RagbHKNeIcfmPdJpNeqFZHe45y4wUkTWN0uzW72qydkN_4uM9fy0nrUpgsJNbtJGAVIUVmDz4pIZkiI1zyGbfZX-PT7Wh9UNM06gEUf4i2goZY-m4wPB0n2zXvxzcEdfTH27iPp-aKiJjfJpYb_ZnHyklk__gZlAy9r7W0594dY-eBJ_iUa5aeDsFS2TIfsfjMJsL8NRWY2noiTw5lsneD8dwvr6N_rYcWoFXDyWXHoRitSSd2iYrB80gbeSOBW0wfKtPxNIZrR0uDhkE8FouS5Pk7QBw412kd43GtrEpAijqn3ne7MNUpCtuNfJ8e_NdGDLTR7CSHhC0jfFlchpIvklF42o216NO-OnyJsjdv1w4_w1ugs61fTHDl8lgBalOjOxauKwIvJJOyFdWmpjlXuzJhrray7ov25uh2ibvFv3Gfd2iuGUnLIZzYBOTT8ftGWTCGXTDvVOvzGbs.c3qMNb2Bne-7g0Wz.PInghFM6Q8Gn0p4Tlebig32s-ZrpLqTMqQDlpXLLYx0iq-StrKco_HrjdN4MxondP4CicCgseIjcV8JR29jKYX-nqKdchEYq_vVIzFHcNI_Mx7y1el192QbMyx6b0Gbj5L79wpuB7qCUqTBNhJZ2c07PuyPsewcNwglvnc-OrA-2vL6lJnBi5ZGH8gBH1cZCgmbrMpZGNFPG3oFpOn9JPzmnvQxe9tvSFFj5989A8d_XMHP-ZQ.dJZxnBRxJeMKswDsCA3cXA"} |
Check yourself by using Private Key included in the response. |
Public Key
This method is used to share your public key for encryption.
GET https://server-domain.com/public-key
Headers:
Content-Type: application/json
response:
200 OK
{
"publicKey": "QSBwdWJsaWMga2V5IHNob3VsZCBiZSBoZXJlIGhvd2V2ZXIgaXQgd2FzIHRvbyBsb25nIDoo"
}
3DS External OTP Notifier
This document describes API for external OTP notifier handling. Clients that are interested into having OTP notifier on their side must have implement this API to allow communication with Antaca to provide one time password about the transaction to client own users.
API 3DS External OTP Notifier
Below you will find a list of endpoints that you should implement on your server side. Please pay special attention to the appropriate security of our connection, the syntax of requests that you can expect from the Verestro side, idempotency and the exact way in which you should respond to each request.
These notifications support sending Idempotency Key
Notification OTP
This method is used to transfer a one-time password generated for transactions without a card present in the 3DS standard.
POST https://server-domain.com/notifications/otp
Headers:
Content-Type: application/json
X-Idempotency-Key: 20e87975-dbfb-4c95-b239-169516c0b707
request body:
{
"storageCustomerId" => "1337",
"storageCardId" => "1337",
"balanceId" => "b334b384-328c-11ed-a261-0242ac120002",
"amount" => "1000",
"currency" => "PLN",
"merchantName" => "merchant test",
"otp" => "1111"
}
Parameters:
Parameter
|
Required
|
Description
|
Type
|
---|---|---|---|
storageCustomerId |
TRUE | Customer identifier | integer value |
storageCardId |
TRUE | Card identifier | integer value |
balanceId |
TRUE | User balance identifier | uuid v4 |
amount | TRUE | Transaction value in gross (minor value) | integer value |
currency | TRUE |
Currency 3-letters code in ISO 4217 |
ISO 4217 3-letter code |
merchantName |
TRUE |
Merchant name |
string value |
otp | TRUE | One time password | string value |
success response:
204 No Content
error responses:
Code 422
{
"detail": "some specific details provided by server"
}
External Verification Notifier
This document describes API for processed KYC verification notifier handling. Clients that are interested into having information about status KYC verification on their side must have implement this API to allow communication with Antaca.
Notifier provide notifications only with internal KYC status processes
These notifications support sending Idempotency Key
Notification verification In-progress
This method is used to transfer information about changed KYC verification status to 'IN_PROGRESS'.
POST https://server-domain.com/notifications/verificationInProgress
Headers:
Content-Type: application/json
X-Idempotency-Key: 20e87975-dbfb-4c95-b239-169516c0b707
request body:
{
"verificationId": "6faaa45a-41f6-4922-95fe-16e316ba7e91",
"userId": "1337",
"email": "leonbakiewicz@gmail.com",
"firstName": "Leon",
"lastName": "Bakiewicz",
"status": "IN_PROGRESS",
"reason": null,
}
response:
204 No Content
Notification verification accepted
This method is used to transfer information about changed KYC verification status to 'ACCEPTED'.
POST https://server-domain.com/notifications/verificationAccepted
Headers:
Content-Type: application/json
X-Idempotency-Key: 20e87975-dbfb-4c95-b239-169516c0b707
request body:
{
"verificationId": "6faaa45a-41f6-4922-95fe-16e316ba7e91",
"userId": "1337",
"email": "leonbakiewicz@gmail.com",
"firstName": "Leon",
"lastName": "Bakiewicz",
"status": "ACCEPTED",
"reason": null,
}
response:
204 No Content
Notification verification rejected
This method is used to transfer information about changed KYC verification status to 'REJECTED'.
POST https://server-domain.com/notifications/verificationRejected
Headers:
Content-Type: application/json
X-Idempotency-Key: 20e87975-dbfb-4c95-b239-169516c0b707
request body:
{
"verificationId": "6faaa45a-41f6-4922-95fe-16e316ba7e91",
"userId": "1337",
"email": "leonbakiewicz@gmail.com",
"firstName": "Leon",
"lastName": "Bakiewicz",
"status": "REJECTED",
"reason": 'INVALID_CUSTOMER_DATA',
}
response:
204 No Content
Parameters:
Parameter
|
Required
|
Description
|
Type
|
---|---|---|---|
verificationId |
TRUE | Verification identifier | uuid v4 |
userId |
TRUE | User identifier | integer value |
TRUE | User's email address | string value | |
firstName | TRUE | User first name |
string value |
lastName | TRUE | User last name | string value |
status | TRUE |
Verification status. Possible values:
|
string value |
reason | TRUE |
Verification status reason ACCEPTED: null IN_PROGRESS: null REJECTED:
|
null/string value |
Sensitive data:
This method is used to share your public key for encryption.
GET https://server-domain.com/public-key
response:
200 OK
{
"publicKey": "QSBwdWJsaWMga2V5IHNob3VsZCBiZSBoZXJlIGhvd2V2ZXIgaXQgd2FzIHRvbyBsb25nIDoo"
}
External Balance
Features
Purpose and scope
Terminology
External Balance API
Below you will find a list of endpoints that you should implement on your server side. Please pay special attention to the appropriate security of our connection, the syntax of requests that you can expect from the Verestro side, idempotency and the exact way in which you should respond to each request.
Process of linking balances
@startuml
skinparam ParticipantPadding 30
skinparam BoxPadding 30
skinparam noteFontColor #FFFFFF
skinparam noteBackgroundColor #1C1E3F
skinparam noteBorderColor #1C1E3F
skinparam noteBorderThickness 1
skinparam sequence {
ArrowColor #1C1E3F
ArrowFontColor #1C1E3F
ActorBorderColor #1C1E3F
ActorBackgroundColor #FFFFFF
ActorFontStyle bold
ParticipantBorderColor #1C1E3F
ParticipantBackgroundColor #1C1E3F
ParticipantFontColor #FFFFFF
ParticipantFontStyle bold
LifeLineBackgroundColor #1C1E3F
LifeLineBorderColor #1C1E3F
}
participant "Client server" as cs
participant Antaca as a
participant Lifecycle as lc
cs->lc: 1. create user by POST /wallet (firstName, lastName, phone, email)
lc-->cs: 2. userId
alt With own KYC process
cs->lc: 3. update KYC status by PUT /user (KYC)
else With Verestro KYC process
cs->a: 4. send KYC data by /register (user data with documents and selfie)
a->a: 5. process KYC
a->lc: 6. update KYC status
end
alt With automatic balance creation
lc-->a: 7. event about the new user with KYC
a->a: 8. create a balance in the default currency
a->cs: 10. link balance (userId, balanceId, currency)
cs-->a: 11. 204 (OK)
else Every time with create a balance
cs->a: 9. create balance by POST /balance (userId, currency)
a->cs: 10. link balance (userId, balanceId, currency)
cs-->a: 11. 204 (OK)
a-->cs: 12. 201 balance created
end
@enduml
Remember to avoid billing problems
Deleting a balance is only possible when its status is 0. This also applies to situations in which a user with at least one balance is deleted.
Transaction processing
Remember to avoid communication errors
Verestro servers attach an X-Idempotency-Key to each request in the header. This header contains a unique ID for each request to ensure idempotence. Each request with a unique identifier in this header should be processed only once on the client side and the response to it should be identical - in most cases, returned from cache
example:
curl POST "https://server-domain.com/transactions/debit"
--header "X-Idempotency-Key: 21aa0c2a-5554-4071-bd48-b9c64a0b6270"
Transaction object
{
"id": "b4f534ef-77c2-4f16-ab4d-496806a76fb6",
"balanceId": "b334b384-328c-11ed-a261-0242ac120002",
"resourceId": "9d673932-3291-11ed-a261-0242ac120002",
"resource": "card",
"transactionId": "ab3d89e4-3291-11ed-a261-0242ac120002",
"referenceTransactionId": "b759931c-3291-11ed-a261-0242ac120002",
"type": "POS",
"amount": 10000,
"currency": "PLN",
"originalAmount": 10000,
"originalCurrency": "PLN",
"status": "AUTHORIZED",
"description": "transaction description",
"date": "2020-08-17T18:43:42+00:00",
"transactionData": {
"mcc": "5942",
"merchantIdentifier": "003060300000005",
"merchantName": "Book store",
"captureMode": "NFC",
"lastFourDigits": "4560",
"acquirerCountry": "PL",
"mdesDigitizedWalletId": "Google Pay",
"cashbackPosCurrencyCode": "PLN",
"cashbackPosAmount": 10000,
"paymentTokenLastFourDigits": "7890",
"adjustmentReasonDescription": "REFUND",
"retrievalReferenceNumber": "749248185012"
}
}
Parameter | Required | Description | Allowed values |
---|---|---|---|
id |
TRUE | Unique identifier of the transaction in UUID format |
any value in UUID v4 format, eg. ddb55ff9-11ca-4621-9129-81f939e66011 |
balanceId |
TRUE | Unique user balance identifier | any string value (recommended uuid v4) |
resourceId | TRUE | Unique resource identifier | any string value (recommended uuid v4) |
resource |
TRUE | Name of a resource. | balance, card |
transactionId |
TRUE |
Transaction identifier obtained from card netwok or generated on client side using the method to generate transaction in Antaca. IMPORTANT: this id may not be unique - it is generated by different systems |
any string value (recommended uuid v4) |
referenceTransactionId |
FALSE | Id of previous transaction to witch current request relates | any string value (recommended uuid v4) |
type |
TRUE | Type of transaction | cashback, loan, payment, topup, commission, fee, funding, interest, withdrawal, pos, atm, cashback_at_pos, adjustment |
amount |
TRUE | Transaction value in gross (minor value) | integer value |
currency |
TRUE | Currency 3-letters code in ISO 4217 | ISO 4217 3-letter code |
originalAmount |
FALSE | Original transaction value in gross (minor value) | integer value |
originalCurrency |
FALSE | Original currency 3-letters code in ISO 4217 | ISO 4217 3-letter code |
status |
TRUE | Transaction status | AUTHORIZED, CLEARED, REVERSED |
description |
TRUE | Transaction description | any string value |
date |
TRUE | Date of transaction in UTC | date in UTC |
transactionData | FALSE | Additional transaction data. This object presents detailed data depending on the transaction type | This object is described below |
Name
|
Required
|
Description
|
Allowed values
|
---|---|---|---|
mcc | FALSE | Merchant category code | any mcc value, eg. can be found here: https://global.alipay.com/docs/ac/files/mcclist |
merchantIdentifier | FALSE | The merchant identifier for the transaction | |
merchantName | FALSE | Name of merchant | |
captureMode | FALSE | Capture mode | magstripe, manual, emv, on behalf (EMV), nfc, ecommerce, adj |
lastFourDigits | FALSE | Last 4 digits of card | |
acquirerCountry | FALSE | Country of acquirer | |
mdesDigitizedWalletId | FALSE | The Wallet ID (Wallet Reference) used to digitize the card. | m4m, google pay, samsung pay, apple pay |
cashbackPosCurrencyCode | FALSE | Represents the currency code of the cashback amount | ISO 4217 3-letter code |
cashbackPosAmount | FALSE | Displays the actual cashback amount | integer value in gross |
paymentTokenLastFourDigits | FALSE | Last 4 digits of Device Primary Account Number (tokenized PAN) | |
adjustmentReasonDescription | FALSE |
Reason for adjustment |
eg. REFUND, MONEY_SEND, CHARGEBACK |
retrievalReferenceNumber | FALSE | 12-digit number generated to record each transaction |
Integration with External Balance
API External balance
Below you will find a list of endpoints that you should implement on your server side. Please pay special attention to the appropriate security of our connection, the syntax of requests that you can expect from the Verestro side, idempotency and the exact way in which you should respond to each request. If you decide to implement external balance to be able to keep the balance on your side and authorize transactions, remember that the implementation of all the methods below is required to ensure the API works.
Link balance
This method is used to link customer balance between client and server. Requested balanceId will be used for communication between client and Verestro side.
If you create balance entity at your end you should create it after receiving this call. Do not create balance entity on your side as result of POST /secure/balances nor POST /secure/customers/{id}/balances, because link balance will be called before response to these methods.
POST https://server-domain.com/users/:id/balances
path parameters:
id - user identifier
Headers:
Content-Type: application/json
Accept: application/json
request body:
{
"balanceId":"2e520dc2-329d-11ed-a261-0242ac120002",
"currency": "PLN"
}
parameters:
balanceId - unique identifier of balance. This id will be used in communication between client and server.
currency - required, should be 3 letters code in ISO 4217 https://www.iban.com/currency-codes
response:
204 NoContent
error codes:
404 - should be returned if no user has been matched by requested path parameter.
Code 404
{
"title": "USER_NOT_FOUND",
"detail": "some specific details provided by server"
}
Get single user balance
Method used to obtain single user balance information.
GET https://server-domain.com/users/:id/balances/:balanceId
path parameters:
id - user identifier
balanceId - unique balance identifier
headers:
Accept: application/json
response:
200 OK
{
"currency": "PLN",
"amount": 250
}
response parameters:
currency - three letter iso 4217 code
amount - actual balance amount in minor (penny), numeric value
error codes:
404 - should be returned if no balance found by requested balanceId.
Code 404
{
"title": "BALANCE_NOT_FOUND",
"detail": "some specific details provided by server"
}
403 - if requested balance does not belong to user.
Code 403
{
"title": "FORBIDDEN",
"detail": "some specific details provided by server"
}
Get balance collection
This method should return collection of customer balances.
GET https://server-domain.com/users/:id/balances
path parameters:
id - user identifier
headers:
Accept: application/json
response:
200 OK
[
{
"id": "a072bd0e-328c-11ed-a261-0242ac120001",
"currency": "PLN",
"amount": 250
},
{
"id": "b334a5e2-328c-11ed-a261-0242ac120002",
"currency": "USD",
"amount": 460
}
]
If user has not created any balance yet, there should be returned empty collection.
200 OK
[]
response parameters:
id - unique identifier of user balance
currency - three letter iso 4217 code
amount - actual balance amount in minor (penny), numeric value
Delete balance
This method is used to unattached balance from user. From legal point of view, balance should be deleted only if there is no money on it.
DELETE https://server-domain.com/users/:id/balances/:balanceId
path parameters:
id - user identifier
balanceId - unique balance identifier
response:
204 No Content
error responses:
404 - if requested balance has not been found.
Code 404
{
"title": "BALANCE_NOT_FOUND",
"detail": "some specific details provided by server"
}
403 - if requested balance does not belong to user.
Code 403
{
"title": "FORBIDDEN",
"detail": "some specific details provided by server"
}
Debit transaction
This kind of transaction is used to authorize transaction. In debit transactions Antaca asks 'if user has money?'.
POST https://server-domain.com/transactions/debit
headers:
Content-Type: application/json
X-Idempotency-Key: uuidV4
request body:
Description of the contents of the transaction object can be found above.
success response:
204 No Content
error responses:
422
{
"title": "INSUFFICIENT_FUNDS",
"detail": "some specific details provided by server"
}
422
{
"title": "LIMITS_EXCEEDED",
"detail": "some specific details provided by server"
}
422
{
"title": "FRAUDS_DETECTED",
"detail": "some specific details provided by server"
}
404
{
"title": "BALANCE_NOT_FOUND",
"detail": "some specific details provided by server"
}
Force debit transaction
This kind of transaction is used to inform server side that transaction has occurred.
For this request, actual transaction already happen so server can not reject this request. This behavior can occur for offline transactions fe: in plane, subway, for refunds and referring to previously authorized transactions.
POST https://server-domain.com/transactions/force-debit
headers:
Content-Type: application/json
X-Idempotency-Key: uuidV4
request body:
Description of the contents of the transaction object can be found above.
response:
204 No Content
error response:
As mention in description section, we do not accept transaction rejection.
Credit transaction
Method is used to credit user balance. In credit transactions Antaca asks 'can user get money?'.
POST https://server-domain.com/transactions/credit
headers:
Content-Type: application/json
X-Idempotency-Key: uuidV4
request body:
Description of the contents of the transaction object can be found above.
success response:
204 No Content
error responses:
404
{
"title": "BALANCE_NOT_FOUND",
"detail": "cannot find requested balance"
}
422
{
"title": "FRAUDS_DETECTED",
"detail": "some specific details provided by server"
}
Force credit
Method is used to credit user balance. This kind of transaction is used to inform server side that transaction has occurred. For this request, actual transaction already happen so server can not reject this request.
POST https://server-domain.com/transactions/force-credit
headers:
Content-Type: application/json
X-Idempotency-Key: uuidV4
request body:
Description of the contents of the transaction object can be found above.
success response:
204 No Content
error response:
As mention in description section, we do not accept transaction rejection.
Reversal
Method is used to revert any changes for previous transaction. Request body will be identical to transaction witch client try to revert. If server cannot find referenced transaction then no action is required.
POST https://server-domain.com/transactions/reversal
headers:
Content-Type: application/json
X-Idempotency-Key: uuidV4
request body:
Description of the contents of the transaction object can be found above.
success response:
204 No Content
error responses:
IMPORTANT: for this method, we do not accept any error. Only satisfying behavior is to revert referenced transaction and no action if cannot find transaction.
Update transaction status
From time to time, client will inform about clearings triggered by acquirer side. If client mark transaction as cleared it means that transaction will not be corrected by any other transaction request and requested amount is final.
PUT https://server-domain.com/transactions/:id
path parameters:
id - transaction identifier
request body:
Description of the contents of the transaction object can be found above.
success response:
204 No Content
error responses:
404
{
"title": "TRANSACTION_NOT_FOUND",
"detail": "cannot find requested transaction"
}
Transactions notifier
To get notifications about transactions use Transaction History Core API
Transaction Types Description
Debit transactions list:
Type |
Description |
POS |
POS transaction (A point-of-sale) applies to the situation when a customer makes a purchase and the payment is processed through the POS system. |
ATM |
ATM Transaction is when the cardholder uses a physical card at an ATM to withdraw cash. |
Balance Inquiry |
Check the available balance of funds. |
Commission |
internal transaction for a partner who wants to debit user balance as a commission referenced to the other transaction. |
Fee |
internal transaction for a partner who wants to debit user balance as a fee. Antaca automatically credits company balance with the funds that were debit the user's balance |
Funding |
internal transaction type used to debit the user's balance. This type indicates that the funds still remain in the Antaca system, usually in conjunction with a payment type a credit transaction on the user's balance. Antaca automatically credit the credit partner balance with this transaction |
Interest |
internal transaction for a partner who wants debit the user's balance as part of the interest connected with credit agreement. |
Withdrawal |
internal transaction type used to debit the user's balance. This type indicates that the funds go outside the Antaca system, fe: withdrawal from an account at a bank branch. |
Credit transactions list:
TopUp |
internal transaction type used to top up the user's balance. This type indicates that the funds come from outside the Antaca system, fe: payment to an account at a bank branch. Antaca automatically debit the credit partner balance with this transaction |
Payment |
internal transaction type used to top up the user's balance. This type indicates that the funds come from the Antaca system, usually in conjunction with a funding type a debit transaction on the user's balance Antaca automatically debit the credit partner balance with this transaction |
Loan |
internal transaction for a partner who wants to top up the user's balance as part of the credit agreement. Antaca automatically debit the credit partner balance with this transaction |
CreditIbanTransfer |
internal transaction dedicated only for IMS API (via specific CN). IMS API uses this balance to credit funds on the user's balance. |
Cashback |
internal transaction for a partner who wants to top up the user's balance as part of the loyalty program Antaca automatically debit the credit partner balance with this transaction |