Get Subscription
GET/subscriptions/:subscriptionId
Returns the details of a specific subscription based on the provided subscription ID.
The request must provide the following header: x-api-key: {merchantKey}
Request
Path Parameters
Unique Identifier of the created Subscription. Format: Subscription + - + <UUID>
Header Parameters
Must be application/json
Must be be en-US
The origin of the request
The client making the request
x-api-key: {merchantKey}
Responses
- 200
- 400
- 401
- 403
- 404
- 500
Successful response
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Possible values: <= 100 characters
Subscription ID automatically generated by the system.
Possible values: <= 30 characters
Timestamp of when the Subscription was created.
Possible values: <= 30 characters
Timestamp of when the Subscription was last updated.
Possible values: <= 30 characters
Timestamp of when the Subscription was deleted (if applicable).
Possible values: <= 100 characters
Plan ID of the existing plan under which the Subscription was created.
Possible values: <= 20 characters
, [created
, pending
, trial
, active
, overdue
, canceled
, expired
, paused
]
Status of the subscription.
payment
object
required
Payment details for the subscription.
Possible values: <= 255 characters
Description of the payment plan.
Possible values: <= 60 characters
Amount to be charged per billing cycle.
Possible values: <= 3 characters
Currency of the payment.
Possible values: <= 30 characters
Start date of the subscription.
Possible values: <= 10 characters
Start date of the trial period.
Possible values: <= 10 characters
End date of the trial period.
Possible values: <= 10 characters
Next scheduled billing date.
Possible values: <= 2 characters
Number of the remaining billing cycles to be charged. Populated initially from the input billingCycles of the parent subscription Plan. Every time a billing occurs (successful transaction) then the billingCyclesRemaining is reduced by 1.
Possible values: <= 125 characters
Customer account associated with the subscription.
Possible values: <= 255 characters
Metadata provided by the merchant.
Possible values: <= 255 characters
External merchant identifier.
billingAgreement
object
required
Billing Agreement linked to the Subscription. Hosting the payment instrument information returned as null for newly created subscription.
Possible values: <= 50 characters
Unique Identifier of the Billing Agreement. Format: BillingAgreement + - + <UUID>
PaymentObject used for billing this subscription.
Possible values: <= 24 characters
Date when the billing agreement was created.
Possible values: <= 255 characters
Display name of the payment option which has been stored.
Possible values: <= 255 characters
Code of the payment option which has been stored.
Masked carrier number of the payment instrument which has been stored.
Possible values: [true
, false
]
Indicates if a card used as a payment option is expired or not.
Possible values: <= 7 characters
, Value must match regular expression ^(0[1-9]|1[0-2])/[0-9]{4}$
If a card is used as a payment option, this shows its expiry date.
Additional data related to the stored payment option.
billingAddress
object
required
Billing or shipping address of the consumer. Please refer to Data Model for details.
Possible values: <= 60 characters
Address line 1.
Possible values: <= 60 characters
Address line 2.
Possible values: <= 60 characters
Address line 3.
Possible values: <= 10 characters
House number/building number.
Possible values: <= 50 characters
City name of the address.
Possible values: <= 10 characters
Postal code of the address.
Possible values: >= 2 characters
and <= 3 characters
Country code. Could be 2 or 3 characters depending on the format used. Format ISO 3166 ALPHA-2 or ISO 3166 ALPHA-3.
Possible values: <= 3 characters
State. Could be 2 or 3 characters depending on the state. This field is mandatory when the countryCode is US, USA, CA or CAN.
shippingAddress
object
required
Billing or shipping address of the consumer. Please refer to Data Model for details.
Possible values: <= 60 characters
Address line 1.
Possible values: <= 60 characters
Address line 2.
Possible values: <= 60 characters
Address line 3.
Possible values: <= 10 characters
House number/building number.
Possible values: <= 50 characters
City name of the address.
Possible values: <= 10 characters
Postal code of the address.
Possible values: >= 2 characters
and <= 3 characters
Country code. Could be 2 or 3 characters depending on the format used. Format ISO 3166 ALPHA-2 or ISO 3166 ALPHA-3.
Possible values: <= 3 characters
State. Could be 2 or 3 characters depending on the state. This field is mandatory when the countryCode is US, USA, CA or CAN.
consumer
object
required
Consumer's personal data, in case the consumer is a physical person. See consumer
in Data model.
Conditional. Can be present if businessConsumer
is missing from the request.
Possible values: <= 60 characters
First name of the consumer.
Possible values: <= 60 characters
Last name of the consumer.
Possible values: <= 60 characters
Middle name of the consumer.
Possible values: <= 255 characters
Email address of the customer.
Possible values: <= 3 characters
, [Mr
, Mrs
, Ms
]
Title of the consumer.
Possible values: <= 5 characters
Consists of ISO 639-1 language code and ISO 3166-1 alpha-2 country code separated by dash. If this value is not provided the browser culture is used. Default culture is English (e.g.,, en-de). This field is not case sensitive.
Date of birth. Dummy data acceptable. Format “YYYY-MM-DD”.
Possible values: [M
, F
, D
]
Gender of the consumer.
Possible values: <= 30 characters
Mobile phone of the customer.
Possible values: <= 30 characters
Home phone of the customer.
Possible values: <= 30 characters
Work phone of the customer.
Possible values: <= 30 characters
Tax ID of the consumer.
businessConsumer
object
nullable
required
Company data, in case the consumer is a business or a legal entity. See businessConsumer
in Data model.
Conditional. Can be present if consumer
is missing from the request.
Possible values: <= 100 characters
Company legal entity name.
Possible values: <= 100 characters
Company legal entity type (e.g., GmbH).
Possible values: <= 255 characters
Customer's email address.
Possible values: <= 30 characters
Tax identification number.
Possible values: <= 5 characters
Consists of ISO 639-1 language code and ISO 3166-1 alpha-2 country code separated by dash. If this value is not provided the browser culture is used. Default culture is English (e.g.,, en-de). This field is not case sensitive.
Possible values: <= 50 characters
Company registration number
Possible values: >= 2 characters
and <= 3 characters
ISO 3166-1 alpha-2 or ISO 3166-1 alpha-3 code of the address country.
Number of days the subscription is paused.
Possible values: <= 30 characters
Date of the last billing notification.
Possible values: <= 2 characters
Number of scheduled billing cycles remaining.
Scheduled amount for upcoming billing.
Indicates if there are pending payments.
Indicates if any action is required from the merchant or customer.
Additional information related to the subscription.
Custom references associated with the subscription.
criteria
object[]
nullable
An array of key-value pair objects. Please refer to Data Model for details.
Possible values: <= 100 characters
Target merchant account reference if applicable.
{
"id": "Subscription-39ab7cc3-57d7-42d7-ad24-a7b8a4164880",
"createdAt": "2024-10-31T14:30:10.51Z",
"updatedAt": "2024-10-31T14:30:10.51Z",
"deletedAt": "2024-07-29T15:51:28.071Z",
"planId": "SubscriptionPlan-700be03c-b1b0-4bea-8971-7f18bdc10d10",
"status": "created",
"payment": {
"description": "string",
"recurrentAmount": 0,
"currencyIsoCode": "string"
},
"startDate": "2024-10-31T08:48:19.96Z",
"timezone": "Europe/Berlin",
"trialStartDate": "2024-07-29",
"trialEndDate": "2024-07-29",
"nextBillingDate": "2024-07-29",
"billingCyclesRemaining": 0,
"customerAccountId": "string",
"merchantMetadata": "string",
"externalMerchantId": "string",
"billingAgreement": {
"id": "BillingAgreement-99aad3ef-78d8-492a-829d-9e5db02018fd",
"paymentObjectId": "8ac7a49f8609e07601860ca28ce656ed",
"billingAgreementDate": "2023-02-02T15:05:37.28Z",
"name": "Mastercard",
"code": "MSTRCRD",
"carrierNumber": "520000****0015",
"expiryDate": "12/2025",
"storedPaymentOptionData": null
},
"billingAddress": {
"addressLine1": "Leopoldstrasse",
"addressLine2": "Building 442A22",
"addressLine3": "7th floor",
"number": "244",
"city": "Munich",
"postCode": "80807",
"countryCode": "DE",
"state": null
},
"shippingAddress": {
"addressLine1": "Leopoldstrasse",
"addressLine2": "Building 442A22",
"addressLine3": "7th floor",
"number": "244",
"city": "Munich",
"postCode": "80807",
"countryCode": "DE",
"state": null
},
"consumer": {
"firstName": "John",
"lastName": "Smith",
"middleName": ".",
"emailAddress": "john.smith@smithentreprise.com",
"title": "Mr",
"culture": "en-de",
"dateOfBirth": "1995-01-26",
"gender": "M",
"mobilePhone": "1285765191221",
"homePhone": "1285765191221",
"workPhone": "1285765191221",
"taxId": "DE1927456229"
},
"businessConsumer": {
"companyName": "Smith Enterprises Ltd.",
"companyType": "GmbH",
"emailAddress": "contact@smithenterprises.com",
"taxId": "DE123456789",
"culture": "en-DE",
"companyRegistrationNumber": "HRB 123456",
"companyRegistrationCountryCode": "DE"
},
"pausePeriodDays": 0,
"billingNotificationDate": "2024-07-29T15:51:28.071Z",
"scheduledBillingCyclesRemaining": 0,
"scheduledAmount": 0,
"pendingPayments": true,
"actionRequired": true,
"extraInfo": {},
"customReferences": {},
"criteria": [
{
"name": "string",
"value": "string"
}
],
"targetMerchantAccountReference": "string"
}
{
"id": "Subscription-39ab7cc3-57d7-42d7-ad24-a7b8a4164880",
"createdAt": "2024-10-31T14:30:10.51Z",
"updatedAt": "2024-10-31T14:30:10.51Z",
"deletedAt": null,
"planId": "SubscriptionPlan-700be03c-b1b0-4bea-8971-7f18bdc10d10",
"status": "created",
"payment": {
"description": "Premium sub for only 100 EUR!",
"recurrentAmount": 100,
"currencyIsoCode": "EUR"
},
"startDate": "2024-10-31T08:48:19.96Z",
"timezone": null,
"trialStartDate": "2024-10-31",
"trialEndDate": "2024-11-30",
"nextBillingDate": "2024-11-30",
"billingCyclesRemaining": 4,
"customerAccountId": "BSTEST01",
"merchantMetadata": "{\"usage\": 250, \"client\": 1248052792, \"monitor\": true }",
"externalMerchantId": "client_21507252",
"billingAgreement": null,
"billingAddress": {
"addressLine1": "Wall st. , NY",
"addressLine2": "Building 442A22",
"addressLine3": "7th floor",
"number": "224",
"city": "NEW YORK",
"postCode": "NEW YORK",
"countryCode": "US",
"state": "AR"
},
"shippingAddress": {
"addressLine1": "Wall st. , NY",
"addressLine2": "Building 442A22",
"addressLine3": "7th floor",
"number": "224",
"city": "NEW YORK",
"postCode": "NEW YORK",
"countryCode": "US",
"state": "AR"
},
"consumer": {
"firstName": "John",
"lastName": "Smith",
"middleName": "Name",
"emailAddress": "john.smith@smithenterprise.com",
"title": "MR",
"culture": "en-de",
"dateOfBirth": "1995-01-26",
"gender": "M",
"mobilePhone": "1285765191221",
"homePhone": "1285765191221",
"workPhone": "1285765191221",
"taxId": "DE1927456229"
},
"businessConsumer": null,
"pausePeriodDays": 0,
"billingNotificationDate": null,
"scheduledBillingCyclesRemaining": null,
"scheduledAmount": 0,
"pendingPayments": false,
"actionRequired": false,
"extraInfo": {
"productGroup": "productGroup",
"customerGroup": "customerGroup"
},
"customReferences": {
"custom1": "payment",
"custom2": "document_123",
"custom3": "ref_number_3765"
},
"criteria": [
{
"name": "zbplRO6U5A6siu2suP7DY",
"value": "hTtMVsv7oslFtbXmZd8CQ9tmIo1MsSa"
}
],
"targetMerchantAccountReference": null
}
Bad Request
For error handling, please refer to this section.
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Internally generated trace_id
for this error message so it can be found easily in the logs.
errors
object[]
A predefined string which describes the error. The purpose of the message is to allow for future usage of translation.
A pre-defined code from the list of error codes.
The property from the request object which the error is linked to.
context
object
A json object containing a list of predefined properties which are filled based on the error.
{
"traceId": "string",
"errors": [
{
"message": "string",
"code": "string",
"property": "string",
"context": {
"type": "string",
"minimum": 0,
"maximum": 0,
"maxLength": 0,
"allowedValues": [
"string"
]
}
}
]
}
{
"traceId": "00-1234567890abcdef0123456789abcdef-0123456789abcdef-00",
"errors": [
{
"message": "Value out of bounds. Value must be between 1 and 100",
"code": "value_out_of_bounds",
"property": "someField",
"context": {
"minimum": 1,
"maximum": 100
}
}
]
}
Unauthenticated
For error handling, please refer to this section.
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Internally generated trace_id
for this error message so it can be found easily in the logs.
errors
object[]
A predefined string which describes the error. The purpose of the message is to allow for future usage of translation.
A pre-defined code from the list of error codes.
The property from the request object which the error is linked to.
context
object
A json object containing a list of predefined properties which are filled based on the error.
{
"traceId": "string",
"errors": [
{
"message": "string",
"code": "string",
"property": "string",
"context": {
"type": "string",
"minimum": 0,
"maximum": 0,
"maxLength": 0,
"allowedValues": [
"string"
]
}
}
]
}
{
"traceId": "00-1234567890abcdef0123456789abcdef-0123456789abcdef-00",
"errors": [
{
"message": "You are not authenticated to perform this request.",
"code": "unauthorized"
}
]
}
Forbidden
For error handling, please refer to this section.
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Internally generated trace_id
for this error message so it can be found easily in the logs.
errors
object[]
A predefined string which describes the error. The purpose of the message is to allow for future usage of translation.
A pre-defined code from the list of error codes.
The property from the request object which the error is linked to.
context
object
A json object containing a list of predefined properties which are filled based on the error.
{
"traceId": "string",
"errors": [
{
"message": "string",
"code": "string",
"property": "string",
"context": {
"type": "string",
"minimum": 0,
"maximum": 0,
"maxLength": 0,
"allowedValues": [
"string"
]
}
}
]
}
{
"traceId": "00-1234567890abcdef0123456789abcdef-0123456789abcdef-00",
"errors": [
{
"message": "You do not have permissions to perform this request.",
"code": "forbidden"
}
]
}
Not Found
For error handling, please refer to this section.
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Internally generated trace_id
for this error message so it can be found easily in the logs.
errors
object[]
A predefined string which describes the error. The purpose of the message is to allow for future usage of translation.
A pre-defined code from the list of error codes.
The property from the request object which the error is linked to.
context
object
A json object containing a list of predefined properties which are filled based on the error.
{
"traceId": "string",
"errors": [
{
"message": "string",
"code": "string",
"property": "string",
"context": {
"type": "string",
"minimum": 0,
"maximum": 0,
"maxLength": 0,
"allowedValues": [
"string"
]
}
}
]
}
{
"traceId": "00-1234567890abcdef0123456789abcdef-0123456789abcdef-00",
"errors": [
{
"message": "Resource not found.",
"code": "not_found"
}
]
}
Internal Server Error
For error handling, please refer to this section.
- application/json
- Schema
- Example (from schema)
- Example
Schema
Array [
]
Internally generated trace_id
for this error message so it can be found easily in the logs.
errors
object[]
A predefined string which describes the error. The purpose of the message is to allow for future usage of translation.
A pre-defined code from the list of error codes.
The property from the request object which the error is linked to.
context
object
A json object containing a list of predefined properties which are filled based on the error.
{
"traceId": "string",
"errors": [
{
"message": "string",
"code": "string",
"property": "string",
"context": {
"type": "string",
"minimum": 0,
"maximum": 0,
"maxLength": 0,
"allowedValues": [
"string"
]
}
}
]
}
{
"traceId": "00-1234567890abcdef0123456789abcdef-0123456789abcdef-00",
"errors": [
{
"message": "Internal server error."
}
]
}