Recurring

MBWAY supports recurring payments, and we streamline this process for you with our payment agreements API.

Create the payment agreement

To create an MBWAY payment agreement, provide the following information when calling our payment agreements API:

Data FieldRequiredDescription
paymentMethodMMBWAY
consumer.nameMFull name of the consumer.
consumer.countryMThe country from which the consumer is shopping.
authenticationSettings.typeMSupply settings for the support authentication flows:APP_NOTIFICATION
frequency.typeCThe type of frequency between consecutive payment charges. Permissible Value are DAILY,WEEKLY.MONTHLY,YEARLY. Mandatory for Subscription Payments and Optional for Stored Credential payments (One Click). We support Subscription Payments for now , One Click to be launched soon.

You can also include the initialPaymentCharge object in this agreement creation call to immediately initiate the first payment without making a separate call. If you include this object, you'll need to specify:

  • The exact amount.value and amount.currency of the first payment

If you don't include an initialPaymentCharge during agreement creation, you'll need to make a separate API call to /v1/payment-agreements/{agreement_id}/payment-charges to create the first charge.

Request

POST /v1/payment-agreements

{
    "paymentMethod": "MBWAY",
    "consumer": {
        "name": "John Smith",
        "country": "PT"
    },
    "frequency": { "type": "MONTHLY"},
    "authenticationSettings": [
        {
            "settings": {
                "instrumentProviderIdentity": "+351999999999"
            },
            "type": "APP_NOTIFICATION"
        }
    ]
}
{
    "paymentMethod": "MBWAY",
    "consumer": {
        "name": "John Smith",
        "country": "PT"
    },
    "frequency": { "type": "MONTHLY"},
     "authenticationSettings": [
        {
            "settings": {
                "instrumentProviderIdentity": "+351999999999"
            },
            "type": "APP_NOTIFICATION"
        }
    ],
    "initialPaymentCharge": {
        "autoCapture": true,
        "amount": {
            "value": 2,
            "currency": "EUR"
        }
    }
}

Response

You'll receive our standard payment agreement response:

{
  "id": "agr_gFCDp991mUCjWVypLEvfZ",
  "status": "AUTHENTICATION_PENDING",
  "paymentMethod": "MBWAY",
  "frequency": {
        "type": "MONTHLY",
        "interval": 1
  },
  "startDate": "2026-03-10T13:31:39.222Z",
  "instrumentId": "instr_hLOqf7bZvyo98kqT4Spio",
  "consumer": {
    "name": "aug 5",
    "country": "PT"
  },
  "authenticationMethods": [
    {
      "details": {
        "requestUrl": "https://redirection-target.ppro.com",
        "requestMethod": "GET"
      },
      "type": "APP_NOTIFICATION"
    }
  ],
  "history": [
    {
      "id": "ahist_8WvsAUIuUR9lYCajdkPsv",
      "status": "AUTHENTICATION_PENDING",
      "createdAt": "2026-03-10T13:31:39.222Z"
    }
  ],
  "createdAt": "2026-03-10T13:31:39.222Z",
  "updatedAt": "2026-03-10T13:31:39.222Z"
}
{
  "id": "agr_gFCDp991mUCjWVypLEvfZ",
  "status": "AUTHENTICATION_PENDING",
  "paymentMethod": "MBWAY",
  "frequency": {
        "type": "MONTHLY",
        "interval": 1
  },
  "startDate": "2026-03-10T13:31:39.222Z",
  "instrumentId": "instr_hLOqf7bZvyo98kqT4Spio",
  "consumer": {
    "name": "aug 5",
    "country": "PT"
  },
  "authenticationMethods": [
    {
      "details": {
        "requestUrl": "https://redirection-target.ppro.com",
        "requestMethod": "GET"
      },
      "type": "APP_NOTIFICATION"
    }
  ],
  "history": [
    {
      "id": "ahist_8WvsAUIuUR9lYCajdkPsv",
      "status": "AUTHENTICATION_PENDING",
      "createdAt": "2026-03-10T13:31:39.222Z"
    }
  ],
  "initialPaymentChargeId": "charge_QQu5vY0HQYKIvsa7OO6Hx",
  "createdAt": "2026-03-10T13:31:39.222Z",
  "updatedAt": "2026-03-10T13:31:39.222Z"
}

Pick the desired authentication method

APP_NOTIFICATION

  1. Ask your consumer for the required identifier needed to initiate the push notification, often a consumer identifier like a phone, email address or tax identification.
  2. The consumer will receive a push notification to complete the payment process.

Handling the result

APP_NOTIFICATION

  1. The payment charge will remain in the AUTHENTICATION_PENDING state until the consumer confirms the payment.
  2. Webhooks are sent to inform you of the agreement and/or payment outcome.
  3. Alternatively, check the agreement and/or payment status and use the Status that you received to display the outcome to the consumer.
    GET /v1/payment-agreements/{agreement-id}
    GET [/v1/payment-charges/{paymentChargeId}]([https://developerhub.ppro.com/global-api/reference/getpaymentcharge](https://developerhub.ppro.com/global-api/reference/getpaymentcharge).
  4. Store the Payment Agreement ID for subsequent payments.

Create a recurring payment

To initiate a subsequent recurring payment, send a request against an active agreement using our payment agreements API.

Request

POST /v1/payment-agreements/{agreement-id}/payment-charges

{
  "amount": {
    "value": 1000,
    "currency": "EUR"
  }
}

Response

{
    "id": "charge_WLnk5R2RKwzAinkEoAMm0",
    "paymentMethod": "MBWAY",
    "currency": "EUR",
    "country": "PT",
    "instrumentId": "instr_86xMmxSjrVafelQgtAXxr",
    "status": "CAPTURED",
    "consumer": {
        "name": "John Smith",
        "country": "PT"
    },
    "authorizations": [
        {
            "id": "authz_nx4VgDiibOTPoYgXxQbrL",
            "amount": 1000,
            "status": "AUTHORIZED",
            "createdAt": "2026-02-10T16:28:40.150Z",
            "updatedAt": "2026-02-10T16:28:40.150Z"
        }
    ],
    "captures": [
        {
            "id": "capture_aJh1kGwLdwK8S3aFCeWFV",
            "amount": 1000,
            "status": "CAPTURED",
            "createdAt": "2026-02-10T16:28:40.150Z",
            "updatedAt": "2026-02-10T16:28:40.150Z"
        }
    ],
    "refunds": [],
    "voids": [],
    "createdAt": "2026-02-10T16:28:38.716Z",
    "updatedAt": "2026-02-10T16:28:40.150Z"
}

Sandbox testing

MB Recurring Way uses PPRO's mock authenticator in sandbox. Learn more.