Manage Unzer Installment payment
Manage Unzer Installment payments.
If you are using payment type installment-secured
, note that this method is now deprecated. It’s currently supported but there are no further developments planned for it.
If you want to access the relevant documentation, see Installment Secured.
After the successful authorize transaction, you can perform additional operations on the payment resource. Some of the important ones are described in the following section.
For a full reference of managing payments, go to relevant server-side integration documentation page: Manage API resources (direct API calls).
Reauthorize the authorization
Reauthorize the authorizationThe authorization patch request changes a previously authorized amount of a purchase with Unzer invoice, Unzer Installment, and Direct Debit Secured methods. It contains the amount value. The customer information from the referenced authorization request is used for another internal risk check. Within a few seconds a response is returned:
Declined: The new amount was not accepted. The originally authorized amount is still valid.
Accepted: The previous amount of authorization is updated and the new one is reserved for charge.
PATCH: https://api.unzer.com/v1/payments/s-pay-1/authorize
{
"amount": "100",
"currency": "EUR"
}
{
"id": "s-aut-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "100.0000",
"currency": "EUR",
"date": "2024-04-09 13:16:22",
"resources": {
"customerId": "s-cst-8cbf627620c7",
"paymentId": "s-pay-4404",
"basketId": "s-bsk-1f4da5b7e014"
"payPageId": "",
"traceId": "20ff08289ea6ea977049e168dc75a2a7",
"typeId": "s-pit-bfte2gs2u0kq"
},
"additionalTransactionData": {
"riskData": {
"threatMetrixId": "f544if49wo4f74ef1x",
"customerGroup": "TOP",
"customerId": "C-122345",
"confirmedAmount": "2569",
"confirmedOrders": "14",
"internalScore": "95",
"registrationLevel": "1",
"registrationDate": "20160412"
}
},
"orderId": "ORD-8282",
"invoiceId": "INV-7098",
"processing": {
"uniqueId": "Tx-yr3nq9rrkze",
"shortId": "Tx-yr3nq9rrkze",
"traceId": "20ff08289ea6ea977049e168dc75a2a7"
}
}
Full charge
Making a charge
transaction signals you are shipping goods to your customer while capturing the respective order amount.
The charge call is a crucial API call that initiates two processes:
- It starts the installment plan for the consumers. The customer will get the installment plan from Unzer with all relevant payment details in on it.
- The other process, which is initiated, is the payout of the charged amount to the merchant
POST: https://api.unzer.com/v1/payments/s-pay-1/charges
{
}
$unzer = new UnzerSDK\Unzer('s-priv-xxxxxxxxxx');
$payment = $unzer->fetchPayment('s-pay-1');
$transaction = $unzer->performChargeOnPayment($payment, new Charge());
Unzer unzer = new Unzer("s-priv-xxxxxxxxxx");
Charge charge = unzer.chargeAuthorization("s-pay-101");
The response looks similar to the following example:
{
"id": "s-chg-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "100.0000",
"currency": "EUR",
"date": "2023-04-25 09:28:44",
"resources": {
"customerId": "s-cst-72e4cfed0be5",
"paymentId": "s-pay-1",
"basketId": "s-bsk-1f4da5b7e014",
"traceId": "20ff08289ea6ea977049e168dc75a2a7",
"typeId": "s-pit-bfte2gs2u0kq"
},
"orderId": "ORD-8282",
"invoiceId": "INV-7098",
"paymentReference": "",
"processing": {
"uniqueId": "Tx-yr3nq9rrkze",
"shortId": "Tx-yr3nq9rrkze",
"traceId": "20ff08289ea6ea977049e168dc75a2a7"
}
}
Provide shipping information
To allow Unzer to track the customer’s order, you can provide shipping information in your charges request. Based on the information provided payment plans can be paused for example, due to a refund.
Shipping information can be provided in the following fields:
Parameter | Type | Description |
---|---|---|
deliveryTrackingId (optional) | string | Tracking ID of the selected delivery service provider for the delivery to the customer. |
returnTrackingId (optional) | string | Tracking ID of the selected delivery service provider if the customer is returning goods to you. |
deliveryService (optional) | string | Delivery service provider used for ship the goods to your customer (such as, DHL, UPS, and Hermes) |
POST: https://api.unzer.com/v1/payments/s-pay-1/charges
{
"amount": "50",
"additionalTransactionData": {
"shipping": {
"deliveryTrackingId": "00340434286851877897",
"returnTrackingId": "00123434286851877897",
"deliveryService": "DHL"
}
}
$unzer = new UnzerSDK\Unzer('s-priv-xxxxxxxxxx');
$shipping = (new ShippingData())
->setDeliveryTrackingId("00340434286851877897")
->setReturnTrackingId("00340434286851877897")
->setDeliveryService("DHL");
$charge = (new Charge(50.00))
->setShipping($shipping);
$transaction = $unzer->performChargeOnPayment('s-pay-1', $charge);
Unzer unzer = new Unzer("s-priv-xxxxxxxxxx");
ShippingTransactionData shippingData = new ShippingTransactionData()
.setDeliveryService("DHL"))
.setReturnTrackingId("00340434286851877897")
.setDeliveryTrackingId("00340434286851877897");
Charge charge = new Charge()
.setPaymentId("s-pay-1")
.setAmount(new BigDecimal("50.00"))
.setAdditionalTransactionData(
new AdditionalTransactionData().setShipping(shippingData)
);
Charge response = unzer.chargeAuthorization(charge);
Partial charge
If you ship an order in multiple steps, you can make a partial charge for each part you want to ship.
The charge call is a crucial API call that initiates two processes:
- It starts the installment plan for the consumers. The customer will get the installment plan from Unzer with all relevant payment details in on it.
- The other process, which is initiated, is the payout of the charged amount to the merchant
POST: https://api.unzer.com/v1/payments/s-pay-1/charges
{
"amount" : "50",
}
$unzer = new UnzerSDK\Unzer('s-priv-xxxxxxxxxx');
$payment = $unzer->fetchPayment('s-pay-1');
$transaction = $unzer->performChargeOnPayment($payment, new Charge(50.00));
Unzer unzer = new Unzer("s-priv-xxxxxxxxxx");
Charge charge = unzer.chargeAuthorization("s-pay-1", new BigDecimal("50.00"));
The response looks similar to the following example:
{
"id": "s-chg-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "50.0000",
"currency": "EUR",
"date": "2023-04-25 09:28:44",
"resources": {
"customerId": "s-cst-72e4cfed0be5",
"paymentId": "s-pay-1",
"basketId": "s-bsk-1f4da5b7e014",
"traceId": "20ff08289ea6ea977049e168dc75a2a7",
"typeId": "s-pit-bfte2gs2u0kq"
},
"orderId": "ORD-8282",
"invoiceId": "INV-7098",
"paymentReference": "",
"processing": {
"uniqueId": "Tx-yr3nq9rrkze",
"shortId": "Tx-yr3nq9rrkze",
"traceId": "20ff08289ea6ea977049e168dc75a2a7"
}
}
You should also provide the shipping information as previously explained in the full charge section.
Cancel before charge (reversal)
If the customer cancels an order completely before you ship the goods or if the goods are not available in stock, you must cancel the order by initializing a reversal.
charge
the remaining items as soon as you ship it.POST: https://api.unzer.com/v1/payments/s-pay-71/authorize/cancels
{
}
$unzer = new Unzer('s-priv-xxxxxxxxxx');
$cancel = $unzer->cancelAuthorizedPayment('s-pay-1');
Unzer unzer = new Unzer("s-priv-xxxxxxxxxx");
Cancel cancel = unzer.cancelAuthorization("s-pay-1");
The response looks similar to the following example:
{
"id": "s-cnl-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "899.5000",
"currency": "EUR",
"date": "2023-04-25 10:32:21",
"resources": {
"customerId": "s-cst-c697a3337a42",
"paymentId": "s-pay-71",
"basketId": "s-bsk-216c7c65ff5d",
"traceId": "e3d93993a1723b4da001853599a7c892",
"typeId": "s-pit-djs8ygsptueq"
},
"orderId": "order-1682418644054-775",
"invoiceId": "iv_1682418644054",
"paymentReference": "",
"processing": {
"uniqueId": "Tx-qprmnpt4wg3",
"shortId": "Tx-qprmnpt4wg3",
"traceId": "e3d93993a1723b4da001853599a7c892"
}
}
Dunning delay (refund announcement)
Dunning delay (refund announcement)This is the prior step required for refund (issued charge cancellation). The merchant announces the charge cancellation, and the fulfillment date will be moved accordingly.
Typical events are customer phone calls or printing return stickers (RMA). They help to prevent unjustified dunning of customers.
POST: https://api.unzer.com/v1/payments/s-pay-1/charges/dunning-delay
{
}
{
"id": "s-dly-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "0.0000",
"currency": "EUR",
"date": "2024-04-09 13:29:43",
"resources": {
"customerId": "s-cst-472f919218b5",
"paymentId": "s-pay-4404",
"basketId": "s-bsk-17387257b8fa",
"metadataId": "s-mtd-nwttumjh10h6",
"payPageId": "",
"traceId": "20ff08289ea6ea977049e168dc75a2a7",
"typeId": "s-pit-bfte2gs2u0kq"
},
"orderId": "ORD-123456",
"invoiceId": "INV-123456",
"paymentReference": "",
"processing": {
"uniqueId": "Tx-yr3nq9rrkze",
"shortId": "Tx-yr3nq9rrkze",
"traceId": "20ff08289ea6ea977049e168dc75a2a7"
}
}
Cancel after charge (refund)
In case you already charged a payment for an order that the customer wants to cancel/return, you can refund it up to the charged amount. To do this you have to make a cancels
transaction on the respective paymentId
.
POST: https://api.unzer.com/v1/payments/s-pay-101/charges/cancels
{
"amount" : "10.00"
}
$unzer = new Unzer('s-priv-xxxxxxxxxx');
$cancel = $unzer->cancelChargedPayment('s-pay-1', new Cancellation(10.00));
Unzer unzer = new Unzer("s-priv-xxxxxxxxxx");
Cancel cancel = unzer.cancelCharge("s-pay-1", new BigDecimal("10.00"));
The response looks similar to the following example:
{
"id": "s-cnl-1",
"isSuccess": true,
"isPending": false,
"isResumed": false,
"isError": false,
"card3ds": false,
"message": {
"code": "COR.000.000.000",
"merchant": "Transaction succeeded",
"customer": "Your payments have been successfully processed."
},
"amount": "10.0000",
"currency": "EUR",
"date": "2023-04-25 13:09:43",
"resources": {
"customerId": "s-cst-8bfeb8b5118c",
"paymentId": "s-pay-101",
"basketId": "s-bsk-c6135882e6ea",
"traceId": "e936d7207bf71e6338286ba6a57b6bdd",
"typeId": "s-pit-nknkqehrgrsw"
},
"orderId": "order-1682428147729-751",
"invoiceId": "iv_1682428147729",
"paymentReference": "",
"processing": {
"uniqueId": "Tx-fpnebaffkut",
"shortId": "Tx-fpnebaffkut",
"traceId": "e936d7207bf71e6338286ba6a57b6bdd"
}
}
charges
initialized after the authorize
are actual payments and can be refunded by canceling them.