Subscriptions can run indefinitely or they may run for a fixed number of billing cycles. Subscription can have "contract terms", which define a lock-in period on the subscription for a certain number of billing cycles. This prevents the subscription from being canceled by the customer when it is within the contract term.
Thecontract term resource described below defines the properties of this lock-in period. This includes thenumber of billing cycles, thetotal contract value, theaction to be taken at the end of the contract term, and so on. To allow for exceptions, you also have the option of terminating anactive contract term and charging atermination fee.
A contract term starts in theactive state and ends in thecompleted state. If the contract was canceled due to non-payment or other reasons, it can end in thecanceled orterminated state. A given contract term is always associated with one, and only one subscription. A subscription, however, can be associated with only oneactive contract term. Over time, a subscription can be associated with several non-active contract terms. Theactive contract term for a subscription is available as anobject within the subscription.
To enable and configure contract terms, follow these steps in the Chargebee UI:
- ClickSettings on the left navigation.
- ClickConfigure Chargebee.
- UnderBilling, clickContract Terms.
- Enable and configure the feature as needed.
Once contract terms have been configured, the following actions can be performed using the API:
Define a contract term for a subscription andset renewal options for the contract term. The following endpoints support this:
- Create a subscription
- Update a subscription
- Reactivate a subscription
- Create a subscription ramp
- Update a subscription ramp
Retrieving a historical record of all contract terms for a subscription can be done via the following endpoint:
- List contract terms for a subscription
Canceling a contract term can be done via the following endpoints:
- Update a subscription
- Cancel a subscription
- Update a subscription ramp
Including a termination fee
When a contract is canceled mid-term, you can set a termination fee to be levied. Here's how:
- Create an item price for an item oftype
chargewithprice set to the termination fee. - Do one of the following:
- Attach the charge-item to a plan, setting the
charge_on_eventparameter tocontract_termination. OR - Include the charge-item price on a subscription, setting the
subscription_items[charge_on_event][i]parameter tocontract_termination.
Once the above steps are done, the termination fee will be charged automatically if youterminate the contract in the middle of its term.
Sample Contract termJSON
API Index URL
Contract terms attributes
Current status of contract
An actively running contract term.
The contract term has run its full duration.
The contract term was ended because: - a change in the subscription caused asubscription term reset.
- the subscription was cancelled due to non-payment.
The contract term was terminated ahead of completion.
The number of billing cycles of the subscription that the contract term is for.
Action to be taken when the contract term completes.
- Contract term completes and a new contract term is started for the number of billing cycles specified in
contract_billing_cycle_on_renewal. - The
action_at_term_endfor the new contract term is set torenew.
Contract term completes and the subscription renews.
Contract term completes and subscription is canceled.
Used when you want to renew the contract term just once. Does the following: - Contract term completes and a new contract term is started for the number of billing cycles specified incontract_billing_cycle_on_renewal.
- The
action_at_term_endfor the new contract term is set tocancel.
The sum of thetotalsof all the invoices raised as part of the contract term. Foractivecontract terms, this is a predicted value. The value depends on thetype of currency.If the subscription wasimportedwith the contract term, then this value includes the value passed fortotal_amount_raised.
It refers to the total amount of revenue that is expected to be generated from a specific contract term, calculated as the sum of all invoices raised during the term, regardless of payment status. It is based on past performance and the specified currency in the contract. If the subscription was imported, the value fortotal_amount_raised_before_taxis included in the calculation of the total contract value before tax. It's important to note that this value excludes any applicable taxes.
The number of days beforecontract_end, during which the customer is barred from canceling the contract term. The customer is allowed to cancel the contract term via the Self-Serve Portal only before this period. This allows you to have sufficient time for processing the contract term closure.
TheIdof the subscription that this contract term is for.