All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.stripe.model.Price Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.PriceCreateParams;
import com.stripe.param.PriceListParams;
import com.stripe.param.PriceRetrieveParams;
import com.stripe.param.PriceSearchParams;
import com.stripe.param.PriceUpdateParams;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * Prices define the unit cost, currency, and (optional) billing cycle for both recurring and
 * one-time purchases of products. Products help
 * you track inventory or provisioning, and prices help you track payment terms. Different physical
 * goods or levels of service should be represented by products, and pricing options should be
 * represented by prices. This approach lets you change prices without having to change your
 * provisioning scheme.
 *
 * 

For example, you might have a single "gold" product that has prices for $10/month, * $100/year, and €9 once. * *

Related guides: Set up a * subscription, create an * invoice, and more about products * and prices. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Price extends ApiResource implements HasId, MetadataStore { /** Whether the price can be used for new purchases. */ @SerializedName("active") Boolean active; /** * Describes how to compute the price per period. Either {@code per_unit} or {@code tiered}. * {@code per_unit} indicates that the fixed amount (specified in {@code unit_amount} or {@code * unit_amount_decimal}) will be charged per unit in {@code quantity} (for prices with {@code * usage_type=licensed}), or per unit of total usage (for prices with {@code usage_type=metered}). * {@code tiered} indicates that the unit pricing will be computed using a tiering strategy as * defined using the {@code tiers} and {@code tiers_mode} attributes. * *

One of {@code per_unit}, or {@code tiered}. */ @SerializedName("billing_scheme") String billingScheme; /** Time at which the object was created. Measured in seconds since the Unix epoch. */ @SerializedName("created") Long created; /** * Three-letter ISO currency code, * in lowercase. Must be a supported currency. */ @SerializedName("currency") String currency; /** * Prices defined in each available currency option. Each key must be a three-letter ISO currency code and a supported currency. */ @SerializedName("currency_options") Map currencyOptions; /** * When set, provides configuration for the amount to be adjusted by the customer during Checkout * Sessions and Payment Links. */ @SerializedName("custom_unit_amount") CustomUnitAmount customUnitAmount; /** Always true for a deleted object. */ @SerializedName("deleted") Boolean deleted; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * Has the value {@code true} if the object exists in live mode or the value {@code false} if the * object exists in test mode. */ @SerializedName("livemode") Boolean livemode; /** * A lookup key used to retrieve prices dynamically from a static string. This may be up to 200 * characters. */ @SerializedName("lookup_key") String lookupKey; /** * 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. */ @Getter(onMethod_ = {@Override}) @SerializedName("metadata") Map metadata; /** Subscriptions using this price will be migrated to use the new referenced price. */ @SerializedName("migrate_to") MigrateTo migrateTo; /** A brief description of the price, hidden from customers. */ @SerializedName("nickname") String nickname; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code price}. */ @SerializedName("object") String object; /** The ID of the product this price is associated with. */ @SerializedName("product") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField product; /** The recurring components of a price such as {@code interval} and {@code usage_type}. */ @SerializedName("recurring") Recurring recurring; /** * 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 {@code inclusive}, {@code * exclusive}, or {@code unspecified}. Once specified as either {@code inclusive} or {@code * exclusive}, it cannot be changed. */ @SerializedName("tax_behavior") String taxBehavior; /** * Each element represents a pricing tier. This parameter requires {@code billing_scheme} to be * set to {@code tiered}. See also the documentation for {@code billing_scheme}. */ @SerializedName("tiers") List tiers; /** * Defines if the tiering price should be {@code graduated} or {@code volume} based. In {@code * volume}-based tiering, the maximum quantity within a period determines the per unit price. In * {@code graduated} tiering, pricing can change as the quantity grows. * *

One of {@code graduated}, or {@code volume}. */ @SerializedName("tiers_mode") String tiersMode; /** * Apply a transformation to the reported usage or set quantity before computing the amount * billed. Cannot be combined with {@code tiers}. */ @SerializedName("transform_quantity") TransformQuantity transformQuantity; /** * One of {@code one_time} or {@code recurring} depending on whether the price is for a one-time * purchase or a recurring (subscription) purchase. */ @SerializedName("type") String type; /** * The unit amount in cents (or local equivalent) to be charged, represented as a whole integer if * possible. Only set if {@code billing_scheme=per_unit}. */ @SerializedName("unit_amount") Long unitAmount; /** * The unit amount in cents (or local equivalent) to be charged, represented as a decimal string * with at most 12 decimal places. Only set if {@code billing_scheme=per_unit}. */ @SerializedName("unit_amount_decimal") BigDecimal unitAmountDecimal; /** Get ID of expandable {@code product} object. */ public String getProduct() { return (this.product != null) ? this.product.getId() : null; } public void setProduct(String id) { this.product = ApiResource.setExpandableFieldId(id, this.product); } /** Get expanded {@code product}. */ public Product getProductObject() { return (this.product != null) ? this.product.getExpanded() : null; } public void setProductObject(Product expandableObject) { this.product = new ExpandableField(expandableObject.getId(), expandableObject); } /** Creates a new price for an existing product. The price can be recurring or one-time. */ public static Price create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new price for an existing product. The price can be recurring or one-time. */ public static Price create(Map params, RequestOptions options) throws StripeException { String path = "/v1/prices"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Price.class); } /** Creates a new price for an existing product. The price can be recurring or one-time. */ public static Price create(PriceCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new price for an existing product. The price can be recurring or one-time. */ public static Price create(PriceCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/prices"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Price.class); } /** * Returns a list of your active prices, excluding inline prices. * For the list of inactive prices, set {@code active} to false. */ public static PriceCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of your active prices, excluding inline prices. * For the list of inactive prices, set {@code active} to false. */ public static PriceCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/prices"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, PriceCollection.class); } /** * Returns a list of your active prices, excluding inline prices. * For the list of inactive prices, set {@code active} to false. */ public static PriceCollection list(PriceListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of your active prices, excluding inline prices. * For the list of inactive prices, set {@code active} to false. */ public static PriceCollection list(PriceListParams params, RequestOptions options) throws StripeException { String path = "/v1/prices"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, PriceCollection.class); } /** Retrieves the price with the given ID. */ public static Price retrieve(String price) throws StripeException { return retrieve(price, (Map) null, (RequestOptions) null); } /** Retrieves the price with the given ID. */ public static Price retrieve(String price, RequestOptions options) throws StripeException { return retrieve(price, (Map) null, options); } /** Retrieves the price with the given ID. */ public static Price retrieve(String price, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/prices/%s", ApiResource.urlEncodeId(price)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Price.class); } /** Retrieves the price with the given ID. */ public static Price retrieve(String price, PriceRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/prices/%s", ApiResource.urlEncodeId(price)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Price.class); } /** * Search for prices you’ve previously created using Stripe’s Search Query Language. Don’t * use search in read-after-write flows where strict consistency is necessary. Under normal * operating conditions, data is searchable in less than a minute. Occasionally, propagation of * new or updated data can be up to an hour behind during outages. Search functionality is not * available to merchants in India. */ public static PriceSearchResult search(Map params) throws StripeException { return search(params, (RequestOptions) null); } /** * Search for prices you’ve previously created using Stripe’s Search Query Language. Don’t * use search in read-after-write flows where strict consistency is necessary. Under normal * operating conditions, data is searchable in less than a minute. Occasionally, propagation of * new or updated data can be up to an hour behind during outages. Search functionality is not * available to merchants in India. */ public static PriceSearchResult search(Map params, RequestOptions options) throws StripeException { String path = "/v1/prices/search"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, PriceSearchResult.class); } /** * Search for prices you’ve previously created using Stripe’s Search Query Language. Don’t * use search in read-after-write flows where strict consistency is necessary. Under normal * operating conditions, data is searchable in less than a minute. Occasionally, propagation of * new or updated data can be up to an hour behind during outages. Search functionality is not * available to merchants in India. */ public static PriceSearchResult search(PriceSearchParams params) throws StripeException { return search(params, (RequestOptions) null); } /** * Search for prices you’ve previously created using Stripe’s Search Query Language. Don’t * use search in read-after-write flows where strict consistency is necessary. Under normal * operating conditions, data is searchable in less than a minute. Occasionally, propagation of * new or updated data can be up to an hour behind during outages. Search functionality is not * available to merchants in India. */ public static PriceSearchResult search(PriceSearchParams params, RequestOptions options) throws StripeException { String path = "/v1/prices/search"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, PriceSearchResult.class); } /** * Updates the specified price by setting the values of the parameters passed. Any parameters not * provided are left unchanged. */ @Override public Price update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified price by setting the values of the parameters passed. Any parameters not * provided are left unchanged. */ @Override public Price update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/prices/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Price.class); } /** * Updates the specified price by setting the values of the parameters passed. Any parameters not * provided are left unchanged. */ public Price update(PriceUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified price by setting the values of the parameters passed. Any parameters not * provided are left unchanged. */ public Price update(PriceUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/prices/%s", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Price.class); } /** * For more details about CurrencyOption, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CurrencyOption extends StripeObject { /** * When set, provides configuration for the amount to be adjusted by the customer during * Checkout Sessions and Payment Links. */ @SerializedName("custom_unit_amount") CustomUnitAmount customUnitAmount; /** * 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 {@code inclusive}, {@code * exclusive}, or {@code unspecified}. Once specified as either {@code inclusive} or {@code * exclusive}, it cannot be changed. */ @SerializedName("tax_behavior") String taxBehavior; /** * Each element represents a pricing tier. This parameter requires {@code billing_scheme} to be * set to {@code tiered}. See also the documentation for {@code billing_scheme}. */ @SerializedName("tiers") List tiers; /** * The unit amount in cents (or local equivalent) to be charged, represented as a whole integer * if possible. Only set if {@code billing_scheme=per_unit}. */ @SerializedName("unit_amount") Long unitAmount; /** * The unit amount in cents (or local equivalent) to be charged, represented as a decimal string * with at most 12 decimal places. Only set if {@code billing_scheme=per_unit}. */ @SerializedName("unit_amount_decimal") BigDecimal unitAmountDecimal; /** * For more details about CustomUnitAmount, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CustomUnitAmount extends StripeObject { /** The maximum unit amount the customer can specify for this item. */ @SerializedName("maximum") Long maximum; /** * The minimum unit amount the customer can specify for this item. Must be at least the * minimum charge amount. */ @SerializedName("minimum") Long minimum; /** The starting unit amount which can be updated by the customer. */ @SerializedName("preset") Long preset; } /** * For more details about Tier, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tier extends StripeObject { /** Price for the entire tier. */ @SerializedName("flat_amount") Long flatAmount; /** * Same as {@code flat_amount}, but contains a decimal value with at most 12 decimal places. */ @SerializedName("flat_amount_decimal") BigDecimal flatAmountDecimal; /** Per unit price for units relevant to the tier. */ @SerializedName("unit_amount") Long unitAmount; /** * Same as {@code unit_amount}, but contains a decimal value with at most 12 decimal places. */ @SerializedName("unit_amount_decimal") BigDecimal unitAmountDecimal; /** Up to and including to this quantity will be contained in the tier. */ @SerializedName("up_to") Long upTo; } } /** * For more details about CustomUnitAmount, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CustomUnitAmount extends StripeObject { /** The maximum unit amount the customer can specify for this item. */ @SerializedName("maximum") Long maximum; /** * The minimum unit amount the customer can specify for this item. Must be at least the minimum * charge amount. */ @SerializedName("minimum") Long minimum; /** The starting unit amount which can be updated by the customer. */ @SerializedName("preset") Long preset; } /** * For more details about MigrateTo, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class MigrateTo extends StripeObject { /** * The behavior controlling at what point in the subscription lifecycle to migrate the price * *

Equal to {@code at_cycle_end}. */ @SerializedName("behavior") String behavior; /** The unix timestamp after at which subscriptions will start to migrate to the new price. */ @SerializedName("effective_after") Long effectiveAfter; /** The id of the price being migrated to. */ @SerializedName("price") String price; } /** * For more details about Recurring, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Recurring extends StripeObject { /** * Specifies a usage aggregation strategy for prices of {@code usage_type=metered}. Defaults to * {@code sum}. * *

One of {@code last_during_period}, {@code last_ever}, {@code max}, or {@code sum}. */ @SerializedName("aggregate_usage") String aggregateUsage; /** * The frequency at which a subscription is billed. One of {@code day}, {@code week}, {@code * month} or {@code year}. */ @SerializedName("interval") String interval; /** * The number of intervals (specified in the {@code interval} attribute) between subscription * billings. For example, {@code interval=month} and {@code interval_count=3} bills every 3 * months. */ @SerializedName("interval_count") Long intervalCount; /** The meter tracking the usage of a metered price. */ @SerializedName("meter") String meter; /** * Default number of trial days when subscribing a customer to this price using {@code * trial_from_plan=true}. */ @SerializedName("trial_period_days") Long trialPeriodDays; /** * Configures how the quantity per period should be determined. Can be either {@code metered} or * {@code licensed}. {@code licensed} automatically bills the {@code quantity} set when adding * it to a subscription. {@code metered} aggregates the total usage based on usage records. * Defaults to {@code licensed}. */ @SerializedName("usage_type") String usageType; } /** * For more details about Tier, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tier extends StripeObject { /** Price for the entire tier. */ @SerializedName("flat_amount") Long flatAmount; /** Same as {@code flat_amount}, but contains a decimal value with at most 12 decimal places. */ @SerializedName("flat_amount_decimal") BigDecimal flatAmountDecimal; /** Per unit price for units relevant to the tier. */ @SerializedName("unit_amount") Long unitAmount; /** Same as {@code unit_amount}, but contains a decimal value with at most 12 decimal places. */ @SerializedName("unit_amount_decimal") BigDecimal unitAmountDecimal; /** Up to and including to this quantity will be contained in the tier. */ @SerializedName("up_to") Long upTo; } /** * For more details about TransformQuantity, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TransformQuantity extends StripeObject { /** Divide usage by this number. */ @SerializedName("divide_by") Long divideBy; /** * After division, either round the result {@code up} or {@code down}. * *

One of {@code down}, or {@code up}. */ @SerializedName("round") String round; } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(customUnitAmount, responseGetter); trySetResponseGetter(migrateTo, responseGetter); trySetResponseGetter(product, responseGetter); trySetResponseGetter(recurring, responseGetter); trySetResponseGetter(transformQuantity, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy