# Getnet
Merchants can configure transactions on **Carat Portal** to be routed by many acquirers and payment methods. One of these is Getnet e-commerce, hereafter mentioned as GetnetWS.
In this page, the nomenclature "**GetnetWS**" will be used to reference the acquirer on Carat Portal.
Thus, the store can configure **Carat Portal** so that transactions made with VISA cards, for example, are routed through **GetnetWS** while those made with MASTERCARD are routed through CIELO.
## Supported Carat Portal interfaces
The following interfaces for integration with GetnetWS are available:
- REST Payment
- REST Pre-Authorization
- REST Cancel
- HTML Payment
- HTML Pre-Authorization
## Allowed Authorizers / Issuers
The following authorizers / issuers are available for integration with GetnetWS:
- VISA
- MASTERCARD
- ELO
- AMERICAN EXPRESS
- HIPERCARD
## Required credentials
**The merchant must obtain with GetnetWS the credentials listed below**, and pass them to Software Express or make the registration as explained later in this document.
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Description",
    "h-2": "Format",
    "0-0": "`username`",
    "0-1": "Access user name.",
    "0-2": "20 N",
    "1-0": "`password`",
    "1-1": "Access password.",
    "1-2": "40 AN",
    "2-0": "`merchantID`",
    "2-1": "EC code registered on GetnetWS.",
    "2-2": "10 AN",
    "3-0": "`terminal`",
    "3-1": "Terminal identification.",
    "3-2": "7 AN",
    "4-0": "`subMerchantId`",
    "4-1": "Submerchant ID.",
    "4-2": "\\< 15 AN"
  },
  "cols": 3,
  "rows": 5,
  "align": [
    "center",
    "center",
    "center"
  ]
}
[/block]
**Important for HTML Payment**: If the merchant has not registered these credentials, this authorizer will not be displayed on the credit card selection screen during the payment transaction.
## Registration of information through the merchant's portal
The merchant can register the information obtained with GetnetWS on the Merchant's Portal on Carat Portal. In this environment, you can change the authentication settings and password of the transactions. For this purpose, the merchant must select the authorizer and enter the editing screen as in the example shown below:
[block:image]
{
  "images": [
    {
      "image": [
        "https://files.readme.io/a549c3d2d9a42fcdbbfefbba09d20766e313bbd7f4b5c4dcfe43fce4d4accd6f-roteamento-getnetws-portal.png",
        null,
        null
      ],
      "align": "center"
    }
  ]
}
[/block]
In the editing environment of the Authorizer, you can change the password registered on the Carat Portal environment. In this case, the change will only occur for this authorizer. Note that if merchant uses the same GetnetWS account, it will be necessary to manually change passwords for all the other authorizers.
Also in this environment, you can also change the registration password on Getnet. It is important to remember that when changing this password on the Getnet environment all the stores associated with this account on Getnet will also have to change the password registered on the Carat Portal environment by going to the edit screen of their authorizer, otherwise Getnet will deny their transactions.
The screen for changing the password on Getnet:
[block:image]
{
  "images": [
    {
      "image": [
        "https://files.readme.io/4266260438f6be89d7abe27235c74a3c0166bba93532eaab186614ed56faf1f1-roteamento-getnetws-portal-senha.png",
        null,
        null
      ],
      "align": "center"
    }
  ]
}
[/block]
The new password must follow the rules defined by Getnet. These rules can be found in the integration document.
## SoftDescriptor Registration on Carat Portal
## Subacquiring
Information related to subacquiring are registered by our support team. The following data are required:
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Format",
    "0-0": "Submerchant ID",
    "0-1": "\\< 15 AN",
    "1-0": "Submerchant City",
    "1-1": "\\< 13 A",
    "2-0": "Submerchant State",
    "2-1": "= 2 A",
    "3-0": "Submerchant Zip Code",
    "3-1": "= 8 N",
    "4-0": "Submerchant CNPJ or CPF",
    "4-1": "\\< 15 AN",
    "5-0": "Submerchant Street Name",
    "5-1": "\\< 40 AN",
    "6-0": "MCC",
    "6-1": "= 4 N",
    "7-0": "Soft-Descriptor",
    "7-1": "\\< 22 AN [Learn more](./soft-descriptor.md#getnet-ws)"
  },
  "cols": 2,
  "rows": 8,
  "align": [
    "left",
    "left"
  ]
}
[/block]
The following fields can also be sent inside Carat Portal requests:
| Parameter       | Field                     | Notes                                             |
| :-------------- | :------------------------ | :------------------------------------------------ |
| Submerchant ID  | `subacquirer_merchant_id` | Sent in the payment effectuation service request. |
| MCC             | `mcc`                     | Sent in the payment effectuation service request. |
| Soft-Descriptor | `soft_descriptor`         | Sent in the transaction creation service request. |
If the fields above are both registered in the merchant's configurations and sent inside the request, the value inside the request has precedence.
## Recurrency
In order to acknowledge a recurrent payment, the GetnetWS integration establishes some rules that will be explained in this section.
The fields used in recurrencies are presented below.
[block:parameters]
{
  "data": {
    "h-0": "Field",
    "h-1": "Description",
    "h-2": "Format",
    "0-0": "`acquirer.recurrency`",
    "0-1": "Sent inside the request. Flag that defines whether or not the payment is recurring.",
    "0-2": "\\< 5 T/F",
    "1-0": "`acquirer.recurrency_tid`",
    "1-1": "Sent inside the request. First transaction's TID. This field tells the first and the subsequent transactions apart.",
    "1-2": "= 18 N",
    "2-0": "`acquirer.recurrency_seq_id`",
    "2-1": "Sent inside the request. Represents the current installment number.",
    "2-2": "\\< 3 N",
    "3-0": "`payment.tid`",
    "3-1": "Received inside the response. It is the acquirer's transaction ID.",
    "3-2": "= 18 N"
  },
  "cols": 3,
  "rows": 4,
  "align": [
    "left",
    "left",
    "left"
  ]
}
[/block]
If the merchant **does the recurrencies by himself/herself**, he/she must follow the following steps:
- **Step 1**: First recurrency:
  - Send `acquirer.recurrency` as **true**;
  - Store `payment.tid` to use in the subsequent recurrencies.
- **Step N**: Subsequent recurrencies:
  - Send `acquirer.recurrency` as **true**;
  - Send `acquirer.recurrency_tid` with the value of the `payment.tid` field stored in **Step 1**;
  - Send `acquirer.recurrency_seq_id` with the current installment number (from 1 up to 999).
If the merchant **does the recurrencies by using Carat Portal schedule service**, the recurrency fields will be sent automatically and the recurrency processing can be monitored in the schedules reports as usual.
If the merchant **does the recurrencies by using Carat Portal payment with schedule service**, the recurrency fields will be sent automatically and the recurrency processing can be monitored in the schedules reports as usual. However, the ID used to identify the first recurrency transaction is the initial payment transaction ID and **it is not** the first scheduled payment ID.
## Transaction Flow
In this section, we will present the particularities of the Getnet transactional flow.
### HTML Payment
It's possible to do a payment with 3DS authentication. For this, just send the `authorizer_authentication` parameter with the value `true` on the transaction creation phase.
Relevant fields in the call described in [HTML Transaction Creation Service](pagamento-html-begin) and [REST Transaction Creation Service](pagamento-rest-begin):
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Description",
    "h-2": "Format",
    "h-3": "Mandatory",
    "0-0": "`authorizer_authentication`",
    "0-1": "Identifies whether the merchant wants a payment with authentication. If positive, send `true`.",
    "0-2": "\\< 5 AN",
    "0-3": "YES for credit with authentication",
    "1-0": "**iata**",
    "1-1": "This element contains specific fields that will be mandatory, if are with IATA transactions.",
    "1-2": "",
    "1-3": "",
    "2-0": "`first_installment`",
    "2-1": "Amount of the first installment on IATA transactions in cents.",
    "2-2": "\\< 12 N",
    "2-3": "Conditional (required only for IATA transactions - sale of airline tickets)",
    "3-0": "`departure_tax`",
    "3-1": "Departure tax in cents.",
    "3-2": "\\< 12 N",
    "3-3": "Conditional (required only for IATA transactions - sale of airline tickets)"
  },
  "cols": 4,
  "rows": 4,
  "align": [
    "center",
    "center",
    "center",
    "center"
  ]
}
[/block]
### Pre-Authorization
It isn't possible to perform a pre-authorization with issuer installment funding.
Relevant fields in the call described in [HTML Transaction Creation Service](pre-autorizacao-html) and [REST Transaction Creation Service](pre-autorizacao-rest-begin.md):
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Description",
    "h-2": "Format",
    "h-3": "Mandatory",
    "0-0": "**iata**",
    "0-1": "This element contains specific fields that will be mandatory, if are with IATA transactions.",
    "0-2": "",
    "0-3": "",
    "1-0": "`first_installment`",
    "1-1": "Amount of the first installment on IATA transactions in cents.",
    "1-2": "\\< 12 N",
    "1-3": "Conditional (required only for IATA transactions - sale of airline tickets)",
    "2-0": "`departure_tax`",
    "2-1": "Departure tax in cents.",
    "2-2": "\\< 12 N",
    "2-3": "Conditional (required only for IATA transactions - sale of airline tickets)"
  },
  "cols": 4,
  "rows": 3,
  "align": [
    "center",
    "center",
    "center",
    "center"
  ]
}
[/block]
### Edit Pre-Authorization
It's possible to re-send the pre-authorization effectuation request with the `amount` field to alter its amount.
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Description",
    "h-2": "Format",
    "h-3": "Mandatory",
    "0-0": "`amount`",
    "0-1": "New pre-authorization amount in cents.",
    "0-2": "\\< 12 N",
    "0-3": "YES"
  },
  "cols": 4,
  "rows": 1,
  "align": [
    "center",
    "center",
    "center",
    "center"
  ]
}
[/block]
### REST Payment and Pre-Authorization
- The `card`.`holder` field is mandatory.
- GetnetWS accepts sending authentication data: `eci`, `xid` and `cavv`.
[block:parameters]
{
  "data": {
    "h-0": "Parameter",
    "h-1": "Description",
    "h-2": "Format",
    "h-3": "Mandatory",
    "0-0": "`card`.`holder`",
    "0-1": "Card holder name.",
    "0-2": "\\< 26 AN",
    "0-3": "**YES**",
    "1-0": "`external_authentication`.`eci`",
    "1-1": "ECI Code of the 3D Secure authenticated transaction.",
    "1-2": "= 2 N",
    "1-3": "NO",
    "2-0": "`external_authentication`.`xid`",
    "2-1": "MPI ID for each authenticated transaction.",
    "2-2": "\\< 40 AN",
    "2-3": "NO",
    "3-0": "`external_authentication`.`cavv`",
    "3-1": "Authentication code encrypted by the issuer.",
    "3-2": "\\< 40 AN",
    "3-3": "NO"
  },
  "cols": 4,
  "rows": 4,
  "align": [
    "center",
    "center",
    "center",
    "center"
  ]
}
[/block]
### Refund
Transaction refunding can be done through the Merchant’s Portal. Only transactions made on the current day can be refunded. The merchant can refund pre-authorization transactions with or without capture and payment transactions. If you refund a pre-authorization transaction with capture, Getnet will refund the capture, however, Carat Portal will display this pre-transaction with status refunded (and confirmed capture).