Recurring payments

  Last updated: 

 

This page explains how to process recurring payments.

  The following content assumes you have obtained the necessary PCI certification to process and submit sensitive cardholder data in the request to our Webservices API.
Read this article to learn more.

  In order to process recurring payments, your merchant ID must be capable of processing recurring or continuous authority payments. If in doubt, we strongly recommend contacting your bank for clarification.

 

Process overview

 

  1. The customer enters their card details on your secure website or provides their card details over the phone.
  2. Where card details are entered into your secure website, you must ensure that 3DS authentication is performed.
  3. When the next payment is due, your system manually processes a child request using our Webservices API, which inherits the previously stored payment, billing and delivery details and seeks authorisation for a new payment.
  4. For high-volume merchants, we strongly recommend that three days before processing a subsequent child request (or where a child request has been declined), your system manually submits a scheme update request using our Webservices API, to check if the customer’s payment details are still up-to-date. Click here for further information.
  5. Your system can manually submit scheme update and child requests at set intervals (daily, weekly, monthly, yearly) to process new payments. The customer will only be debited after a new child request is submitted.

  Benefits of recurring payments

  • Payment details need only be provided by the customer once, at time of purchase.
  • Process repeat payments for customers without needing to store their card details on your own system for future use. Payment details are stored securely on our servers.
  • A recurring payment is only processed when a request has been submitted by your system. This allows for greater control over when payments are processed, as you are able to define your own interval between each payment.

 

Parent request

This section describes the initial request your system will need to process. You can inherit the payment details submitted in this request in subsequent recurring payments.

 

Configuration of parent request

Expand the relevant section below to learn how to configure the parent request using your preferred interface.

Parent request using Payment Pages

  Payment Pages is our fully-hosted checkout solution. If you are unfamiliar with our Payment Pages solution, click here to learn more and get started.

  To support the THREEDQUERY then ACCOUNTCHECK flow, Payment Pages customers will need to use the Enhanced Post feature. Click here to learn more.

The THREEDQUERY then AUTH flow is performed by processing a standard, 3-D Secure authenticated transaction using Payment Pages, with additional fields included in the POST, as described below.

<html>
<head>
</head>
<body>
<!--YOUR HTML-->
<form method="POST" action="<DOMAIN>/process/payments/choice">
<input type="hidden" name="credentialsonfile" value="1">
<input type="hidden" name="currencyiso3a" value="USD">
<input type="hidden" name="mainamount" value="100.00">
<input type="hidden" name="sitereference" value="test_site12345">
<input type="hidden" name="sitesecurity" value="hee879a9ab97753b3a768925d50842f10e19fea03fef0b820026b6df92d415866">
<input type="hidden" name="sitesecuritytimestamp" value="2019-05-28 14:22:37">
<input type="hidden" name="stprofile" value="default">
<input type="hidden" name="subscriptionnumber" value="1">
<input type="hidden" name="subscriptiontype" value="RECURRING">
<input type="hidden" name="version" value="2">
<input type="submit" value="Pay">
</form>
</body>
</html>

Replace <DOMAIN> with a supported domain. Click here for a full list.

 

Field specification

  Field Format Description
X1-EN.png mainamount Numeric (14)

The amount associated with this request in main units, with decimal places being separated by commas/decimal point. e.g. £10.99 would be submitted as “10.99” and ¥246 would be submitted as “246”.

This amount will be immediately reserved on the customer’s bank account.

This value will be inherited in all child requests that inherit from this parent request, unless the field is manually overridden.

X1-EN.png credentialsonfile Numeric (1) Visa and Mastercard have mandated that you must obtain cardholder consent before storing card details for future use. Following this, you must appropriately identify credentials that are to be stored for later, by assigning a Credentials on File (CoF) flag to signify this. For this reason, you must always submit credentialsonfile with value “1” in the parent request.

If you are processing a new recurring payments sequence using previously-stored credentials, you must still submit credentialsonfile = 1 in the parent request, to indicate the credentials will be stored to process future child payments in this sequence.

