Skip to content
Menu

PAYMENT GATEWAY

[THK] F.1.5 End-to-End Example – Recurring Payment (Credit Card – CIT & MIT)

Overview

This example illustrates a complete end-to-end flow for recurring payments using Credit Card, based on:

  • Customer Initiated Transactions (CIT) → initial authorization and consent
  • Merchant Initiated Transactions (MIT) → subsequent recurring charges

It demonstrates how the merchant system:

  • Performs an initial transaction to establish customer consent and tokenization
  • Stores the required identifiers for future use
  • Executes recurring payments without customer interaction
  • Processes asynchronous updates via Webhooks
  • Confirms final transaction states using the Status Inquiry endpoint

This scenario represents a multi-phase lifecycle, where the initial transaction enables a sequence of future automated payments.

Goal

Enable recurring payments using a credit card, ensuring:

  • Proper initial authorization and consent (CIT)
  • Secure storage of tokenized payment credentials
  • Correct execution of subsequent recurring payments (MIT)
  • Reliable transaction validation and reconciliation

Preconditions

Before executing this flow, the following must be in place:

  • Valid SPG credentials:
    • terminalId
    • X-IBM-Client-Id
    • Bearer token
  • Configured Webhook endpoint
  • Backend capable of storing:
    • transactionID
    • originalTransactionId
    • originalTransactionDateTime
    • token (if applicable)
  • Recurring business rules defined (frequency, amount, duration)
Notification

In Postman, ensure the following variables are configured:

    • terminalId
    • ClientID
    • Bearer
    • host

(See collection root variables in SIBS PAYMENT GATEWAY POSTMAN Collection)

Phase 1 – Initial Transaction (CIT / Authorization & Tokenization)

Step 1 – Create Checkout (CIT)

The merchant creates a checkout for the initial customer-initiated transaction.

Endpoint

POST <ROOT_URL>/api/v2/payments

Headers

Authorization: Bearer <AuthToken>
X-IBM-Client-Id: <clientId>
Content-Type: application/json
Accept: application/json

Example Request

{
    "merchant": {
        "terminalId": 11111,
        "channel": "web",
        "merchantTransactionId": "ORDER-CIT-0001"
    },
    "transaction": {
        "transactionTimestamp": "2026-04-15T14:00:00.000Z",
        "description": "Initial recurring setup",
        "paymentType": "AUTH",
        "amount": {
            "value": 0.00,
            "currency": "EUR"
        },
        "paymentMethod": [
            "CARD"
        ]
    }
}
Info

Execute this step in Postman using:

Collection Path:

SIBS PAYMENT GATEWAY → Card → Checkout Card

Key Outputs

  • transactionID
  • formContext
  • transactionSignature

The transactionID must be used as the primary correlation identifier across all subsequent steps, including webhook processing and status validation.

Step 2 – Customer Interaction (Consent & Authentication)

The customer is redirected to the hosted payment form.

<script src="https://spg.qly.site1.sibs.pt/assets/js/widget.js?id={transactionID}"></script>

<form
  spg-context="{formContext}"
  spg-config='{"redirectUrl":"https://merchant.example.com/return"}'>
</form>

At this stage:

  • The customer enters card details
  • 3DS authentication may occur
  • Consent for recurring usage is established

Step 3 – Handle Customer Redirection

After authorization, the customer is redirected to the merchant.

Warning

Important

 

The redirect does not guarantee that the authorization is finalized.

 

At this point, the transaction may still be:

  • Pending
  • InProcessing
  • Success

Recommended behavior:

  • Display a “processing authorization” state
  • Trigger backend validation

The backend must use the transactionID obtained during checkout to perform a Status Inquiry request.

Step 4 – Receive and Process Webhook (CIT)

SPG sends a notification with the authorization result.

Example Payload

{
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success"
    },
    "paymentStatus": "Success",
    "paymentMethod": "CARD",
    "paymentType": "AUTH",
    "transactionID": "s2ExampleTxCIT123",
    "notificationID": "notif-cit-001",
    "token": {
        "tokenType": "Card",
        "value": "TKN123456789"
    }
}

Processing Requirements

  • Receive and validate webhook
  • Store and process using notificationID
  • Persist token and transaction identifiers
  • Ensure idempotent processing
  • Acknowledge correctly

Response to SPG

{
    "statusCode": "000",
    "statusMsg": "Success",
    "notificationID": "notif-cit-001"
}

The notificationID must match the value received in the webhook payload.

Warning

Important

 

Webhooks provide event-driven updates only.

 

They must not be used to determine the final transaction outcome.

Step 5 – Confirm CIT (Status Inquiry)

The merchant must confirm that authorization was successful.

Endpoint

GET <ROOT_URL>/api/v2/payments/{transactionID}/status

Headers

Authorization: Bearer <AuthToken>
X-IBM-Client-Id: <clientId>
Content-Type: application/json
Accept: application/json

Example Response

