Creates a new Price for an existing Product. The Price can be recurring or one-time.
Parameters
- currencyenumRequired
Three-letter ISO currency code, in lowercase. Must be a supported currency.
- activeboolean
Whether the price can be used for new purchases. Defaults to
true. - metadataobject
Set of key-value pairs that you can attach to an object. This can be useful for storing additional information about the object in a structured format. Individual keys can be unset by posting an empty value to them. All keys can be unset by posting an empty value to
metadata. - nicknamestring
A brief description of the price, hidden from customers.
- productstringRequired unless product_data is provided
- recurringobject
The recurring components of a price such as
intervalandusage_.type - recurring.
intervalenumRequired Specifies billing frequency. Either
day,week,monthoryear.Possible enum valuesdaymonthweekyear - recurring.
interval_ countinteger The number of intervals between subscription billings. For example,
interval=monthandinterval_bills every 3 months. Maximum of three years interval allowed (3 years, 36 months, or 156 weeks).count=3 - recurring.
meterstring The meter tracking the usage of a metered price
- recurring.
usage_ typeenum Configures how the quantity per period should be determined. Can be either
meteredorlicensed.licensedautomatically bills thequantityset when adding it to a subscription.meteredaggregates the total usage based on usage records. Defaults tolicensed.Possible enum valueslicensedmetered
- tax_
behaviorenumRecommended if calculating taxes Only required if a default tax behavior was not provided in the Stripe Tax settings. Specifies whether the price is considered inclusive of taxes or exclusive of taxes. One of
inclusive,exclusive, orunspecified. Once specified as eitherinclusiveorexclusive, it cannot be changed.Possible enum valuesexclusiveinclusiveunspecified - unit_
amountintegerRequired conditionally A positive integer in cents (or 0 for a free price) representing how much to charge. One of
unit_,amount unit_, oramount_ decimal custom_is required, unlessunit_ amount billing_.scheme=tiered
More parameters
- billing_
schemeenum Describes how to compute the price per period. Either
per_orunit tiered.per_indicates that the fixed amount (specified inunit unit_oramount unit_) will be charged per unit inamount_ decimal quantity(for prices withusage_), or per unit of total usage (for prices withtype=licensed usage_).type=metered tieredindicates that the unit pricing will be computed using a tiering strategy as defined using thetiersandtiers_attributes.mode Possible enum valuesper_unit tiered - currency_
optionsobject Prices defined in each available currency option. Each key must be a three-letter ISO currency code and a supported currency.
- currency_options.
<currency>. custom_ unit_ amountobjectRequired conditionally When set, provides configuration for the amount to be adjusted by the customer during Checkout Sessions and Payment Links.
- currency_options.
<currency>.custom_unit_amount. enabledbooleanRequired Pass in
trueto enablecustom_, otherwise omitunit_ amount custom_.unit_ amount - currency_options.
<currency>.custom_unit_amount. maximuminteger The maximum unit amount the customer can specify for this item.
- currency_options.
<currency>.custom_unit_amount. minimuminteger The minimum unit amount the customer can specify for this item. Must be at least the minimum charge amount.
- currency_options.
<currency>.custom_unit_amount. presetinteger The starting unit amount which can be updated by the customer.
- currency_options.
<currency>. tax_ behaviorenumRecommended if calculating taxes Only required if a default tax behavior was not provided in the Stripe Tax settings. Specifies whether the price is considered inclusive of taxes or exclusive of taxes. One of
inclusive,exclusive, orunspecified. Once specified as eitherinclusiveorexclusive, it cannot be changed.Possible enum valuesexclusiveinclusiveunspecified - currency_options.
<currency>. tiersarray of objectsRequired if billing_scheme=tiered Each element represents a pricing tier. This parameter requires
billing_to be set toscheme tiered. See also the documentation forbilling_.scheme - currency_options.
<currency>.tiers. up_ tostring | integerRequired Specifies the upper bound of this tier. The lower bound of a tier is the upper bound of the previous tier adding one. Use
infto define a fallback tier. - currency_options.
<currency>.tiers. flat_ amountinteger The flat billing amount for an entire tier, regardless of the number of units in the tier.
- currency_options.
<currency>.tiers. flat_ amount_ decimalstring Same as
flat_, but accepts a decimal value representing an integer in the minor units of the currency. Only one ofamount flat_andamount flat_can be set.amount_ decimal - currency_options.
<currency>.tiers. unit_ amountinteger The per unit billing amount for each individual unit for which this tier applies.
- currency_options.
<currency>.tiers. unit_ amount_ decimalstring Same as
unit_, but accepts a decimal value in cents with at most 12 decimal places. Only one ofamount unit_andamount unit_can be set.amount_ decimal
- currency_options.
<currency>. unit_ amountintegerRequired conditionally A positive integer in cents (or 0 for a free price) representing how much to charge.
- currency_options.
<currency>. unit_ amount_ decimalstringRequired conditionally Same as
unit_, but accepts a decimal value in cents with at most 12 decimal places. Only one ofamount unit_andamount unit_can be set.amount_ decimal
- custom_
unit_ amountobjectRequired unless unit_amount is provided When set, provides configuration for the amount to be adjusted by the customer during Checkout Sessions and Payment Links.
- custom_unit_amount.
enabledbooleanRequired Pass in
trueto enablecustom_, otherwise omitunit_ amount custom_.unit_ amount - custom_unit_amount.
maximuminteger The maximum unit amount the customer can specify for this item.
- custom_unit_amount.
minimuminteger The minimum unit amount the customer can specify for this item. Must be at least the minimum charge amount.
- custom_unit_amount.
presetinteger The starting unit amount which can be updated by the customer.
- lookup_
keystring A lookup key used to retrieve prices dynamically from a static string. This may be up to 200 characters.
- product_
dataobjectRequired unless product is provided These fields can be used to create a new product that this price will belong to.
- product_data.
namestringRequired The product’s name, meant to be displayable to the customer.
- product_data.
activeboolean Whether the product is currently available for purchase. Defaults to
true. - product_data.
metadataobject Set of key-value pairs that you can attach to an object. This can be useful for storing additional information about the object in a structured format. Individual keys can be unset by posting an empty value to them. All keys can be unset by posting an empty value to
metadata. - product_data.
statement_ descriptorstring An arbitrary string to be displayed on your customer’s credit card or bank statement. While most banks display this information consistently, some may display it incorrectly or not at all.
This may be up to 22 characters. The statement description may not include
<,>,\,",'characters, and will appear on your customer’s statement in capital letters. Non-ASCII characters are automatically stripped. - product_data.
tax_ codestringRecommended if calculating taxes A tax code ID.
- product_data.
unit_ labelstring A label that represents units of this product. When set, this will be included in customers’ receipts, invoices, Checkout, and the customer portal.
- tiersarray of objectsRequired if billing_scheme=tiered
Each element represents a pricing tier. This parameter requires
billing_to be set toscheme tiered. See also the documentation forbilling_.scheme - tiers.
up_ tostring | integerRequired Specifies the upper bound of this tier. The lower bound of a tier is the upper bound of the previous tier adding one. Use
infto define a fallback tier. - tiers.
flat_ amountinteger The flat billing amount for an entire tier, regardless of the number of units in the tier.
- tiers.
flat_ amount_ decimalstring Same as
flat_, but accepts a decimal value representing an integer in the minor units of the currency. Only one ofamount flat_andamount flat_can be set.amount_ decimal - tiers.
unit_ amountinteger The per unit billing amount for each individual unit for which this tier applies.
- tiers.
unit_ amount_ decimalstring Same as
unit_, but accepts a decimal value in cents with at most 12 decimal places. Only one ofamount unit_andamount unit_can be set.amount_ decimal
- tiers_
modeenumRequired if billing_scheme=tiered Defines if the tiering price should be
graduatedorvolumebased. Involume-based tiering, the maximum quantity within a period determines the per unit price, ingraduatedtiering pricing can successively change as the quantity grows. - transfer_
lookup_ keyboolean If set to true, will atomically remove the lookup key from the existing price, and assign it to this price.
- transform_
quantityobject Apply a transformation to the reported usage or set quantity before computing the billed price. Cannot be combined with
tiers.- transform_quantity.
divide_ byintegerRequired Divide usage by this number.
- transform_quantity.
roundenumRequired After division, either round the result
upordown.
- unit_
amount_ decimalstring Same as
unit_, but accepts a decimal value in cents with at most 12 decimal places. Only one ofamount unit_andamount unit_can be set.amount_ decimal
Returns
The newly created Price object is returned upon success. Otherwise, this call raises an error.
{ "id": "price_1MoBy5LkdIwHu7ixZhnattbh", "object": "price", "active": true, "billing_scheme": "per_unit", "created": 1679431181, "currency": "usd", "custom_unit_amount": null, "livemode": false, "lookup_key": null, "metadata": {}, "nickname": null, "product": "prod_NZKdYqrwEYx6iK", "recurring": { "interval": "month", "interval_count": 1, "trial_period_days": null, "usage_type": "licensed" }, "tax_behavior": "unspecified", "tiers_mode": null, "transform_quantity": null, "type": "recurring", "unit_amount": 1000, "unit_amount_decimal": "1000"}