X1-EN.png currencyiso3a Alpha (3) The transaction currency. This must remain the same in all future child requests processed that inherit from this parent request.
X1-EN.png sitereference Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png sitesecurity

Site security hash

Used to submit the request site security hash in the POST.
X1-EN.png sitesecuritytimestamp

Date YYYY-MM-DD hh:mm:ss 

As accurately as possible, the timestamp that reflects when the customer’s payment session was initiated. The customer will have 3 hours from the specified time to complete the payment.

Additional considerations:

  • The timestamp value must be in UTC.
  • The timestamp value must NOT be in the future.
X1-EN.png stprofile

Alphanumeric (20)

  • Lowercase letters only.
  • Punctuation and spaces not permitted.
Used to specify the styling used to render the Payment Pages. When using the default appearance, this is set to “default”.
Click here for further information.
X1-EN.png subscriptionnumber Numeric (5) Submit “1” to denote the first request in the recurring sequence.

In each subsequent child request, the number submitted must be incremented by 1. For example the second request is “2”, the third is “3”, etc.

X1-EN.png subscriptiontype Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

Note: If the subscription type is “INSTALLMENT” and you are processing payments on the US platform, certain acquiring banks also require the field subscriptionfinalnumber is submitted. Contact our Support Team for further information.

X2-EN.png subscriptionfinalnumber Numeric (5)

This is used to set the number of payments to be processed over the course of the subscription.

Note: This field is required for certain acquiring banks on the US platform when the subscriptiontype is “INSTALLMENT” (otherwise the field is optional). Contact our Support Team for further information.

 

Response

You will need to ensure your system stores the transactionreference field returned in the browser redirect at the end of the checkout session (if configured), and/or the URL notification (if configured), as this must be referenced in the child request that is submitted later.

Parent request using JavaScript Library

  Our JavaScript Library provides resources to help you quickly build your own streamlined checkout solution on the web. If you are unfamiliar with our JavaScript Library solution, click here to learn more and get started.

  • Both the [“THREEDQUERY”,”AUTH”] and [“THREEDQUERY”,”ACCOUNTCHECK”] parent requests follow a similar specification to that of a standard payment processed using our JavaScript Library, but are subject to different requirements when employed as part of a recurring payments solution.
  • These changes are made within the payload of the JWT.
  • Refer to the example and field specification below for further information.
{
"payload":{
"accounttypedescription":"ECOM",
"baseamount":"1050",
"credentialsonfile":"1",
"currencyiso3a":"GBP",
"requesttypedescriptions":["THREEDQUERY","AUTH"]
"sitereference":"test_site12345",
"subscriptionnumber":"1",
"subscriptiontype":"RECURRING",
},
"iat":1559033849,
"iss":"jwt.user"
}

 

Field specification

  Field Format Description
X1-EN.png accounttypedescription Alpha (20)

Submit "ECOM" to indicate an e-commerce transaction.

We recommend contacting our Support Team for advice on which account type values are supported on your site reference.

X1-EN.png baseamount Numeric (13)

The amount associated with this request in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

  • For an initial [“THREEDQUERY”,”AUTH”] request: This amount will be immediately reserved on the customer’s bank account.
  • For an initial [“THREEDQUERY”,”ACCOUNTCHECK”] request: No funds are reserved on the customer’s bank account.

This value will be inherited in all child requests that inherit from this parent request, unless the field is manually overridden.

X1-EN.png credentialsonfile Numeric (1) Visa and Mastercard have mandated that you must obtain cardholder consent before storing card details for future use. Following this, you must appropriately identify credentials that are to be stored for later, by assigning a Credentials on File (CoF) flag to signify this. For this reason, you must always submit credentialsonfile with value “1” in the parent request.

If you are processing a new recurring payments sequence using previously-stored credentials, you must still submit credentialsonfile = 1 in the parent request, to indicate the credentials will be stored to process future child payments in this sequence.

The value submitted here is returned in the response JWT.