{
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success"
    },
    "paymentStatus": "Success",
    "paymentType": "AUTH",
    "transactionID": "s2ExampleTxCIT123"
}

The identifiers obtained from the CIT transaction (including transactionID, originalTransaction.id, and originalTransaction.datetime) must be stored and reused for subsequent MIT operations.

Rule

The initial transaction must be confirmed as successful before enabling recurring payments.

Phase 2 – Recurring Transactions (MIT)

Step 6 – Execute MIT Payment

The merchant initiates a recurring charge without customer interaction.

Endpoint

POST <ROOT_URL>/api/v2/payments/{transactionID}/card/purchase

Headers

Authorization: Digest <transactionSignature>
X-IBM-Client-Id: <clientId>
Content-Type: application/json
Accept: application/json

Example Request

{
    "amount": {
        "value": 19.99,
        "currency": "EUR"
    },
    "merchantInitiatedTransaction": {
        "type": "UCOF",
        "originalTransaction": {
            "id": "s2ExampleTxCIT123",
            "datetime": "2026-04-15T14:00:00.000Z"
        }
    }
}
Info

Execute this step in Postman using:

Collection Path:

SIBS PAYMENT GATEWAY → Card → MIT Purchase

The MIT request must reference the original CIT transaction to ensure proper linkage and compliance with recurring payment rules.

The MIT transaction must comply with the conditions established during the original CIT transaction, including consent scope, transaction type, and applicable regulatory requirements.

Step 7 – Receive Webhook (MIT)

SPG sends a notification with the authorization result.

Example Payload

{
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success"
    },
    "paymentStatus": "Success",
    "paymentType": "MITR",
    "transactionID": "s2ExampleTxMIT123",
    "notificationID": "notif-mit-001"
}

Processing Requirements

  • Receive the notification
  • Validate authenticity and integrity according to the configured webhook security model (e.g., payload decryption and header validation)
  • Store and process the notification using notificationID as a unique identifier
  • Ensure idempotent processing
  • Acknowledge correctly

Response to SPG

{
    "statusCode": "000",
    "statusMsg": "Success",
    "notificationID": "notif-mit-001"
}

The notificationID must match the value received in the webhook payload.

Warning

Important

 

Webhooks provide event-driven updates only.

 

They must not be used to determine the final transaction outcome.

Step 8 – Confirm MIT (Status Inquiry)

The merchant must confirm that the recurring transaction has been successfully completed.

Endpoint

GET <ROOT_URL>/api/v2/payments/{transactionID}/status

Headers

Authorization: Bearer <AuthToken>
X-IBM-Client-Id: <clientId>
Content-Type: application/json
Accept: application/json

Example Response

{
    "returnStatus": {
        "statusCode": "000",
        "statusMsg": "Success"
    },
    "paymentStatus": "Success",
    "paymentType": "MITR",
    "transactionID": "s2ExampleTxMIT123"
}

Authoritative Rule

The Status endpoint is the single source of truth for the final transaction state.

This ensures consistency between:

  • Merchant-initiated transaction execution (no customer interaction)
  • Webhook notifications
  • Backend processing

This ensures consistency between event execution, webhook notifications, and backend processing, particularly in scenarios involving delays, retries, or asynchronous flows.

Expected Final Outcome

  • CIT → Success
  • MIT → Success

Recurring cycle continues according to business rules.

Implementation Notes

  • CIT establishes customer consent and tokenization
  • MIT executes without customer interaction
  • originalTransaction.id and datetime are mandatory
  • Tokenization may be implicit or explicit
  • Webhooks may arrive before or after status checks
  • Status validation is mandatory for each transaction
  • Failures in MIT must be handled according to retry policies

Use of Postman Collection

The Postman Collections should be used as the execution layer for this example.

Relevant Requests

  • Checkout
SIBS PAYMENT GATEWAY → Card → Checkout Card
  • Status
SIBS PAYMENT GATEWAY → Card → getStatus
  • MIT Purchase
SIBS PAYMENT GATEWAY → Card → MIT Purchase

Use the previously referenced requests to execute each step, validate responses, and simulate different transaction outcomes in sandbox environments.

Recommended Usage

  • Execute initial CIT transaction
  • Validate CIT status and store identifiers
  • Execute MIT transaction
  • Validate MIT status
  • Simulate success and failure scenarios

Final Notes

This example demonstrates the full lifecycle of recurring payments using SPG.

For production-grade implementations:

  • Use API responses for immediate execution flow control
  • Use Webhooks for event-driven updates
  • Use Status Inquiry for final validation

This ensures secure, compliant, and reliable recurring payment processing across all transaction cycles.

Privacy Overview

This website uses cookies so that we can provide you with the best user experience possible. Cookie information is stored in your browser and performs functions such as recognising you when you return to our website and helping our team to understand which sections of the website you find most interesting and useful.

Strictly Necessary Cookies

Strictly Necessary Cookie should be enabled at all times so that we can save your preferences for cookie settings.