POST /v1/payment-schedules/batch

Creates multiple payment schedules at once. You can create both recurring payment schedules and custom payment schedules in one request. The maximum number of payment schedules that can be created by a single request is 50. The maximum number of payment schedule items that each payment schedule can contain is 1000, i.e., you must specify less than 1000 items for a custom payment schedule, and the occurrences field must be less than 1000 for a recurring payment schedule.

Note:

Servers

Request headers

Name Type Required Description
Content-Type String Yes The media type of the request body.

Default value: "application/json"

Content-Encoding String No

Include the Content-Encoding: gzip header to compress a request. With this header specified, you should upload a gzipped file for the request payload instead of sending the JSON payload.

Zuora-Track-Id String No

A custom identifier for tracing the API call. If you set a value for this header, Zuora returns the same value in the response headers. This header enables you to associate your system process identifiers with Zuora API calls, to assist with troubleshooting in the event of an issue.

The value of this field must use the US-ASCII character set and must not include any of the following characters: colon (:), semicolon (;), double quote ("), and quote (').

zuora-version String No

The minor version of the Zuora REST API. See Minor Version for information about REST API version control.

This header affects the availability of the following request fields:

  • paymentSchedules > billingDocument
  • paymentSchedules > items > billingDocument
Authorization String No

The value is in the Bearer {token} format where {token} is a valid OAuth token generated by calling Create an OAuth token.

Idempotency-Key String No

Specify a unique idempotency key if you want to perform an idempotent POST or PATCH request. Do not use this header in other request types.

With this header specified, the Zuora server can identify subsequent retries of the same request using this value, which prevents the same operation from being performed multiple times by accident.

Zuora-Entity-Ids String No

An entity ID. If you have Zuora Multi-entity enabled and the OAuth token is valid for more than one entity, you must use this header to specify which entity to perform the operation in. If the OAuth token is only valid for a single entity, or you do not have Zuora Multi-entity enabled, you do not need to set this header.

Zuora-Org-Ids String No

Comma separated IDs. If you have Zuora Multi-Org enabled, you can use this header to specify which orgs to perform the operation in. If you do not have Zuora Multi-Org enabled, you should not set this header.

The IDs must be a sub-set of the user's accessible orgs. If you specify an org that the user does not have access to, the operation fails.

If the header is not set, the operation is performed in scope of the user's accessible orgs.

Accept-Encoding String No

Include the Accept-Encoding: gzip header to compress responses as a gzipped file. It can significantly reduce the bandwidth required for a response.

If specified, Zuora automatically compresses responses that contain over 1000 bytes of data, and the response contains a Content-Encoding header with the compression algorithm so that your client can decompress it.

Request body fields

Name Type Required Description
paymentSchedules[] Array No

Container of the payment schedules to be created.

paymentSchedules[].billingDocument Object No

Object of the billing document with which the payment schedule is associated.

Note:

  • This field is optional. If you have the Standalone Payment feature enabled, you can leave this field blank and set standalone to true to create standalone payments. You can also choose to create unapplied payments by leaving this object blank and setting standalone to false.
  • If Standalone Payment is not enabled, leaving this object unspecified will create unapplied payments.
paymentSchedules[].billingDocument.id String No

ID of the billing document.

Note: If a billing document is specified, either id or number of the billing document must be specified. You cannot specify both of them or skip both.

paymentSchedules[].billingDocument.number String No

ID of the billing document.

Note: If a billing document is specified, either id or number of the billing document must be specified. You cannot specify both of them or skip both.

paymentSchedules[].billingDocument.type String Yes

The type of the billing document. The default value is Invoice.

Possible values:

  • "Invoice"
  • "DebitMemo"
paymentSchedules[].paymentMethodId String No

ID of the payment method.

Note:

  • This field is optional. The default value is the account's default payment method ID.
  • This field will be ignored when items is specified.
paymentSchedules[].accountId String No

ID of the customer account the payment schedule belongs to.

Note: accountId and accountNumber cannot both be null. When both fields are specified, the two values must match each other.

paymentSchedules[].description String No

Description of the payment schedule. Max length is 255.

paymentSchedules[].paymentGatewayId String No

ID of the payment gateway.

Note:

  • This field is optional. The default value is the account's default payment gateway ID. If no payment gateway ID is found on the cusotmer account level, the default value will be the tenant's default payment gateway ID.
  • This field will be ignored when items is specified.
paymentSchedules[].items[] Array No

Container array for payment schedule items.

paymentSchedules[].items[].billingDocument Object No

Object for the billing document with which the payment schedule item is associated. Note: You must specify the same billing document for all the payment schedule items in one payment schedule.

paymentSchedules[].items[].billingDocument.id String No

The ID of the billing document.

Note: If a billing document is specified, one of id or number must be specified. You cannot specify both of them or or skip both.

paymentSchedules[].items[].billingDocument.number String No

The number of the billing document.

Note: If a billing document is specified, one of id or number must be specified. You cannot specify both of them or skip both.

paymentSchedules[].items[].billingDocument.type String Yes

The type of the billing document. The default value is Invoice.

Possible values:

  • "Invoice"
  • "DebitMemo"
paymentSchedules[].items[].scheduledDate String No

The date to collect the payment.

paymentSchedules[].items[].paymentMethodId String No

The ID of the payment method.

Note:

  • This field is optional. If not specified, the default value is the payment method id set for the account.
paymentSchedules[].items[].paymentOption[] Array No

Container for the paymentOption items, which describe the transactional level rules for processing payments. Currently, only the Gateway Options type is supported.

Here is an example:

"paymentOption": [
  {
    "type": "GatewayOptions",
    "detail": {
      "SecCode":"WEB"
    }
  }
]

paymentOption of the payment schedule takes precedence over paymentOption of the payment schedule item.

To enable this field, submit a request at Zuora Global Support. This field is only available if zuora-version is set to 337.0 or later available versions.

paymentSchedules[].items[].paymentOption[].type String No

The type of the payment option. Currently, only GatewayOptions is supported for specifying Gateway Options fields supported by a payment gateway.

paymentSchedules[].items[].paymentOption[].detail Object No

The field used to pass the transactional payment data to the gateway side in the key-value format.

paymentSchedules[].items[].paymentOption[].detail.key String No

The name of the field.

paymentSchedules[].items[].paymentOption[].detail.value String No

The value of the field.

paymentSchedules[].items[].description String No

Description of the payment schedule item.

paymentSchedules[].items[].paymentGatewayId String No

The ID of the payment gateway.

Note:

  • This field is optional. If not specified, the default value is the payment gateway id set for the account.
paymentSchedules[].items[].amount Number No

The amount that needs to be collected by this payment schedule item.

paymentSchedules[].items[].runHour String No

At which hour in the day in the tenant’s timezone this payment will be collected. Available values:[0,1,2,~,22,23]. If the time difference between your tenant’s timezone and the timezone where Zuora servers are is not in full hours, for example, 2.5 hours, the payment schedule items will be triggered half hour later than your scheduled time. The default value is 0. If the payment runHour and scheduledDate are backdated, the system will collect the payment when the next runHour occurs.

paymentSchedules[].items[].currency String No

The currency of the payment.

Note:

  • This field is optional. If not specified, the default value is the currency set for the account.
paymentSchedules[].startDate String No

The date for the first payment collection.

Note:

  • This field is required when items is not specified.
  • This field will be ignored when items is specified.
paymentSchedules[].currency String No

Currency of the payment schedule.

Note:

  • This field is optional. The default value is the account's default currency.
  • This field will be ignored when items is specified.
paymentSchedules[].accountNumber String No

Account number of the customer account the payment schedule belongs to.

Note: accountId and accountNumber cannot both be null. When both fields are specified, the two values must match each other.

paymentSchedules[].paymentOption[] Array No

Container for the paymentOption items, which describe the transactional level rules for processing payments. Currently, only the Gateway Options type is supported.

Here is an example:

"paymentOption": [
  {
    "type": "GatewayOptions",
    "detail": {
      "SecCode":"WEB"
    }
  }
]

paymentOption of the payment schedule takes precedence over paymentOption of the payment schedule item.

paymentSchedules[].paymentOption[].type String No

The type of the payment option. Currently, only GatewayOptions is supported for specifying Gateway Options fields supported by a payment gateway.

paymentSchedules[].paymentOption[].detail Object No

The field used to pass the transactional payment data to the gateway side in the key-value format.

paymentSchedules[].paymentOption[].detail.key String No

The name of the field.

paymentSchedules[].paymentOption[].detail.value String No

The value of the field.

paymentSchedules[].occurrences Integer No

The number of payment schedule item to be created. Maximum value is 1000.

Note:

  • This field is required when items is not specified.
  • This field will be ignored when items is specified.
paymentSchedules[].period String No

The frequency for the payment collection since the startDate.

Note:

  • Thie field is required when items is not specified.
  • This field will be ignored when items is specified.
  • If startDate is 30 or 31 and period is Monthly, when in February, payment schedule will use the last day of February for payment collection.

Possible values:

  • "BiWeekly"
  • "Monthly"
  • "Weekly"
paymentSchedules[].prepayment Boolean No

Indicates whether the payments created by the payment schedule will be used as reserved payments. This field will only be available if the prepaid cash drawdown permission is enabled. See Prepaid Cash with Drawdown for more information.

paymentSchedules[].amount Number No

The amount of each payment schedule item in the payment schedule.

Note:

  • This field is required when items is not specified.
  • This field will be ignored when items is specified.
  • When creating recurring payment schedules, there are 2 options to specify amounts:
    • Specify totalAmount and occurrences, amount will be calculated.
    • Specify amount and occurrences, totalAmount will be calculated. You must specify either totalAmount or amount. Specifying both fields at the same time is not allowed.
paymentSchedules[].standalone Boolean No

Indicate whether the payments created by the payment schedule are standalone payments or not. When setting to true, standalone payments will be created. When setting to false, you can either specify a billing document, or not specifying any billing documents. In the later case, unapplied payments will be created. If set to null, standalone payment will be created.

Note:

  • This field is only available if the Standalone Payment is enabled. Do not include this field if Standalone Payment is not enabled.
  • If Standalone Payment is enabled, default value is true.
paymentSchedules[].paymentScheduleNumber String No

You can use this field to specify the number of the payment schedule. Only characters from the following sets are allowed: A-Z, a-z, 0-9, and -. Payment numbers must start with a letter. In addition,- can only be used at most once and cannot be placed at the beginning or the end of the payment numbers.

paymentSchedules[].runHour Integer No

Specifies at which hour in the day in the tenant’s time zone when this payment will be collected. Available values: [0,1,2,~,22,23].

Note:

  • If the time difference between your tenant’s timezone and the timezone where Zuora servers are is not in full hours, for example, 2.5 hours, the payment schedule items will be triggered half hour later than your scheduled time.
  • If the payment runHour and scheduledDate are backdated, the system will collect the payment when the next runHour occurs.
  • This field is optional. The default value is 0.
  • This field will be ignored when items is specified.
paymentSchedules[].totalAmount Number No

The total amount of that the payment schedule will collect. This field is only available for recurring payment schedules.

Note:

  • When creating recurring payment schedules, there are 2 options to specify amounts:

    • Specify totalAmount and occurrences, amount will be calculated.
    • Specify amount and occurrences, totalAmount will be calculated.

    You must specify either totalAmount or amount. Specifying both fields at the same time is not allowed.

  • If the Standalone Payments feature is enabled and standalone is set to true for the payment schedule, totalAmount will be ignored.

How to start integrating

  1. Add HTTP Task to your workflow definition.
  2. Search for the API you want to integrate with and click on the name.
    • This loads the API reference documentation and prepares the Http request settings.
  3. Click Test request to test run your request to the API and see the API's response.