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
interval
andusage_
.type - recurring.
intervalenumRequired Specifies billing frequency. Either
day
,week
,month
oryear
.Possible enum valuesday
month
week
year
- recurring.
interval_ countinteger The number of intervals between subscription billings. For example,
interval=month
andinterval_
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
metered
orlicensed
.licensed
automatically bills thequantity
set when adding it to a subscription.metered
aggregates the total usage based on usage records. Defaults tolicensed
.Possible enum valueslicensed
metered
- 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 eitherinclusive
orexclusive
, it cannot be changed.Possible enum valuesexclusive
inclusive
unspecified
- 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 tiered
indicates that the unit pricing will be computed using a tiering strategy as defined using thetiers
andtiers_
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
true
to 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 eitherinclusive
orexclusive
, it cannot be changed.Possible enum valuesexclusive
inclusive
unspecified
- 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
inf
to 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
true
to 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
inf
to 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
graduated
orvolume
based. Involume
-based tiering, the maximum quantity within a period determines the per unit price, ingraduated
tiering 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
up
ordown
.
- 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 throws 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"}