X1-EN.png currencyiso3a Alpha (3) The transaction currency. This must remain the same in all future child requests processed that inherit from this parent request.
X1-EN.png requesttypedescriptions List The request types to be processed.
For the parent, this should be either [“THREEDQUERY”,”AUTH”] or [“THREEDQUERY”,”ACCOUNTCHECK”]
X1-EN.png sitereference Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png subscriptionnumber Numeric (5) For the parent [“THREEDQUERY”,”AUTH”] or [“THREEDQUERY”,”ACCOUNTCHECK”] request: Submit “1”.

In each subsequent child request, the number submitted must be incremented by 1. For example the second request is “2”, the third is “3”, etc.

X1-EN.png subscriptiontype Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

Note: If the subscription type is “INSTALLMENT” and you are processing payments on the US platform, certain acquiring banks also require the field subscriptionfinalnumber is submitted. Contact our Support Team for further information.

X2-EN.png subscriptionfinalnumber Numeric (5)

This is used to set the number of payments to be processed over the course of the subscription.

Note: This field is required for certain acquiring banks on the US platform when the subscriptiontype is “INSTALLMENT” (otherwise the field is optional). Contact our Support Team for further information.

 

Response

The response JWT returned follows the same specification as when processing a standard payment. Of particular importance, your system will need to store the transactionreference returned, as this must be referenced in the child request that is submitted later. Click here to learn about decoding the JWT response.

Parent request using Mobile SDK

  Our Mobile SDK provides resources to help you quickly build a streamlined checkout solution into your mobile app. If you are unfamiliar with our Mobile SDK solution, click here to learn more and get started.

  • Both the [“THREEDQUERY”,”AUTH”] and [“THREEDQUERY”,”ACCOUNTCHECK”] parent requests follow a similar specification to that of a standard payment processed using our Mobile SDK, but are subject to different requirements when employed as part of a recurring payments solution.
  • These changes are made within the payload of the JWT.
  • Refer to the example and field specification below for further information.
{
"payload":{
"accounttypedescription":"ECOM",
"baseamount":"1050",
"credentialsonfile":"1",
"currencyiso3a":"GBP",
"requesttypedescriptions":["THREEDQUERY","AUTH"]
"sitereference":"test_site12345",
"subscriptionnumber":"1",
"subscriptiontype":"RECURRING",
"termurl":"https://payments.securetrading.net/process/payments/mobilesdklistener",
},
"iat":1559033849,
"iss":"jwt.user"
}

 

Field specification

  Field Format Description
X1-EN.png accounttypedescription Alpha (20)

Submit "ECOM" to indicate an e-commerce transaction.

We recommend contacting our Support Team for advice on which account type values are supported on your site reference.

X1-EN.png baseamount Numeric (13)

The amount associated with this request in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

  • For an initial [“THREEDQUERY”,”AUTH”] request: This amount will be immediately reserved on the customer’s bank account.
  • For an initial [“THREEDQUERY”,”ACCOUNTCHECK”] request: No funds are reserved on the customer’s bank account.

This value will be inherited in all child requests that inherit from this parent request, unless the field is manually overridden.

X1-EN.png credentialsonfile Numeric (1) Visa and Mastercard have mandated that you must obtain cardholder consent before storing card details for future use. Following this, you must appropriately identify credentials that are to be stored for later, by assigning a Credentials on File (CoF) flag to signify this. For this reason, you must always submit redentialsonfile with value “1” in the parent request.

If you are processing a new recurring payments sequence using previously-stored credentials, you must still submit credentialsonfile = 1 in the parent request, to indicate the credentials will be stored to process future child payments in this sequence.

The value submitted here is returned in the response JWT.

X1-EN.png currencyiso3a Alpha (3) The transaction currency. This must remain the same in all future child requests processed that inherit from this parent request.
X1-EN.png requesttypedescriptions List The request types to be processed.
For the parent, this should be either [“THREEDQUERY”,”AUTH”] or [“THREEDQUERY”,”ACCOUNTCHECK”]
X1-EN.png sitereference Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png subscriptionnumber Numeric (5) For the parent [“THREEDQUERY”,”AUTH”] or [“THREEDQUERY”,”ACCOUNTCHECK”] request: Submit “1”.

