Payment can be made in 3D via TAMİ. 3D payment process consists of 2 steps. Firstly, 3D sales transaction is initiated, and as a result of this process, the service returns html content information which is decoded from base64 to obtain an html. This html is then directed to the 3D verification page, where the verification code is entered to complete the 3D verification and see the result. To convert a successful 3D verification process into a sale, the 3D Complete service must be called to complete the transaction.
For Virtual POS transactions, merchants can use the merchant information given in the table below for the controls they want to perform in the test environment.
For Virtual POS transactions to be realized from the prod environment via Tami, the merchant number is obtained by making an application.
You can access the Sandbox test portal at https://sandbox-portal.tami.com.tr. When you log in to the test portal with the users provided below, the transactions made by the workplace connected to this user can be viewed. Transactions can be canceled/refunded.
User Phone Number | User Password | Sms / Email Otp | Workplace Number | Terminal Number | Secret Key |
---|---|---|---|---|---|
5346484700 | 147854 | 147852 | 77006950 | 84006953 | 0edad05a-7ea7-40f1-a80c-d600121ca51b |
5346484709 | 147850 | 147852 | 77006951 | 84006954 | c8581bb6-a4b2-4925-8c94-529fc651399e |
5346484803 | 147850 | 147852 | 77006952 | 84006955 | ff7d4895-0c32-4f48-86ab-fb9ecca9f3d7 |
5346484807 | 147850 | 147852 | 77006953 | 84006956 | 33124ff0-0b19-4cf9-b002-13a35eae865b |
5346484800 | 147850 | 147852 | 77006954 | 84006957 | 7daf9631-e136-4164-9ddb-dd1c02df851d |
5346484808 | 147850 | 147852 | 77006956 | 84006959 | fe6f3fff-0434-4932-a27d-bb3dac9de49d |
The request sent for many transaction types should include the PG-Auth-Token in the header information. The PG-Auth-Token consists of the values "MerchantNumber:TerminalNumber:Hash".
When calculating the hash here, the merchantNumber, terminalNumber, and secretKey information belonging to the merchant are hashed with sha256 and converted to a string.
You can access the Tami test portal at https://sandbox-portal.tami.com.tr. From this address, you can view the portal screen with the users specified above.
For your production environment information you can become a member at https://portal.tami.com.tr or You can apply to the e-commerce support unit.
The first step of a 3D secure sales transaction. The 3D secure sales transaction is initiated by adding the member merchant's callbackUrl address as shown in the example request format below. At the end of the process, the member merchant receives html content information. This content is decoded in base64 to obtain an html. The obtained html is redirected to the 3D authentication page, where the authentication code is entered and the result of the 3D authentication is seen.
In test environment, the "https://sandbox-paymentapi.tami.com.tr/payment/auth" URL will be used.
In production environment, the "https://paymentapi.tami.com.tr/payment/auth" URL will be used.
The request structure required for Virtual POS Cash/Installment Sales transactions without 3D is indicated in the table below. The information and explanations in the request message should be examined, and the request message should be provided according to the rules specified in this table:
Field | Format | Maximum Size | (O)ptional/(C)onditional/(M)andatory | Description |
---|---|---|---|---|
orderId | String | (2-36) | M | The payment request is a singular communication information used in the interaction between Tami-customer. For the merchant and POS pair, this value must be singular. |
amount | Decimal | M | The amount is the transaction. The fractional separator must be a period (.). | |
currency | String | 3 | M | Specifies the currency code of the transaction. Example: TRY should be sent for TL. |
installmentCount | Number | M | This is the installment information of the desired transaction. For cash transactions, 1 must be sent. Sending 0 is not accepted. | |
paymentGroup | String | M | Payment group, default PRODUCT should be forwarded | |
paymentChannel | enum | O | Payment channel. Valid values are provided in the enum: WEB, MOBILE, MOBILE_WEB, MOBILE_IOS, MOBILE_ANDROID, MOBILE_WINDOWS, MOBILE_TABLET, MOBILE_PHONE | |
callbackUrl | String | C | If a transaction is desired to be carried out in 3D, it must be sent. The address to which the 3D verification result will be returned is the address associated with the merchant. | |
card | Object | M | ||
cvv | String | M | The security code of the card from which the payment will be taken. | |
expireMonth | Number | (1-12) | M | Expiration date and month of the card from which the payment will be taken. |
expireYear | Number | 4 | M | The expiration date and year of the card from which the payment will be taken. |
holderName | String | 30 | M | Name and surname of the cardholder from whom the payment will be received. |
number | String | (5-35) | M | The card number from which the payment will be received. |
billingAddress | Object | O | ||
address | String | 400 | O | Billing address information on the merchant side. |
emailAddress | String | O | E-mail information of the merchant | |
city | String | 30 | O | Billing address city information on the merchant side. |
companyName | String | 100 | O | Trade name information of the merchant. |
country | String | 50 | O | Country of the billing address on the merchant side. |
contactName | String | 30 | O | Billing address, name and surname information on the merchant side. |
phone | String | O | GSM number of the buyer on the merchant side. | |
zipCode | String | 15 | O | Postal code of the billing address on the merchant side. |
district | String | 50 | O | Neighborhood information of the billing address on the merchant side. |
shippingAddress | Object | O | ||
address | String | 400 | O | Delivery address information on the merchant side. |
emailAddress | String | O | E-mail information of the merchant | |
city | String | 30 | O | Delivery address city information on the merchant side. |
country | String | 50 | O | Delivery address country information on the merchant side. |
contactName | String | 30 | O | Delivery address, name and surname information on the merchant side. |
zipCode | String | 15 | O | Postal code information of the delivery address on the merchant side. |
district | String | 50 | O | Delivery address neighborhood information on the merchant side. |
buyer | Object | M | Contains information about the buyer on the merchant side | |
ipAddress | String | M | It is the IP address of the buyer on the merchant side. The real IP address of the recipient must be transmitted. | |
buyerId | String | 50 | M | The buyer's id on the merchant side. |
name | String | 30 | M | Name of the buyer on the merchant side. |
surName | String | 30 | M | Last name of the buyer on the merchant side. Buyer object is an optional field, but if any field from the buyer object is sent, surname is required. |
identityNumber | String | 11 | O | Identification number of the buyer on the merchant side. |
city | String | 50 | O | City information of the recipient on the merchant side. |
country | String | 50 | O | Country information of the buyer on the merchant side. |
emailAddress | String | M | The e-mail information of the recipient on the merchant side. The e-mail address must be a valid and accessible address of the recipient. | |
phoneNumber | String | M | The GSM number of the buyer on the merchant side. | |
registrationAddress | String | 400 | O | Recipient's registration address on the merchant side. |
zipCode | String | 15 | O | Postal code of the recipient on the merchant side. |
registrationDate | Date | O | Recording date of the buyer on the merchant side. The date format should be 2015-09-17 23:45:06. | |
lastLoginDate | Date | O | Last receipt date for the merchant-side buyer. The date format should be 2015-09-17 23:45:06. | |
basket | O | |||
basketId | String | 50 | C | The id of the basket on the merchant side. If an item is sent in the basket, it is mandatory to send basketId. |
basket/basketItems | List | 0 | ||
itemId | String | 50 | C | The id of the product in the basket on the merchant side. If the item is transmitted in the basket, it is mandatory to send itemId. |
itemType | String | 50 | C | The type of the product in the cart at the merchant. Valid enum values: PHYSICAL and VIRTUAL. If an item is sent in the basket, the itemType must be sent. |
name | String | 50 | C | The name of the product in the basket on the merchant side. If the item is sent in the basket, it is mandatory to send the name. |
category | String | 50 | O | The category of the product in the cart on the merchant side. |
subCategory | String | 100 | O | Subcategory of the product in the cart on the merchant side. |
unitPrice | Decimal | min 0.0 | O | The single amount of the product in the basket on the merchant side. |
totalPrice | Decimal | min 0.0 | C | The total amount of the product in the basket on the merchant side. It cannot be 0 and less than 0, the sum of the amounts must be equal to the basket amount. If an item is sent in the basket, totalPrice must be sent. Unitprice * numberOfProducts = totalPrice |
numberOfProducts | Number | 1-99999 | O | The number of products in the basket on the merchant side. |
securityHash | String | M | It is the value expected to be calculated and transmitted according in the document. If it is missing or incorrect, the transaction is not routed to the bank, an error is given. |
Parametre Adı | Format | Description |
---|---|---|
success | String | If True, the sale is successful. If False is returned, an error was received. Error details are shared in errorCode and errorMessage fields. |
systemTime | DateTime | Transaction date |
correlationId | String | Transaction number |
orderId | String | Order number |
amount | Number | Transaction amount |
currency | String | Transaction currency |
card/binNumber | String | First 8 digits of the card |
card/maskedNumber | String | Masked card trick |
card/cardBrand | String | Card brand |
card/cardOrganization | String | Card organization |
card/cardType | String | Card type |
threeDSHtmlContent | It is the html content information that will redirect to the 3d validation page. The content is decoded in base 64 to get Html. | |
errorCode | String | Error code |
errorMessage | String | Error message |
securityHash | String | The value to be used to determine that the result of the operation comes from the correct source. The documentation describes how to calculate it. |
After starting the 3D Secure process, the bank's 3D verification screen will be displayed with the HTML data obtained. After the cardholder enters the code sent to their mobile phone, they will be automatically redirected to the address specified in the callbackUrl parameter. Tami will post the following values to this address. If the 3D verification is successful, no money has been withdrawn from the card yet. When the returned success field is true in the response, you can proceed to the next step to convert the transaction into payment for the next 3D secure sales transaction.
Parametre Adı | Format | Açıklama |
---|---|---|
cardBrand | String | Card Brand |
cardOrganization | String | Card Organization |
cardType | String | Card Type |
currencyCode | String | Transaction Currency |
hashedData | String | Value to be used to check the accuracy of the information returned in the answer |
installmentCount | Number | Number of Transaction Installments |
maskedNumber | Number | Card number as masked |
mdStatus | String | It is the mdStatus value returned for informational purposes. It can return 1 for successful cases and 0, 2, 3, 4, 4, 5, 5, 6, 7, 8 for unsuccessful cases. |
orderId | String | Order number |
success | String | Reports the result of the 3d verification process. Returns true if the operation is successful, false if the operation is failed |
systemTime | DateTime | Transaction date |
txnAmount | Number | Transaction amount |
In case the Success field returned in the 3D Validation response is false, the table below will help with the cause of the error.
mdStatus | Format |
---|---|
mdStatus = 0 | 3D Secure signature or verification invalid |
mdStatus = 2 | Cardholder or bank not registered in the system |
mdStatus = 3 | The bank of the card is not registered in the system |
mdStatus = 4 | Verification attempt, cardholder chose to register later in the system |
mdStatus = 5 | Unable to verify |
mdStatus = 6 | 3D Secure error |
mdStatus = 7 | System error |
mdStatus = 8 | Unknown card no |
To verify that the information returned in the 3D Verification response is from the correct source, you can calculate hashedData according to the fields below and compare it with this information in the response. SecretKey is different for each pos belonging to the merchant.
When calculating HashedData, a data is created by bringing all the following parameters side by side in the given order. The secretKey of the merchant is hashed with HMAC sha256 and secretKeySpec is obtained. Two data are sorted in the format specified in the generator below. Base 64 is encrypted and encrypted hashedData is obtained.
NOTE: In advance transactions, "InstallmentCount" is expected to be sent as 1. This information is added to the hashedData.
Parameters used in HashedData calculation;
cardOrg+cardBrand+cardType+maskedNumber+installmentCount+currency+originalAmount+orderID+systemTime+status (success field)
The generator to be used in HashedData calculation is given below;
It is used for Tami merchants to complete transactions that have been successfully 3d verified. By calling this service, the card is not charged for transactions that are not completed in 3d.
In test environment, the "https://sandbox-paymentapi.tami.com.tr/payment/complete-3ds" URL will be used.
In production environment, the "https://paymentapi.tami.com.tr/payment/complete-3ds" URL will be used.
Field | Format | Max Size | (O)psiyonel / (M)andatory | Description |
---|---|---|---|---|
orderId | String | (2-36) | M | Order number information with successful completion of 3d verification |
securityHash | String | M | It is the value expected to be calculated and transmitted according to the fields specified in the document. If it is missing or incorrect, the transaction is not routed to the bank, an error is given. |
Field | Format | Description |
---|---|---|
errorCode | String | Error code |
errorMessage | String | Error message |
success | String | If true, the sale is successful, if false, an error was received. Error details are shared in error code and error message fields |
systemTime | dateTime | Transaction date |
correlationId | String | Transaction number |
orderId | String | Order number |
amount | Number | Transaction amount |
currency | String | Transaction currency information |
installmentCount | Number | Transaction installment count |
card/binNumber | String | First 8 digits of the card |
card/maskedNumber | String | Masked card trick |
card/cardBrand | String | Card brand |
card/cardOrganization | String | Card organization |
card/cardType | String | Card type |
securityHash | String | Hash information to check that the transaction has returned from the correct source |
You can use the documentation here to calculate the securityHash field in service requests and incoming service responses.
You can access the list of error codees on this page.
You can access the list of test cards on this page.
Key | Value |
---|---|
correlationId | PG-Auth-Token |
Correlation{{randomNumber}} | {{merchantNumber}}:{{terminalNumber}}:{{hash}} |
Response
"PG-Auth-Token" parameter should be passed in the header in all sales, cancellation/refund, pre-authorization, pre-authorization closure, 3D sales and 3D sales completion requests.
This information consists of "merchantNumber:TerminalNumber:Hash" information of the merchant. The hash information is expected to be calculated according to the requested values and added to the PG-Auth-Token parameter.