Checkout Payments API
Capture, refund, and cancel an authorized Payment.
After a Payment has been authorized and commercetools Checkout has created an Order, you might need to perform actions on the Payment during its lifecycle. The Checkout Payments API lets you send requests to capture, refund, or cancel an authorized Payment.
Following your request via the Checkout Payments API, Checkout will request the payment service provider (PSP) to perform the related financial process.
Scope
Scope | Permission granted |
---|---|
manage_checkout_payment_intents:{projectKey} | Send capture, refund, or cancel requests to the payment service provider (PSP) and update the Payment by calling the payment Connector. |
Representations
PaymentAction
Depending on the action specified, Checkout requests the payment service provider (PSP) to capture, refund, or cancel the authorization for the given Payment.
action | Action to execute for the given Payment. |
amount | Amount to be captured or refunded. |
Amount
The amount related to a payment action.
centAmount Int | Amount in the smallest indivisible unit of a currency, such as:
|
currencyCode String | Currency code compliant to ISO 4217. Pattern:^[A-Z]{3}$ |
PaymentOperation
The possible values for a payment action.
Region
The Region in which the Checkout application is hosted.
europe-west1.gcp
for Europe (Google Cloud, Belgium)
us-central1.gcp
for North America (Google Cloud, Iowa)
australia-southeast1.gcp
for Australia (Google Cloud, Sydney)
Manage Payment by ID
Specific Error Codes:
manage_checkout_payment_intents:{projectKey}
region String | |
projectKey String | Identifier of your Checkout entity and |
paymentId String |
|
application/json
actions Array of PaymentAction | Action to execute for the given Payment. MinItems:1 MaxItems: 1 |
any
asapplication/json
curl https://checkout.{region}.commercetools.com/{projectKey}/payment-intents/{paymentId} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}' \--header 'Content-Type: application/json' \--data-binary @- << DATA{"actions" : [ {"action" : "capturePayment","amount" : {"centAmount" : 10000,"currencyCode" : "EUR"}} ]}DATA
{}
Manage Payment actions
Capture Payment
Requests to capture the given amount from the customer. Checkout will request the PSP to proceed with the financial process to capture the amount.
action String | "capturePayment" |
amount | Amount to be captured. It must be less than or equal to the authorized amount. |
{"action": "capturePayment","amount": {"centAmount": 10000,"currencyCode": "EUR"}}
Refund Payment
Requests to refund the given amount to the customer. Checkout will request the PSP to proceed with the financial process to refund the amount.
Cancel Payment
Requests to cancel the authorization for a Payment. Checkout will cancel the Payment and will request the PSP to proceed with the financial process to cancel the authorization.
You cannot request to cancel the authorization for a Payment that has already been captured.
action String | "cancelPayment" |
{"action": "cancelPayment"}
Errors
500 Internal Server Error
The following general error code can appear in responses with the HTTP status code 500
:
GeneralError
Returned when a server-side problem occurs. In some cases, the requested action may successfully complete after the error is returned. Therefore, it is recommended to verify the status of the requested resource after receiving a 500 error.
If you encounter this error, report it to the Checkout support team.
code String | "General" |
message String | Description about any known details of the problem, for example, |
400 Bad Request
The following error codes can appear in responses with the HTTP status code 400
:
MultipleActionsNotAllowed
Returned when actions
in the request body contains more than one object.
code String | "MultipleActionsNotAllowed" |
message String |
|
RequiredField
Returned when a value is not defined for a required field.
code String | "RequiredField" |
message String |
|
field String | Name of the field missing the value. |
404 Not Found
The following error code can appear in responses with the HTTP status code 404
:
ResourceNotFound
Returned when the resource addressed by the request URL does not exist.
code String | "ResourceNotFound" |
message String |
|