In each subsequent child request, the number submitted must be incremented by 1. For example the second request is “2”, the third is “3”, etc.

X1-EN.png subscriptiontype Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

Note: If the subscription type is “INSTALLMENT” and you are processing payments on the US platform, certain acquiring banks also require the field subscriptionfinalnumber is submitted. Contact our Support Team for further information.

X1-EN.png termurl URL (1024)

This URL is used to instruct the card issuer where to send the customer’s browser after they have been authenticated on the card issuer’s ACS. You must submit the following URL in this field when performing 3-D Secure:

https://payments.securetrading.net/process/payments/mobilesdklistener

X2-EN.png subscriptionfinalnumber Numeric (5)

This is used to set the number of payments to be processed over the course of the subscription.

Note: This field is required for certain acquiring banks on the US platform when the subscriptiontype is “INSTALLMENT” (otherwise the field is optional). Contact our Support Team for further information.

 

Response

The response JWT returned follows the same specification as when processing a standard payment. Of particular importance, your system will need to store the transactionreference returned, as this must be referenced in the child request that is submitted later. Click here to learn about decoding the JWT response.

Parent request using Webservices API (ECOM)

  Our Webservices API is a powerful server-to-server payment processing solution that supports multiple message types. If you are unfamiliar with our Webservices API, click here to learn more and get started.

  • The example below is an AUTH request that can be used to process the first payment in the recurring sequence.
  • The accounttypedescription is "ECOM" to indicate the transaction was performed using your website.
  • If you need to start a recurring payment agreement without processing a payment, you can change the requesttypedescriptions value to "ACCOUNTCHECK".
Python PHP cURL Raw JSON Raw XML

#!/usr/bin/python
import securetrading

stconfig = securetrading.Config()
stconfig.username = "webservices@example.com"
stconfig.password = "Password1^"
st = securetrading.Api(stconfig)

auth = {
"sitereference": "test_site12345",
"requesttypedescriptions": ["AUTH"],
"accounttypedescription": "ECOM",
"currencyiso3a": "GBP",
"baseamount": "1050",
"orderreference": "My_Order_123",
"pan": "4111111111111111",
"expirydate": "12/2020",
"securitycode": "123",
"cavv":"Q0FWVkNBVlZDQVZWQ0FWVkNBVlY=",
"eci":"05",
"enrolled":"Y",
"status":"Y",
"threedversion":"2.1.0", "threeddirectorytransactionreference":"f00e1111-0011-00a6-ab00-a00000a00000",
"subscriptiontype": "RECURRING",
"subscriptionnumber": "1",
"credentialsonfile": "1"
}

strequest = securetrading.Request()
strequest.update(auth)
stresponse = st.process(strequest) #stresponse contains the transaction response
  Field Format Description
X1-EN.png accounttypedescription
XPath: /operation/accounttypedescription
Alpha (20)

Submit "ECOM" to indicate an e-commerce transaction.

X1-EN.png baseamount
XPath: /billing/amount
Numeric (13)

The amount associated with this request in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

This value will be inherited in all child requests that inherit from this parent request, unless the field is manually overridden.

  Where performing an ACCOUNTCHECK, you must include the maximum amount to be processed in any subsequent child transaction.

X1-EN.png credentialsonfile
XPath: /operation/credentialsonfile
Numeric (1) Visa and Mastercard have mandated that you must obtain cardholder consent before storing card details for future use. Following this, you must appropriately identify credentials that are to be stored for later, by assigning a Credentials on File (CoF) flag to signify this. For this reason, you must always submit credentialsonfile with value “1” in the parent request.

If you are processing a new recurring payments sequence using previously-stored credentials, you must still submit credentialsonfile = 1 in the parent request, to indicate the credentials will be stored to process future child payments in this sequence.

The value submitted here is returned in the response JWT.

