This flow completes the payment approval and starts the consumer's payment plan, but does not initiate the settlement process. This flow allows settlement of merchant funds to be deferred until order fulfilment can be confirmed.

1. Auth Flow

  1. Merchant calls the Get Configuration endpoint to retrieve Afterpay order limits, possibly as part of an asynchronous scheduled background process.
  2. Merchant stores these minimum and maximum order values server-side.
  3. Separately, at the checkout, Merchant uses the stored Afterpay minimum and maximum order values to determine if Afterpay should be presented as an available payment method.
  4. Merchant calls the Create Checkout endpoint to retrieve an Afterpay checkout token.
  5. Merchant uses the token in combination with the JavaScript afterpay.js to direct the Consumer through the Afterpay screenflow.
  6. Consumer completes the Afterpay screenflow and is returned to the Merchant website.
  • If the Consumer clicks "confirm", they will be returned to the Merchant website with the orderToken and a status of "SUCCESS".
  • If the Consumer cancels, they will be returned to the Merchant website with the orderToken and a status of "CANCELLED".
  1. Merchant calls the Auth endpoint to confirm the order.
  • Payment status ("APPROVED" or "DECLINED") is only known once Auth has been completed.
  • If the payment was approved by Afterpay, Merchant stores the id of the Payment, and the expires timestamp of the "AUTH_APPROVED" Payment Event, and presents the Consumer with an order confirmation/receipt page.
  • If the payment was declined by Afterpay (e.g. the Consumer’s card details are entered incorrectly), Merchant presents an appropriate message to the Consumer at the checkout.

2. Capture Flow

This part of the flow applies only to orders that received a status of "APPROVED" during the Auth Flow.

The below scenarios occur after the Consumer has seen their order confirmation page and potentially left the Merchant website.

📘

Note

In all cases, the minimum amount that can be captured is $1.00. Capture requests less than $1.00 will be rejected.

Scenario 1: Merchant can completely fulfil the order

(Capture)

  • As soon as it is determined that the entire order will be fulfilled, Merchant calls the Capture Payment endpoint for the entire amount.
  • In this case, the capture amount will match both the originalAmount and openToCaptureAmount of the Payment object, as returned in the Auth response.

Scenario 2: Merchant can partially fulfil the order

(Capture + Void)

  • As soon as it is determined that only part of the order will be fulfilled, Merchant calls the Capture Payment endpoint with the combined total amount for all items that will be fulfilled.
  • Merchant calls the Void endpoint to finalise the order, refunding the openToCapture amount to the consumer and reducing the openToCapture amount to zero.
    • When the auth expiration date/time is reached, if the order still has a paymentState of "AUTH_APPROVED" or "PARTIALLY_CAPTURED", Void will be triggered automatically.

Scenario 3: Merchant fulfils the order incrementally and captures a payment at each fulfilment

( Capture + [ Captures + Voids ])

  • As soon as a shipment is dispatched, Merchant calls the Capture Payment endpoint for the combined value of all applicable items.
    • This can occur multiple times.
    • Any capture request that exceeds the 'openToCapture' amount will fail.
  • As soon as a shipment is determined it cannot be dispatched, Merchant calls the Void endpoint for the combined value of all applicable items.
    • This can occur multiple times.
    • Any void request for an amount exceeding the 'openToCapture' amount will fail.
  • Once the entire 'openToCapture' reaches zero, no further Captures or Voids will be valid.
  • When the auth expiration date/time is reached, if the order still has a paymentState of "AUTH_APPROVED" or "PARTIALLY_CAPTURED", Void will be triggered automatically.

Scenario 4: Merchant cannot completely or partially fulfil the order

(Void)

  • As soon as it is determined that no fulfilment can occur, Merchant calls the Void endpoint to finalise the order, refunding the openToCapture amount to the consumer and reducing the openToCapture amount to zero.
    • When the auth expiration date/time is reached, if the order still has a paymentState of "AUTH_APPROVED", Void will be triggered automatically.
    • Please be mindful that even though an approved auth will expire and void automatically, consumers began their payment plan at the time of auth approval.

🚧

Warning

When the auth expiration date/time is reached, the auth will be automatically voided.