Hosted pages are the easiest way to integrate Chargebee with your website. For card payment methods, they help meet most of your PCI DSS compliance requirements. Chargebee offers hosted pages where your customers can perform the following actions:
redirect_url
with the hosted page id
and state
passed as query string parameters. As soon as the redirection happens, retrieve the hosted page to get details of the customer, subscription, invoice etc.
{
"created_at": 1517464663,
"embed": false,
"expires_at": 1517468263,
"id": "__one_time_checkout___test__cdqM9MLUubELMycut0Cr9sHq8gOTKEZSdcu",
"object": "hosted_page",
"resource_version": 1517444863979,
"state": "created",
"type": "checkout_one_time",
"updated_at": 1517444863,
"url": "https://yourapp.chargebee.com/pages/v3/__one_time_checkout___test__cdqM9MLUubELMycut0Cr9sHq8gOTKEZSdcu/"
}
This attribute allows you to store custom information with the hosted_page
object. You can use it to associate specific data with a hosted page session.
For example, you can store the ID of the marketing campaign that initiated the user session. After a successful checkout, when the customer is redirected, you can retrieve the hosted page ID from the redirect URL's query parameters. Using this ID, you can fetch the hosted page and perform actions related to the success of the marketing campaign.
Create a Chargebee hosted page to accept payment details from a customer and checkout charge-items and one-time charges.
The following steps describe how best to use this API:
pass_thru_content
containing information and IDs from your systems that must be associated with the checkout page. url
received in the response.customer
record in Chargebee, and they are redirected to the redirect_url
with the id
and state
attributes passed as query string parameters. When customer[id]
is provided for this operation, it is looked up by Chargebee, and if found, the hosted_page is created for it. If not found, a new customer resource is created with an autogenarated ID, and the hosted_page is created.
If multiple business entities are created for the site, the customer resource lookup and creation happen within the context of the business entity specified in this API call. If no business entity is specified, the customer resource lookup is performed within the site context , and if not found, the resource is created for the default business entity of the site.
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_one_time_for_items \ -u {site_api_key}:\ -d "customer[id]"="__test__XpbXKKYSOUtL5p2E" \ -d "shipping_address[first_name]"="John" \ -d "shipping_address[last_name]"="Mathew" \ -d "shipping_address[city]"="Walnut" \ -d "shipping_address[state]"="California" \ -d "shipping_address[zip]"="91789" \ -d "shipping_address[country]"="US" \ -d "item_prices[item_price_id][0]"="ssl-charge-USD" \ -d "item_prices[unit_price][0]"=2000
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_one_time_for_items \ -u {site_api_key}:\ -d "customer[id]"="__test__XpbXKKYSOUtL5p2E" \ -d "shipping_address[first_name]"="John" \ -d "shipping_address[last_name]"="Mathew" \ -d "shipping_address[city]"="Walnut" \ -d "shipping_address[state]"="California" \ -d "shipping_address[zip]"="91789" \ -d "shipping_address[country]"="US" \ -d "item_prices[item_price_id][0]"="ssl-charge-USD" \ -d "item_prices[unit_price][0]"=2000
Sets the context for this operation to the business entity specified. Applicable only when multiple business entities have been created for the site. When this parameter is provided, the operation is able to read/write data associated only to the business entity specified. When not provided, the operation can read/write data for the entire site.
An alternative way of passing this parameter is by means of a custom HTTP header.
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. This attribute allows you to store custom information with the hosted_page
object. You can use it to associate specific data with a hosted page session.
For example, you can store the ID of the marketing campaign that initiated the user session. After a successful checkout, when the customer is redirected, you can retrieve the hosted page ID from the redirect URL's query parameters. Using this ID, you can fetch the hosted page and perform actions related to the success of the marketing campaign.
The unique ID of the customer for which this hosted_page
should be created. If not provided, the ID of the newly created customer resource is autogenerated.
entity_code
or exempt_number
attributes if you use Chargebee’s AvaTax for Sales or specify exemption_details
attribute if you use Chargebee’s AvaTax for Communications integration. Tax may still be applied by Avalara for certain values of entity_code
/exempt_number
/exemption_details
based on the state/region/province of the taxable address.billing_address
country
as
XI
(which is United Kingdom - Northern Ireland), the first two characters of the full VAT
number can be overridden by setting
vat_number_prefix
. billing_address
country
as XI
(which is United Kingdom - Northern Ireland).billing_address
country
as XI
. That’s the code for United Kingdom - Northern
Ireland. The first two characters of the VAT number in such a case is
XI
by default. However, if the VAT number was registered in UK, the value should be GB
. Set
vat_number_prefix
to GB
for such cases. true
or not set to any value, the customer is e-invoiced so long as e-invoicing is enabled for their country (billing_address.country
). When set to false
, the customer is not e-invoiced even if e-invoicing is enabled for their country.
Tip:
It is possible to set a value for this flag even when E-Invoicing is disabled. However, it comes into effect only when E-Invoicing is enabled.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
entity_identifier_scheme
. Currently only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
Indicates whether invoices raised on the same day for the customer
are consolidated. When provided, this overrides the default configuration at the site-level. This parameter can be provided only when Consolidated Invoicing is enabled.
Note:
Any invoices raised when a subscription activates from in_trial
or future
status
, are not consolidated by default. Contact Support to enable consolidation for such invoices.
state_code
as AZ
(not US-AZ
). For Tamil Nadu (India), set as TN
(not IN-TN
). For British Columbia (Canada), set as BC
(not CA-BC
). state_code
is provided. Brexit
If you have enabled EU VAT in 2021 or later, or have manually enable the Brexit configuration, then XI
(the code for United Kingdom – Northern Ireland) is available as an option.
state_code
as AZ
(not US-AZ
). For Tamil Nadu (India), set as TN
(not IN-TN
). For British Columbia (Canada), set as BC
(not CA-BC
). state_code
is provided. Brexit
If you have enabled EU VAT in 2021 or later, or have manually enable the Brexit configuration, then XI
(the code for United Kingdom – Northern Ireland) is available as an option.
item_price
. This is only applicable when the pricing_model
of the item_price
is flat_fee
or per_unit
. The value depends on the type of currency. pricing_model
is tiered
or volume
. The total cost for the item price when the pricing_model
is stairstep
. The value is in the minor unit of the currency. ending_unit_in_decimal
of the next lower tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. starting_unit_in_decimal
of the next higher tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. pricing_model
is tiered
or volume
. When the pricing_model
is stairstep
, it is the decimal representation of the total price for the item. The value is in major units of the currency. Returned when the plan is quantity-based and multi-decimal pricing is enabled. pricing_type
will be set to flat_fee
by default. For example, if the flat fee for a tier is $100, the customer pays $100 whether they consume 1 unit or the maximum number of units within that tier.packageIndicates that the tier pricing is based on a package of units. Customers are charged for each block or package of units. For example, if the package size is 100 units and the cost per block is $20 consuming 400 units will result in a charge of $80 (4 × $20).charges[discount_percentage]
should be passed. sub_total
.specific_item_priceThe discount is applied to the invoice.line_item.amount
that corresponds to the item price specified by item_price_id
.apply_on
= specific_item_price
. entity_identifier[i]
in Chargebee. This is required when entity_identifier[operation][i]
is update
or delete
.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
. This identifies the customer entity on the Peppol network. For example: 10101010-STO-10
.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
.
entity_identifier
for the customer.updateUpdates an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.deleteDeletes an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.entity_identifier
scheme
. Currently, only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
Create a Chargebee hosted page to accept payment details from a customer and checkout a new subscription.
The following steps describe how best to use this API:
Call this endpoint, providing item prices, coupons and a host of other details such as billing and shipping addresses to be prefilled for the customer on the checkout page. You may also provide pass_thru_content
containing information and IDs from your systems that must be associated with the checkout page.
The first item price in the list (parameter subscription_items[item_price_id][0]
) must be an item_price
of item_type plan
.
url
received in the response. redirect_url
with the id
and state
attributes passed as query string parameters.redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. When the customer[id]
parameter is provided and if a customer resource with the ID is found to be already created in Chargebee, the subscription is created under that customer resource. If not found, then a new customer resource is created with an autogenarated ID and the subscription is created under it.
If multiple business entities are created for the site, the customer resource lookup and creation happen within the context of the business entity specified in this API call. If no business entity is specified, the customer resource lookup is performed within the site context, and if not found, the resource is created for the default business entity of the site.
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_new_for_items \ -u {site_api_key}:\ -d "subscription_items[item_price_id][0]"="basic-USD" \ -d "subscription_items[quantity][0]"=1 \ -d "subscription_items[item_price_id][1]"="day-pass-USD" \ -d "subscription_items[unit_price][1]"=100
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_new_for_items \ -u {site_api_key}:\ -d "subscription_items[item_price_id][0]"="basic-USD" \ -d "subscription_items[quantity][0]"=1 \ -d "subscription_items[item_price_id][1]"="day-pass-USD" \ -d "subscription_items[unit_price][1]"=100
Sets the context for this operation to the business entity specified. Applicable only when multiple business entities have been created for the site. When this parameter is provided, the operation is able to read/write data associated only to the business entity specified. When not provided, the operation can read/write data for the entire site.
An alternative way of passing this parameter is by means of a custom HTTP header.
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. This attribute allows you to store custom information with the hosted_page
object. You can use it to associate specific data with a hosted page session.
For example, you can store the ID of the marketing campaign that initiated the user session. After a successful checkout, when the customer is redirected, you can retrieve the hosted page ID from the redirect URL's query parameters. Using this ID, you can fetch the hosted page and perform actions related to the success of the marketing campaign.
start_date
. Set it to 0
to have no trial period. This parameter overrides the item_price_trial_period
directly. start_date
cannot be earlier than 14th February.The id of the coupon. For validating the coupon code provided by the user , use the following codes in combination with the param attribute in the error response.
billing_cycles
or a custom value depending on the site configuration. The unique identifier for the customer resource for which the subscription should be created.
When not provided, a new customer is created with the ID set to the value provided for subscription[id]
. If subscription[id]
is unavailable, then the customer ID is autogenerated.
entity_code
or exempt_number
attributes if you use Chargebee’s AvaTax for Sales or specify exemption_details
attribute if you use Chargebee’s AvaTax for Communications integration. Tax may still be applied by Avalara for certain values of entity_code
/exempt_number
/exemption_details
based on the state/region/province of the taxable address.billing_address
country
as
XI
(which is United Kingdom - Northern Ireland), the first two characters of the full VAT
number can be overridden by setting
vat_number_prefix
. billing_address
country
as XI
(which is United Kingdom - Northern Ireland).billing_address
country
as XI
. That’s the code for United Kingdom - Northern
Ireland. The first two characters of the VAT number in such a case is
XI
by default. However, if the VAT number was registered in UK, the value should be GB
. Set
vat_number_prefix
to GB
for such cases. true
or not set to any value, the customer is e-invoiced so long as e-invoicing is enabled for their country (billing_address.country
). When set to false
, the customer is not e-invoiced even if e-invoicing is enabled for their country.
Tip:
It is possible to set a value for this flag even when E-Invoicing is disabled. However, it comes into effect only when E-Invoicing is enabled.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
entity_identifier_scheme
. Currently only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
state_code
as AZ
(not US-AZ
). For Tamil Nadu (India), set as TN
(not IN-TN
). For British Columbia (Canada), set as BC
(not CA-BC
). state_code
is provided. Brexit
If you have enabled EU VAT in 2021 or later, or have manually enable the Brexit configuration, then XI
(the code for United Kingdom – Northern Ireland) is available as an option.
state_code
as AZ
(not US-AZ
). For Tamil Nadu (India), set as TN
(not IN-TN
). For British Columbia (Canada), set as BC
(not CA-BC
). state_code
is provided. Brexit
If you have enabled EU VAT in 2021 or later, or have manually enable the Brexit configuration, then XI
(the code for United Kingdom – Northern Ireland) is available as an option.
contract_billing_cycle_on_renewal
.action_at_term_end
for the new contract term is set to renew
.contract_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 subscription_items[item_price_id][0]
) must be an item_price
of item_type plan
. pricing_model
of the item price is flat_fee
or per_unit
. Also, it is only allowed when price overriding is enabled for the site. The value depends on the type of currency. If changes_scheduled_at
is in the past and a unit_price
is not passed, then the item price’s current unit price is considered even if the item price did not exist on the date as of when the change is scheduled. charge_on_option
option is set to on_event
, this parameter specifies the event at which the charge-item is applied to the subscription. This parameter only applies to charge-items. active
or non-renewing
state. Also includes reactivations of canceled subscriptions.contract_terminationwhen a contract term is terminated.charge_on_event
occurs. This parameter only applies to charge-items. charge_on_event
.sub_total
.specific_item_priceThe discount is applied to the invoice.line_item.amount
that corresponds to the item price specified by item_price_id
.period
and period_unit
.period_units
. Applicable only when duration_type
is limited_period
. period
. Applicable only when duration_type
is limited_period
. duration_type
is one_time
and when the feature is enabled in Chargebee. Also, If the site-level setting is to exclude one-time discounts from MRR calculations, this value is always returned false
. apply_on
= specific_item_price
. ending_unit_in_decimal
of the next lower tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. starting_unit_in_decimal
of the next higher tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. pricing_model
is tiered
or volume
. When the pricing_model
is stairstep
, it is the decimal representation of the total price for the item. The value is in major units of the currency. Returned when the plan is quantity-based and multi-decimal pricing is enabled. pricing_type
will be set to flat_fee
by default. For example, if the flat fee for a tier is $100, the customer pays $100 whether they consume 1 unit or the maximum number of units within that tier.packageIndicates that the tier pricing is based on a package of units. Customers are charged for each block or package of units. For example, if the package size is 100 units and the cost per block is $20 consuming 400 units will result in a charge of $80 (4 × $20).entity_identifier[i]
in Chargebee. This is required when entity_identifier[operation][i]
is update
or delete
.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
. This identifies the customer entity on the Peppol network. For example: 10101010-STO-10
.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
.
entity_identifier
for the customer.updateUpdates an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.deleteDeletes an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.entity_identifier
scheme
. Currently, only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
Create a Chargebee hosted page to accept payment details from a customer and checkout to update the subscription.
The following steps describe how best to use this API:
Provide item prices, coupons and a host of other details such as billing and shipping addresses to be prefilled for the customer on the checkout page. You may also provide pass_thru_content
containing information and IDs from your systems that must be associated with the checkout page.
The first item price in the list (parameter subscription_items[item_price_id][0]
) must be an item_price
of item_type plan
.
url
received in the response. They can now add a payment method or use an existing one, to complete the checkout. redirect_url
with the id
and state
attributes passed as query string parameters.redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_existing_for_items \ -u {site_api_key}:\ -d "subscription[id]"="__test__KyVnGWS4EgP3HA" \ -d "subscription_items[item_price_id][0]"="basic-USD" \ -d "subscription_items[quantity][0]"=4 \ -d "subscription_items[unit_price][0]"=1000
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_existing_for_items \ -u {site_api_key}:\ -d "subscription[id]"="__test__KyVnGWS4EgP3HA" \ -d "subscription_items[item_price_id][0]"="basic-USD" \ -d "subscription_items[quantity][0]"=4 \ -d "subscription_items[unit_price][0]"=1000
create_pending_invoices
is set to true
, and if the site is configured to set invoice dates to date of closing, then upon invoice closure, this date is changed to the invoice closing date. taxes and line_item_taxes are computed based on the tax configuration as of invoice_date
. When passing this parameter, the following prerequisites must be met:
invoice_date
must be in the past.invoice_date
is not more than one calendar month into the past. For example, if today is 13th January, then you cannot pass a value that is earlier than 13th December.changes_scheduled_at
, reactivate_from
, or trial_end
.invoice_immediately
is true
.terms_to_charge
is inclusive of this new term. See description for the force_term_reset
parameter to learn more about when a subscription term is reset. status
is cancelled
and it is being reactivated via this operation, this is the date/time at which the subscription should be reactivated.changed_scheduled_at
. reactivate_from
can be backdated (set to a value in the past). Use backdating when the subscription has been reactivated already but its billing has been delayed. Backdating is allowed only when the following prerequisites are met:
changes_scheduled_at
cannot be earlier than 14th February.cancelled
subscriptions. When set to true
, it activates the canceled subscription; otherwise, subscription changes are applied without altering its status
. Additionally, if not explicitly set and the subscription_items
provided in the API differ from the existing items, the subscription will still be reactivated. Note: This parameter is relevant only for subscriptions with status
of active
, non_renewing
, or cancelled
.
When you set this parameter to true
, the subscription term resets to the date of the subscription change.
By default, if you change the plan-item price to another with the same billing period, the subscription term remains unchanged. For example, if the subscription renews on the 28th of every month, it will continue to renew on the 28th after the change.
Note: If the new plan-item price has a different billing period from the current plan-item price, the subscription term resets automatically, regardless of the value of force_term_reset
.
changes_scheduled_at
.change_option
is set to specific_date
, specify the date and time for the subscription change to occur or to reflect a past change. reactivate_from
. changes_scheduled_at
value cannot be set to a past date.redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. This attribute allows you to store custom information with the hosted_page
object. You can use it to associate specific data with a hosted page session.
For example, you can store the ID of the marketing campaign that initiated the user session. After a successful checkout, when the customer is redirected, you can retrieve the hosted page ID from the redirect URL's query parameters. Using this ID, you can fetch the hosted page and perform actions related to the success of the marketing campaign.
future
subscription. Applicable only for future
subscriptions. status
is future
, in_trial
, or cancelled
. Also, the value must not be earlier than changes_scheduled_at
or start_date
. Note: This parameter can be backdated (set to a value in the past) only when the subscription is in cancelled
or in_trial
status
. Do this to keep a record of when the trial ended in case it ended at some point in the past. When trial_end
is backdated, the subscription immediately goes into active
or non_renewing
status. This parameter overrides the item_price_trial_period
directly. billing_cycles
or a custom value depending on the site configuration. billing_address
country
as
XI
(which is United Kingdom - Northern Ireland), the first two characters of the full VAT
number can be overridden by setting
vat_number_prefix
. billing_address
country
as XI
(which is United Kingdom - Northern Ireland).billing_address
country
as XI
. That’s the code for United Kingdom - Northern
Ireland. The first two characters of the VAT number in such a case is
XI
by default. However, if the VAT number was registered in UK, the value should be GB
. Set
vat_number_prefix
to GB
for such cases. true
or not set to any value, the customer is e-invoiced so long as e-invoicing is enabled for their country (billing_address.country
). When set to false
, the customer is not e-invoiced even if e-invoicing is enabled for their country.
Tip:
It is possible to set a value for this flag even when E-Invoicing is disabled. However, it comes into effect only when E-Invoicing is enabled.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
entity_identifier_scheme
. Currently only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there are additional entity identifiers for the customer not associated with the vat_number
, they can be provided as the entity_identifiers[]
array.
contract_billing_cycle_on_renewal
.action_at_term_end
for the new contract term is set to renew
.contract_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 subscription_items[item_price_id][0]
) must be an item_price
of item_type plan
. pricing_model
of the item price is flat_fee
or per_unit
. Also, it is only allowed when price overriding is enabled for the site. The value depends on the type of currency. If changes_scheduled_at
is in the past and a unit_price
is not passed, then the item price’s current unit price is considered even if the item price did not exist on the date as of when the change is scheduled. changes_scheduled_at
is in the past and a unit_price_in_decimal
is not passed, then the item price’s current unit price is considered even if the item price did not exist on the date as of when the change is scheduled. charge_on_option
option is set to on_event
, this parameter specifies the event at which the charge-item is applied to the subscription. This parameter only applies to charge-items. active
or non-renewing
state. Also includes reactivations of canceled subscriptions.contract_terminationwhen a contract term is terminated.charge_on_event
occurs. This parameter only applies to charge-items. charge_on_event
.sub_total
.specific_item_priceThe discount is applied to the invoice.line_item.amount
that corresponds to the item price specified by item_price_id
.period
and period_unit
.period_units
. Applicable only when duration_type
is limited_period
. period
. Applicable only when duration_type
is limited_period
. duration_type
is one_time
and when the feature is enabled in Chargebee. Also, If the site-level setting is to exclude one-time discounts from MRR calculations, this value is always returned false
. apply_on
= specific_item_price
. discounts[id]
) is removed from the subscription. Subsequent invoices will no longer have the discount applied. Tip: If you want to replace a discount, remove
it and add
another in the same API call.ending_unit_in_decimal
of the next lower tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. starting_unit_in_decimal
of the next higher tier. Returned only when the pricing_model is tiered
, volume
or stairstep
and multi-decimal pricing is enabled. pricing_model
is tiered
or volume
. When the pricing_model
is stairstep
, it is the decimal representation of the total price for the item. The value is in major units of the currency. Returned when the plan is quantity-based and multi-decimal pricing is enabled. pricing_type
will be set to flat_fee
by default. For example, if the flat fee for a tier is $100, the customer pays $100 whether they consume 1 unit or the maximum number of units within that tier.packageIndicates that the tier pricing is based on a package of units. Customers are charged for each block or package of units. For example, if the package size is 100 units and the cost per block is $20 consuming 400 units will result in a charge of $80 (4 × $20).entity_identifier[i]
in Chargebee. This is required when entity_identifier[operation][i]
is update
or delete
.
vat_number
of the customer. This helps identify the specific type of customer entity. For example, DE:VAT
is used for a German business entity while DE:LWID45
is used for a German government entity. The value must be from the list of possible values and must correspond to the country provided under billing_address.country
. See list of possible values.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
. This identifies the customer entity on the Peppol network. For example: 10101010-STO-10
.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
entity_identifier
.
entity_identifier
for the customer.updateUpdates an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.deleteDeletes an existing entity_identifier
for the customer. entity_identifier[id]
must be provided in this case.entity_identifier
scheme
. Currently, only iso6523-actorid-upis
is supported and is used by default when not provided.
Tip:
If there is only one entity identifier for the customer and the value is the same as vat_number
, then there is no need to provide the entity_identifiers[]
array. See description for entity_identifiers[]
.
Note: If you're using In-App Checkout , use Manage Payment Sources API to request your customers to update their payment method details or change their payment method.
Using this API, you can request your customers to update their payment method details or change their payment method. This is used in scenarios like customers updating their payment methods before the end of trial or customers switching among payment methods.
When this API is invoked, it returns a hosted page URL. When the customers are directed to this URL, they will be able to change/update their payment methods.
Depending on the payment methods (Card, PayPal Express Checkout, Amazon Payments) that you offer your customers, they will find options to switch among the various methods of payment.
Note:curl https://{site}.chargebee.com/api/v2/hosted_pages/update_payment_method \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnHhSBWmKhy2uX" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
curl https://{site}.chargebee.com/api/v2/hosted_pages/update_payment_method \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnHhSBWmKhy2uX" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout. This attribute allows you to store custom information with the hosted_page
object. You can use it to associate specific data with a hosted page session.
For example, you can store the ID of the marketing campaign that initiated the user session. After a successful session, when the customer is redirected, you can retrieve the hosted page ID from the redirect URL's query parameters. Using this ID, you can fetch the hosted page and perform actions related to the success of the marketing campaign.
curl https://{site}.chargebee.com/api/v2/hosted_pages/manage_payment_sources \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnHhSBWmJIX2uE" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
curl https://{site}.chargebee.com/api/v2/hosted_pages/manage_payment_sources \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnHhSBWmJIX2uE" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
curl https://{site}.chargebee.com/api/v2/hosted_pages/collect_now \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnGlSBWmHH82Pw" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
curl https://{site}.chargebee.com/api/v2/hosted_pages/collect_now \ -u {site_api_key}:\ -d "customer[id]"="__test__KyVnGlSBWmHH82Pw" \ -d "card[gateway_account_id]"="gw___test__KyVnGlSBWmAIk2Ph"
curl https://{site}.chargebee.com/api/v2/hosted_pages/accept_quote \ -u {site_api_key}:\ -d "quote[id]"="1"
curl https://{site}.chargebee.com/api/v2/hosted_pages/accept_quote \ -u {site_api_key}:\ -d "quote[id]"="1"
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout.curl https://{site}.chargebee.com/api/v2/hosted_pages/extend_subscription \ -u {site_api_key}:\ -d billing_cycle=2 \ -d expiry=14 \ -d "subscription[id]"="__test__KyVnHhSBWmIgw2u6"
curl https://{site}.chargebee.com/api/v2/hosted_pages/extend_subscription \ -u {site_api_key}:\ -d billing_cycle=2 \ -d expiry=14 \ -d "subscription[id]"="__test__KyVnHhSBWmIgw2u6"
Creates a hosted page for a customer (called the gifter) to gift a subscription to another customer (called the receiver).
When gifter[customer_id]
is provided, it is looked up in Chargebee when the gifter completes the hosted page checkout. If not found, a new customer resource is created with this ID.
If multiple business entities are created for the site, the lookup and creation of the gifter customer resource happen within the context of the business entity specified in this API call. If no business entity is specified, the customer resource lookup is performed within the site context, and if not found, the resource is created for the default business entity of the site.
Once the gifter checks out using the hosted page returned by this endpoint, Chargebee checks if a customer resource with the receiver’s email address exists. The first such customer record is considered the receiver’s customer resource. A new customer resource is created for the receiver if none are found.
If multiple business entities are created for the site, the lookup and creation of the gift receiver’s customer resource happen within the context of the business entity of the gifter
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_gift_for_items \ -u {site_api_key}:\ -d "gifter[customer_id]"="gifter" \ -d "subscription_items[item_price_id][0]"="gift-plan-USD" \ -d "subscription_items[quantity][0]"=2
curl https://{site}.chargebee.com/api/v2/hosted_pages/checkout_gift_for_items \ -u {site_api_key}:\ -d "gifter[customer_id]"="gifter" \ -d "subscription_items[item_price_id][0]"="gift-plan-USD" \ -d "subscription_items[quantity][0]"=2
Sets the context for this operation to the business entity specified. Applicable only when multiple business entities have been created for the site. When this parameter is provided, the operation is able to read/write data associated only to the business entity specified. When not provided, the operation can read/write data for the entire site.
An alternative way of passing this parameter is by means of a custom HTTP header.
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout.The customer ID of the gifter. If not provided, the gifter customer resource is created with an autogenerated ID on checkout.
curl https://{site}.chargebee.com/api/v2/hosted_pages/claim_gift \ -u {site_api_key}:\ -d "gift[id]"="__test__KyVnHhSBWmGdM2tv__test__21cdZvclBhOULyCT1SBUPDKjoXsuc3wdj"
curl https://{site}.chargebee.com/api/v2/hosted_pages/claim_gift \ -u {site_api_key}:\ -d "gift[id]"="__test__KyVnHhSBWmGdM2tv__test__21cdZvclBhOULyCT1SBUPDKjoXsuc3wdj"
redirect_url
after successful checkout, we do not recommend relying on it for completing critical post-checkout actions. This is because redirection may not happen due to unforeseen reasons such as user closing the tab, or exiting the browser, and so on. If there is any synchronization that you are doing after the redirection, you will have to have a backup. Chargebee recommends listening to appropriate webhooks such as subscription_created
or invoice_generated
to verify a successful checkout.This is applicable only for Direct Debit via SEPA, Bacs, Bg Autogiro, BECS (for both Australia and New Zealand) and PAD. For Direct Debit, the customer needs to accept an agreement that allows the merchant to debit their bank account. This agreement PDF allows you to easily display scheme-rules compliant Direct Debit mandates to your customers.
This API retrieves the redirect link to the corresponding agreement for customers. The agreement PDF can be your “Thank You” page or sent by email to customers. Communicating this PDF to your customers is mandatory.
Customer locale is used to generate the PDF in the required language. If a customer language is not supported, the PDF is generated in English. Checkout the list of languages supported by GoCardless.
curl https://{site}.chargebee.com/api/v2/hosted_pages/retrieve_agreement_pdf \ -u {site_api_key}:\ -d payment_source_id="pm___test__KyVnHhSBWmKRg2uT"
curl https://{site}.chargebee.com/api/v2/hosted_pages/retrieve_agreement_pdf \ -u {site_api_key}:\ -d payment_source_id="pm___test__KyVnHhSBWmKRg2uT"
state
is automatically changed to succeeded
. Acknowledging a hosted page confirms that you have moved the customer details from Chargebee into your system and are ready to fulfill it. This API is used to acknowledge the hosted page in succeeded
state and change its state to acknowledged
. When you retrieve a hosted page whose status
is successful
, the content
attribute has the following objects based on the type
of the hosted page.
type of hosted page |
content attribute constituents |
checkout_new |
|
checkout_existing |
|
update_payment_method |
|
pre_cancel |
retention : Use the bypass flag in this object to route the cancellation flow to the merchants’ portal or the Chargebee Retention.
beta . To enable Retention, Contact Support.
|
collect_now |
|
curl https://{site}.chargebee.com/api/v2/hosted_pages/__test__Mgd44pMvDRJLhuy3KNs2j6qBRNbuGG9r \ -u {site_api_key}:
curl https://{site}.chargebee.com/api/v2/hosted_pages/__test__Mgd44pMvDRJLhuy3KNs2j6qBRNbuGG9r \ -u {site_api_key}:
This API retrieves the list of hosted page resources.
curl https://{site}.chargebee.com/api/v2/hosted_pages \ -G \ -u {site_api_key}:\ --data-urlencode limit=2
curl https://{site}.chargebee.com/api/v2/hosted_pages \ -G \ -u {site_api_key}:\ --data-urlencode limit=2
hosted_page
resource of type
pre_cancel
. Route canceling users to this page to provide them a retention experience and start saving revenue.url
in the endpoint response.curl https://{site}.chargebee.com/api/v2/hosted_pages/pre_cancel \ -u {site_api_key}:\ -d pass_thru_content='{custom : {discount_percent: 10}}' \ -d "subscription[id]"="__test__KyVnHhSBWmCoF2tJ"
curl https://{site}.chargebee.com/api/v2/hosted_pages/pre_cancel \ -u {site_api_key}:\ -d pass_thru_content='{custom : {discount_percent: 10}}' \ -d "subscription[id]"="__test__KyVnHhSBWmCoF2tJ"
Additional data to be passed to Chargebee Retention. Only the value of pass_thru_content.custom
is sent to Chargebee Retention. It is sent as the value of the custom
property. The fields provided in pass_thru_content.custom
must be preconfigured in Chargebee Retention.
Although only pass_thru_content.custom
is sent to Chargebee Retention, all of pass_thru_content
is stored by Chargebee billing and is retrievable as an attribute of the hosted_page
.
curl https://{site}.chargebee.com/api/v2/hosted_pages/events \ -u {site_api_key}:\ -d event_name="CANCELLATION_PAGE_LOADED" \ -d occurred_at=1435054328 \ -d event_data='{"subscription_id" : "__test__KyVnHhSBWmCoF2tJ"}'
curl https://{site}.chargebee.com/api/v2/hosted_pages/events \ -u {site_api_key}:\ -d event_name="CANCELLATION_PAGE_LOADED" \ -d occurred_at=1435054328 \ -d event_data='{"subscription_id" : "__test__KyVnHhSBWmCoF2tJ"}'
hosted_page
resource of type, view_voucher
. When your end customers choose the Boleto payment method, you can generate a voucher for their pending invoice. Using this API, you can create a voucher_detail hosted page for your customers and email them a link to this hosted page. Your customers can review the voucher details on the page by clicking the link in the email.curl https://{site}.chargebee.com/api/v2/hosted_pages/view_voucher \ -u {site_api_key}:\ -d "customer[locale]"="fr-CA"
curl https://{site}.chargebee.com/api/v2/hosted_pages/view_voucher \ -u {site_api_key}:\ -d "customer[locale]"="fr-CA"