X1-EN.png currencyiso3a
XPath: /billing/amount/@currencycode
Alpha (3) The transaction currency. This must remain the same in all future child requests processed that inherit from this parent request.
X1-EN.png enrolled
XPath: /threedsecure/enrolled
Char (1) Submit ‘Y’ to indicate that card is enrolled. See below for information on handling not-enrolled cards.
X1-EN.png expirydate
XPath: /billing/payment/expirydate
Date MM/YYYY The expiry date printed on the card.
X1-EN.png pan
XPath: /billing/payment/pan
Numeric (12-19) This is the long number printed on the front of the customer’s card.
X1-EN.png requesttypedescriptions
XPath: /@type
List The request types to be processed.
For the parent, this should be either ["AUTH"] or ["ACCOUNTCHECK"]
X1-EN.png sitereference
XPath: /operation/sitereference
Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png status
XPath: /threedsecure/status
Char (1) Indicates whether or not the customer was authenticated on the card issuer’s ACS.

Successful authentication with status "Y" is required.

X1-EN.png subscriptionnumber
XPath: /billing/subscription/number
Numeric (5) For the parent request: Submit “1”.

In each subsequent child request, the number submitted must be incremented by 1. For example the second request is “2”, the third is “3”, etc.

X1-EN.png subscriptiontype
XPath: /billing/subscription/@type
Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

Note: If the subscription type is “INSTALLMENT” and you are processing payments on the US platform, certain acquiring banks also require the field subscriptionfinalnumber is submitted. Contact our Support Team for further information.

X2-EN.png billingfirstname
XPath: /billing/name/first
Alphanumeric including
symbols (127)

The customer’s billing first name.

Required for gaming merchants.

X2-EN.png billinglastname
XPath: /billing/name/last
Alphanumeric including
symbols (127)

The customer’s billing last name.

Required for gaming merchants.

X2-EN.png cavv
XPath: /threedsecure/cavv
Alphanumeric (56)

The unique Cardholder Authentication Verification Value (CAVV) associated with the transaction.

Always submit this value when it is available.

X2-EN.png eci
XPath: /threedsecure/eci
Alphanumeric (2)

The ECI (E-Commerce Indicator) security level associated with the transaction.

Always submit this value when it is available.

X2-EN.png threedversion
XPath: /threedsecure/version
Numeric (6)

Version of 3-D Secure used to authenticate the payment. (e.g. “2.1.0”)

Always submit this value when it is available.

X2-EN.png threeddirectorytransactionreference
XPath: /threedsecure/directorytransactionreference
Alphanumeric (48)

Unique DSTransactionId returned by your MPI provider.

Always submit this value when it is available.

X2-EN.png subscriptionfinalnumber
XPath: /billing/subscription/finalnumber
Numeric (5)

This is used to set the number of payments to be processed over the course of the subscription.

Note: This field is required for certain acquiring banks on the US platform when the subscriptiontype is “INSTALLMENT” (otherwise the field is optional). Contact our Support Team for further information.

X3-EN.png securitycode
XPath: /billing/payment/securitycode
Numeric (3-4)

This is the 3-digit security code printed on the back of the card.

(For AMEX cards, this is a 4-digit code found on the front of the card)

This field is not strictly required by Trust Payments, but it is highly recommended for the processing of security code checks.

Additionally, some banks may decline the payment if the security code is not present.

 

Response

The response returned follows the same specification as a standard AUTH response.

 

Parent request using Webservices API (MOTO)

  Our Webservices API is a powerful server-to-server payment processing solution that supports multiple message types. If you are unfamiliar with our Webservices API, click here to learn more and get started.

  • The example below is an AUTH request that can be used to process the first payment in the recurring sequence.
  • The accounttypedescription is "MOTO" to indicate the order was placed over the phone.
  • If you need to start a recurring payment agreement without processing a payment, you can change the requesttypedescriptions value to "ACCOUNTCHECK".
Python PHP cURL Raw JSON Raw XML

#!/usr/bin/python
import securetrading

stconfig = securetrading.Config()
stconfig.username = "webservices@example.com"
stconfig.password = "Password1^"
st = securetrading.Api(stconfig)

auth = {
"sitereference": "test_site12345",
"requesttypedescriptions": ["AUTH"],
"accounttypedescription": "MOTO",
"currencyiso3a": "GBP",
"baseamount": "1050",
"orderreference": "My_Order_123",
"billingfirstname": "Joe",
"billinglastname": "Bloggs",
"pan": "4111111111111111",
"expirydate": "12/2020",
"securitycode": "123",
"subscriptiontype": "RECURRING",
"subscriptionnumber": "1",
"credentialsonfile": "1"
}

strequest = securetrading.Request()
strequest.update(auth)
stresponse = st.process(strequest) #stresponse contains the transaction response
  Field Format Description
X1-EN.png accounttypedescription
XPath: /operation/accounttypedescription
Alpha (20)

Submit "MOTO" to indicate a Mail Order Telephone Order transaction.

(Note that 3-D Secure authentication is not supported for MOTO transactions)

X1-EN.png baseamount
XPath: /billing/amount
Numeric (13)

The amount associated with this request in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

This value will be inherited in all child requests that inherit from this parent request, unless the field is manually overridden.

  Where performing an ACCOUNTCHECK, you must include the maximum amount to be processed in any subsequent child transaction.

X1-EN.png credentialsonfile
XPath: /operation/credentialsonfile
Numeric (1) Visa and Mastercard have mandated that you must obtain cardholder consent before storing card details for future use. Following this, you must appropriately identify credentials that are to be stored for later, by assigning a Credentials on File (CoF) flag to signify this. For this reason, you must always submit credentialsonfile with value “1” in the parent request.

If you are processing a new recurring payments sequence using previously-stored credentials, you must still submit credentialsonfile = 1 in the parent request, to indicate the credentials will be stored to process future child payments in this sequence.

The value submitted here is returned in the response JWT.

X1-EN.png currencyiso3a
XPath: /billing/amount/@currencycode
Alpha (3) The transaction currency. This must remain the same in all future child requests processed that inherit from this parent request.
X1-EN.png expirydate
XPath: /billing/payment/expirydate
Date MM/YYYY The expiry date printed on the card.
X1-EN.png pan
XPath: /billing/payment/pan
Numeric (12-19) This is the long number printed on the front of the customer’s card.
X1-EN.png requesttypedescriptions
XPath: /@type
List The request types to be processed.
For the parent, this should be either ["AUTH"] or ["ACCOUNTCHECK"]
X1-EN.png sitereference
XPath: /operation/sitereference
Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png subscriptionnumber
XPath: /billing/subscription/number
Numeric (5) For the parent request: Submit “1”.

In each subsequent child request, the number submitted must be incremented by 1. For example the second request is “2”, the third is “3”, etc.

X1-EN.png subscriptiontype
XPath: /billing/subscription/@type
Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

Note: If the subscription type is “INSTALLMENT” and you are processing payments on the US platform, certain acquiring banks also require the field subscriptionfinalnumber is submitted. Contact our Support Team for further information.

X2-EN.png billingfirstname
XPath: /billing/name/first
Alphanumeric including
symbols (127)

The customer’s billing first name.

Required for gaming merchants.

X2-EN.png billinglastname
XPath: /billing/name/last
Alphanumeric including
symbols (127)

The customer’s billing last name.

Required for gaming merchants.

X2-EN.png subscriptionfinalnumber
XPath: /billing/subscription/finalnumber
Numeric (5)

This is used to set the number of payments to be processed over the course of the subscription.

Note: This field is required for certain acquiring banks on the US platform when the subscriptiontype is “INSTALLMENT” (otherwise the field is optional). Contact our Support Team for further information.

X3-EN.png securitycode
XPath: /billing/payment/securitycode
Numeric (3-4)

This is the 3-digit security code printed on the back of the card.

(For AMEX cards, this is a 4-digit code found on the front of the card)

This field is not strictly required by Trust Payments, but it is highly recommended for the processing of security code checks.

Additionally, some banks may decline the payment if the security code is not present.

 

Response

The response returned follows the same specification as a standard AUTH response.

 

  Your progress

After following the instructions above, you should now be ready to manually process repeat payments using our Webservices API. You can take the transactionreference returned in the response and include this in subsequent child requests.

 


 

Child request

  This section describes the subsequent recurring payment. This section assumes the parent request described earlier has already been processed.

  Before processing a child request, you must ensure that the parent request has completed successfully. Investigate any issues raised and if assistance is required, contact our Support Team.


  Mastercard has mandated that in cases where a recurring payment has been declined by the card issuer, your system must not retry the request more than once per day for the next 31 days. After this period has passed, your system must not send further requests for the affected customer.

  When a parenttransactionreference from a successful parent "AUTH" or "ACCOUNTCHECK" is included in a child request, Trust Payments will provide the required scheme reference data to Visa and Mastercard.

Please contact our Support Team if you need to include scheme reference data from another processor or process child transactions including a PAN and Expiry. Click here to learn more.

 

Child request overview

  1. Your system requests that a new payment is processed, by manually submitting an AUTH request using our Webservices API, which includes the transactionreference of the parent AUTH or ACCOUNTCHECK in the parenttransactionreference field.

  For those using our JavaScript Library or Mobile SDK to process the parent request, the subsequent response JWT returned will also contain the transactionreference of the THREEDQUERY. You must not submit this in the child request. Instead, you must only submit the transactionreference value associated with the parent AUTH or ACCOUNTCHECK.

  1. We contact the acquiring bank to seek authorisation for the payment, using the billing and delivery details inherited from the parent AUTH/ACCOUNTCHECK. (Your system does not need to re-submit these details)
  2. Your system receives an AUTH response, including the results of the request.

 

Request

The request type submitted for the child request must be “AUTH” (submitted in the requesttypedescriptions field). The AUTH child request follows a similar specification to a standard AUTH request, but is subject to different requirements when employed as part of a recurring payments solution. Refer to the example and field specification below for further information.

Python PHP cURL Raw JSON Raw XML
#!/usr/bin/python
import securetrading

stconfig = securetrading.Config()
stconfig.username = "webservices@example.com"
stconfig.password = "Password1^"
st = securetrading.Api(stconfig)

auth = {
"sitereference": "test_site12345",
"requesttypedescriptions": ["AUTH"],
"accounttypedescription": "RECUR",
"parenttransactionreference": "12-3-4567",
"baseamount": "1050",
"subscriptiontype": "RECURRING",
"subscriptionnumber": "2",
"credentialsonfile": "2"
}

strequest = securetrading.Request()
strequest.update(auth)
stresponse = st.process(strequest) #stresponse contains the transaction response

Replace <DOMAIN> with a supported domain. Click here for a full list.

 

  The example above assumes that the previous request was the first to be processed, therefore the subscriptionnumber is assigned value “2”. Subsequent child requests are processed with the same structure, incrementing this number each time (i.e. next payment in sequence would be “3”, then “4” and so on).

  Field Format Description
X1-EN.png accounttypedescription
XPath: /operation/accounttypedescription
Alpha (20) This must be set to “RECUR”.
X3-EN.png baseamount
XPath: /billing/amount
Numeric (13)

The amount associated with the child payment in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

If you don’t submit this field, the amount processed will be inherited from the preceding parent request.

X1-EN.png credentialsonfile
XPath: /operation/credentialsonfile
Numeric (1)

This is required for Visa and Mastercard transactions where the merchant is utilising Credentials on File (CoF).

Submit “2” in this field to indicate the payment is using previously-stored credentials.

X3-EN.png currencyiso3a
XPath: /billing/amount/@currencycode
Alpha (3) If submitted, this must be the same currency used in the parent request.

If not submitted, this value is inherited from the parent request.

X1-EN.png parenttransactionreference
XPath: /operation/parenttransactionreference
Alphanumeric
& hyphens (25)
You must submit the transactionreference value of the AUTH or ACCOUNTCHECK returned in the response JWT of the initial parent request.

You must not submit the transactionreference value associated with the THREEDQUERY.

X1-EN.png requesttypedescriptions
XPath: /@type
Alpha (20) You must submit “AUTH”, as shown in the request example.
X1-EN.png sitereference
XPath: /operation/sitereference
Alphanumeric
& underscore (50)
The site reference relates to your individual account which you received on setup. If you do not know your site reference, please contact our Support Team.
X1-EN.png subscriptionnumber
XPath: /billing/subscription/number
Numeric (5)

This is used to identify a payment’s position within a sequence of recurring transactions.

For each subsequent payment, the number submitted should be incremented by 1 (without gaps).

e.g. 2nd transaction is “2”, 3rd is “3”, then “4” etc.

(You should only increment this number if the previous recurring payment request was successful)

We do not impose limits on the number of payments made against a card.

X1-EN.png subscriptiontype
XPath: /billing/subscription/@type
Alpha (11)

This is the type of subscription:

“RECURRING” is for when the customer is making a recurring payment for a new product/service each time.

“INSTALLMENT” is for when a customer is purchasing a single order over several installments. Installments are supported for merchants with a Trust Payments acquiring account. If you are using a different acquiring bank, you will need to contact our Support Team to check this feature is supported before proceeding.

 

Response

The response returned follows the same specification as a standard AUTH response, with the exception of the additional field acquireradvicecode that can be returned (see the field specification below for further information).

 

Field specification

  Field Format Description
X4-EN.png accounttypedescription
XPath: /operation/accounttypedescription
Alpha (20) Account type “RECUR” will be returned.
X2-EN.png acquireradvicecode
XPath: /acquireradvicecode
Numeric (1)

A numeric value returned from the acquiring bank, which is used to indicate whether further payments can be processed. A full mapping of these values can be found in the “Additional notes” section at the bottom of this page.

Only returned if supported by your acquiring bank.

X4-EN.png baseamount
XPath: /billing/amount
Numeric (13)

The amount associated with the child payment in base units, with no commas or decimal points. e.g. £10.99 would be submitted as “1099” but ¥246 would be submitted as “246”.

We recommend checking this amount matches the value you are expecting. The amount returned here reflects the amount the customer will be debited on the child payment.

X4-EN.png credentialsonfile
XPath: /operation/credentialsonfile
Numeric (1) If the credentialsonfile field has been submitted in the request and it is supported by the acquirer processing the transaction, it is returned in the response.
X4-EN.png currencyiso3a
XPath: /billing/amount/@currencycode
Alpha (3)

The currency of the transaction.

Click here for a full list of available currencies.

X4-EN.png parenttransactionreference
XPath: /operation/parenttransactionreference
Alphanumeric
& hyphens (25)
The transaction reference of the parent transaction.
X4-EN.png requesttypedescription
XPath: /@type
Alpha (20) Request type “AUTH” will be returned.

  Summary

Following the instructions above, your system should now be able to manually process repeat payments using our Webservices API, without needing to re-submit any of the customer’s billing or payment credentials. As always, we strongly recommend thoroughly testing your solution to ensure recurring payments are being processed as expected, before performing live payments on your production system. Please read on for additional information you may find useful when developing a recurring payments solution.

 

Additional notes

 

Below are some additional notes to consider when processing recurring payments.

 

About the acquirer advice code

The acquirer advice code is a numeric value returned if supported by your acquiring bank, indicating if and when further payments can be processed.

  Click here to learn more

Scheme Update

For high-volume merchants, we strongly recommend that three days before processing a subsequent child request (or where a child request has been declined), your system manually submits a scheme update request using our Webservices API, to check if the customer’s payment details are still up-to-date.

  Click here to learn more.

Related articles


Subscription Engine

Submit a single request and we will process recurring payments automatically at regular intervals.

  Learn more

Merchant Initiated Transactions (MIT)

Submit a single request to process a transaction from previously stored card details.

  Learn more

Was this article helpful?
0 out of 0 found this helpful