com.stripe.model.Subscription Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model;
import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.testhelpers.TestClock;
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.SubscriptionCancelParams;
import com.stripe.param.SubscriptionCreateParams;
import com.stripe.param.SubscriptionListParams;
import com.stripe.param.SubscriptionResumeParams;
import com.stripe.param.SubscriptionRetrieveParams;
import com.stripe.param.SubscriptionSearchParams;
import com.stripe.param.SubscriptionUpdateParams;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* Subscriptions allow you to charge a customer on a recurring basis.
*
* Related guide: Creating
* subscriptions
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class Subscription extends ApiResource implements HasId, MetadataStore {
/** ID of the Connect Application that created the subscription. */
@SerializedName("application")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField application;
/**
* A non-negative decimal between 0 and 100, with at most two decimal places. This represents the
* percentage of the subscription invoice total that will be transferred to the application
* owner's Stripe account.
*/
@SerializedName("application_fee_percent")
BigDecimal applicationFeePercent;
@SerializedName("automatic_tax")
AutomaticTax automaticTax;
/**
* The reference point that aligns future billing cycle dates. It sets the
* day of week for {@code week} intervals, the day of month for {@code month} and {@code year}
* intervals, and the month of year for {@code year} intervals. The timestamp is in UTC format.
*/
@SerializedName("billing_cycle_anchor")
Long billingCycleAnchor;
/** The fixed values used to calculate the {@code billing_cycle_anchor}. */
@SerializedName("billing_cycle_anchor_config")
BillingCycleAnchorConfig billingCycleAnchorConfig;
/**
* Define thresholds at which an invoice will be sent, and the subscription advanced to a new
* billing period.
*/
@SerializedName("billing_thresholds")
BillingThresholds billingThresholds;
/** A date in the future at which the subscription will automatically get canceled. */
@SerializedName("cancel_at")
Long cancelAt;
/**
* Whether this subscription will (if {@code status=active}) or did (if {@code status=canceled})
* cancel at the end of the current billing period.
*/
@SerializedName("cancel_at_period_end")
Boolean cancelAtPeriodEnd;
/**
* If the subscription has been canceled, the date of that cancellation. If the subscription was
* canceled with {@code cancel_at_period_end}, {@code canceled_at} will reflect the time of the
* most recent update request, not the end of the subscription period when the subscription is
* automatically moved to a canceled state.
*/
@SerializedName("canceled_at")
Long canceledAt;
/** Details about why this subscription was cancelled. */
@SerializedName("cancellation_details")
CancellationDetails cancellationDetails;
/**
* Either {@code charge_automatically}, or {@code send_invoice}. When charging automatically,
* Stripe will attempt to pay this subscription at the end of the cycle using the default source
* attached to the customer. When sending an invoice, Stripe will email your customer an invoice
* with payment instructions and mark the subscription as {@code active}.
*
* One of {@code charge_automatically}, or {@code send_invoice}.
*/
@SerializedName("collection_method")
String collectionMethod;
/** 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;
/**
* End of the current period that the subscription has been invoiced for. At the end of this
* period, a new invoice will be created.
*/
@SerializedName("current_period_end")
Long currentPeriodEnd;
/** Start of the current period that the subscription has been invoiced for. */
@SerializedName("current_period_start")
Long currentPeriodStart;
/** ID of the customer who owns the subscription. */
@SerializedName("customer")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField customer;
/**
* Number of days a customer has to pay invoices generated by this subscription. This value will
* be {@code null} for subscriptions where {@code collection_method=charge_automatically}.
*/
@SerializedName("days_until_due")
Long daysUntilDue;
/**
* ID of the default payment method for the subscription. It must belong to the customer
* associated with the subscription. This takes precedence over {@code default_source}. If neither
* are set, invoices will use the customer's invoice_settings.default_payment_method
* or default_source.
*/
@SerializedName("default_payment_method")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField defaultPaymentMethod;
/**
* ID of the default payment source for the subscription. It must belong to the customer
* associated with the subscription and be in a chargeable state. If {@code
* default_payment_method} is also set, {@code default_payment_method} will take precedence. If
* neither are set, invoices will use the customer's invoice_settings.default_payment_method
* or default_source.
*/
@SerializedName("default_source")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField defaultSource;
/**
* The tax rates that will apply to any subscription item that does not have {@code tax_rates}
* set. Invoices created will have their {@code default_tax_rates} populated from the
* subscription.
*/
@SerializedName("default_tax_rates")
List defaultTaxRates;
/**
* The subscription's description, meant to be displayable to the customer. Use this field to
* optionally store an explanation of the subscription for rendering in Stripe surfaces and
* certain local payment methods UIs.
*/
@SerializedName("description")
String description;
/**
* Describes the current discount applied to this subscription, if there is one. When billing, a
* discount applied to a subscription overrides a discount applied on a customer-wide basis. This
* field has been deprecated and will be removed in a future API version. Use {@code discounts}
* instead.
*/
@SerializedName("discount")
Discount discount;
/**
* The discounts applied to the subscription. Subscription item discounts are applied before
* subscription discounts. Use {@code expand[]=discounts} to expand each discount.
*/
@SerializedName("discounts")
List> discounts;
/** If the subscription has ended, the date the subscription ended. */
@SerializedName("ended_at")
Long endedAt;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
@SerializedName("invoice_settings")
InvoiceSettings invoiceSettings;
/** List of subscription items, each with an attached price. */
@SerializedName("items")
SubscriptionItemCollection items;
/** Details of the most recent price migration that failed for the subscription. */
@SerializedName("last_price_migration_error")
LastPriceMigrationError lastPriceMigrationError;
/** The most recent invoice this subscription has generated. */
@SerializedName("latest_invoice")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField latestInvoice;
/**
* 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;
/**
* 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;
/**
* Specifies the approximate timestamp on which any pending invoice items will be billed according
* to the schedule provided at {@code pending_invoice_item_interval}.
*/
@SerializedName("next_pending_invoice_item_invoice")
Long nextPendingInvoiceItemInvoice;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code subscription}.
*/
@SerializedName("object")
String object;
/**
* The account (if any) the charge was made on behalf of for charges associated with this
* subscription. See the Connect documentation for details.
*/
@SerializedName("on_behalf_of")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField onBehalfOf;
/**
* If specified, payment collection for this subscription will be paused. Note that the
* subscription status will be unchanged and will not be updated to {@code paused}. Learn more
* about pausing
* collection.
*/
@SerializedName("pause_collection")
PauseCollection pauseCollection;
/** Payment settings passed on to invoices created by the subscription. */
@SerializedName("payment_settings")
PaymentSettings paymentSettings;
/**
* Specifies an interval for how often to bill for any pending invoice items. It is analogous to
* calling Create an invoice for the
* given subscription at the specified interval.
*/
@SerializedName("pending_invoice_item_interval")
PendingInvoiceItemInterval pendingInvoiceItemInterval;
/**
* You can use this SetupIntent to collect
* user authentication when creating a subscription without immediate payment or updating a
* subscription's payment method, allowing you to optimize for off-session payments. Learn more in
* the SCA
* Migration Guide.
*/
@SerializedName("pending_setup_intent")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField pendingSetupIntent;
/**
* If specified, pending
* updates that will be applied to the subscription once the {@code latest_invoice} has been
* paid.
*/
@SerializedName("pending_update")
PendingUpdate pendingUpdate;
/** Time period and invoice for a Subscription billed in advance. */
@SerializedName("prebilling")
Prebilling prebilling;
/** The schedule attached to the subscription. */
@SerializedName("schedule")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField schedule;
/**
* Date when the subscription was first created. The date might differ from the {@code created}
* date due to backdating.
*/
@SerializedName("start_date")
Long startDate;
/**
* Possible values are {@code incomplete}, {@code incomplete_expired}, {@code trialing}, {@code
* active}, {@code past_due}, {@code canceled}, {@code unpaid}, or {@code paused}.
*
* For {@code collection_method=charge_automatically} a subscription moves into {@code
* incomplete} if the initial payment attempt fails. A subscription in this status can only have
* metadata and default_source updated. Once the first invoice is paid, the subscription moves
* into an {@code active} status. If the first invoice is not paid within 23 hours, the
* subscription transitions to {@code incomplete_expired}. This is a terminal status, the open
* invoice will be voided and no further invoices will be generated.
*
*
A subscription that is currently in a trial period is {@code trialing} and moves to {@code
* active} when the trial period is over.
*
*
A subscription can only enter a {@code paused} status when
* a trial ends without a payment method. A {@code paused} subscription doesn't generate
* invoices and can be resumed after your customer adds their payment method. The {@code paused}
* status is different from pausing collection,
* which still generates invoices and leaves the subscription's status unchanged.
*
*
If subscription {@code collection_method=charge_automatically}, it becomes {@code past_due}
* when payment is required but cannot be paid (due to failed payment or awaiting additional user
* actions). Once Stripe has exhausted all payment retry attempts, the subscription will become
* {@code canceled} or {@code unpaid} (depending on your subscriptions settings).
*
*
If subscription {@code collection_method=send_invoice} it becomes {@code past_due} when its
* invoice is not paid by the due date, and {@code canceled} or {@code unpaid} if it is still not
* paid by an additional deadline after that. Note that when a subscription has a status of {@code
* unpaid}, no subsequent invoices will be attempted (invoices will be created, but then
* immediately automatically closed). After receiving updated payment information from a customer,
* you may choose to reopen and pay their closed invoices.
*
*
One of {@code active}, {@code canceled}, {@code incomplete}, {@code incomplete_expired},
* {@code past_due}, {@code paused}, {@code trialing}, or {@code unpaid}.
*/
@SerializedName("status")
String status;
/** ID of the test clock this subscription belongs to. */
@SerializedName("test_clock")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField testClock;
/**
* The account (if any) the subscription's payments will be attributed to for tax reporting, and
* where funds from each payment will be transferred to for each of the subscription's invoices.
*/
@SerializedName("transfer_data")
TransferData transferData;
/** If the subscription has a trial, the end of that trial. */
@SerializedName("trial_end")
Long trialEnd;
/** Settings related to subscription trials. */
@SerializedName("trial_settings")
TrialSettings trialSettings;
/** If the subscription has a trial, the beginning of that trial. */
@SerializedName("trial_start")
Long trialStart;
/** Get ID of expandable {@code application} object. */
public String getApplication() {
return (this.application != null) ? this.application.getId() : null;
}
public void setApplication(String id) {
this.application = ApiResource.setExpandableFieldId(id, this.application);
}
/** Get expanded {@code application}. */
public Application getApplicationObject() {
return (this.application != null) ? this.application.getExpanded() : null;
}
public void setApplicationObject(Application expandableObject) {
this.application = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code customer} object. */
public String getCustomer() {
return (this.customer != null) ? this.customer.getId() : null;
}
public void setCustomer(String id) {
this.customer = ApiResource.setExpandableFieldId(id, this.customer);
}
/** Get expanded {@code customer}. */
public Customer getCustomerObject() {
return (this.customer != null) ? this.customer.getExpanded() : null;
}
public void setCustomerObject(Customer expandableObject) {
this.customer = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code defaultPaymentMethod} object. */
public String getDefaultPaymentMethod() {
return (this.defaultPaymentMethod != null) ? this.defaultPaymentMethod.getId() : null;
}
public void setDefaultPaymentMethod(String id) {
this.defaultPaymentMethod = ApiResource.setExpandableFieldId(id, this.defaultPaymentMethod);
}
/** Get expanded {@code defaultPaymentMethod}. */
public PaymentMethod getDefaultPaymentMethodObject() {
return (this.defaultPaymentMethod != null) ? this.defaultPaymentMethod.getExpanded() : null;
}
public void setDefaultPaymentMethodObject(PaymentMethod expandableObject) {
this.defaultPaymentMethod =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code defaultSource} object. */
public String getDefaultSource() {
return (this.defaultSource != null) ? this.defaultSource.getId() : null;
}
public void setDefaultSource(String id) {
this.defaultSource = ApiResource.setExpandableFieldId(id, this.defaultSource);
}
/** Get expanded {@code defaultSource}. */
public PaymentSource getDefaultSourceObject() {
return (this.defaultSource != null) ? this.defaultSource.getExpanded() : null;
}
public void setDefaultSourceObject(PaymentSource expandableObject) {
this.defaultSource =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code latestInvoice} object. */
public String getLatestInvoice() {
return (this.latestInvoice != null) ? this.latestInvoice.getId() : null;
}
public void setLatestInvoice(String id) {
this.latestInvoice = ApiResource.setExpandableFieldId(id, this.latestInvoice);
}
/** Get expanded {@code latestInvoice}. */
public Invoice getLatestInvoiceObject() {
return (this.latestInvoice != null) ? this.latestInvoice.getExpanded() : null;
}
public void setLatestInvoiceObject(Invoice expandableObject) {
this.latestInvoice = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code onBehalfOf} object. */
public String getOnBehalfOf() {
return (this.onBehalfOf != null) ? this.onBehalfOf.getId() : null;
}
public void setOnBehalfOf(String id) {
this.onBehalfOf = ApiResource.setExpandableFieldId(id, this.onBehalfOf);
}
/** Get expanded {@code onBehalfOf}. */
public Account getOnBehalfOfObject() {
return (this.onBehalfOf != null) ? this.onBehalfOf.getExpanded() : null;
}
public void setOnBehalfOfObject(Account expandableObject) {
this.onBehalfOf = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code pendingSetupIntent} object. */
public String getPendingSetupIntent() {
return (this.pendingSetupIntent != null) ? this.pendingSetupIntent.getId() : null;
}
public void setPendingSetupIntent(String id) {
this.pendingSetupIntent = ApiResource.setExpandableFieldId(id, this.pendingSetupIntent);
}
/** Get expanded {@code pendingSetupIntent}. */
public SetupIntent getPendingSetupIntentObject() {
return (this.pendingSetupIntent != null) ? this.pendingSetupIntent.getExpanded() : null;
}
public void setPendingSetupIntentObject(SetupIntent expandableObject) {
this.pendingSetupIntent =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code schedule} object. */
public String getSchedule() {
return (this.schedule != null) ? this.schedule.getId() : null;
}
public void setSchedule(String id) {
this.schedule = ApiResource.setExpandableFieldId(id, this.schedule);
}
/** Get expanded {@code schedule}. */
public SubscriptionSchedule getScheduleObject() {
return (this.schedule != null) ? this.schedule.getExpanded() : null;
}
public void setScheduleObject(SubscriptionSchedule expandableObject) {
this.schedule =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code testClock} object. */
public String getTestClock() {
return (this.testClock != null) ? this.testClock.getId() : null;
}
public void setTestClock(String id) {
this.testClock = ApiResource.setExpandableFieldId(id, this.testClock);
}
/** Get expanded {@code testClock}. */
public TestClock getTestClockObject() {
return (this.testClock != null) ? this.testClock.getExpanded() : null;
}
public void setTestClockObject(TestClock expandableObject) {
this.testClock = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get IDs of expandable {@code discounts} object list. */
public List getDiscounts() {
return (this.discounts != null)
? this.discounts.stream().map(x -> x.getId()).collect(Collectors.toList())
: null;
}
public void setDiscounts(List ids) {
if (ids == null) {
this.discounts = null;
return;
}
if (this.discounts != null
&& this.discounts.stream().map(x -> x.getId()).collect(Collectors.toList()).equals(ids)) {
// noop if the ids are equal to what are already present
return;
}
this.discounts =
(ids != null)
? ids.stream()
.map(id -> new ExpandableField(id, null))
.collect(Collectors.toList())
: null;
}
/** Get expanded {@code discounts}. */
public List getDiscountObjects() {
return (this.discounts != null)
? this.discounts.stream().map(x -> x.getExpanded()).collect(Collectors.toList())
: null;
}
public void setDiscountObjects(List objs) {
this.discounts =
objs != null
? objs.stream()
.map(x -> new ExpandableField(x.getId(), x))
.collect(Collectors.toList())
: null;
}
/**
* Cancels a customer’s subscription immediately. The customer won’t be charged again for the
* subscription. After it’s canceled, you can no longer update the subscription or its metadata.
*
* Any pending invoice items that you’ve created are still charged at the end of the period,
* unless manually deleted. If you’ve
* set the subscription to cancel at the end of the period, any pending prorations are also left
* in place and collected at the end of the period. But if the subscription is set to cancel
* immediately, pending prorations are removed.
*
*
By default, upon subscription cancellation, Stripe stops automatic collection of all
* finalized invoices for the customer. This is intended to prevent unexpected payment attempts
* after the customer has canceled a subscription. However, you can resume automatic collection of
* the invoices manually after subscription cancellation to have us proceed. Or, you could check
* for unpaid invoices before allowing the customer to cancel the subscription at all.
*/
public Subscription cancel() throws StripeException {
return cancel((Map) null, (RequestOptions) null);
}
/**
* Cancels a customer’s subscription immediately. The customer won’t be charged again for the
* subscription. After it’s canceled, you can no longer update the subscription or its metadata.
*
* Any pending invoice items that you’ve created are still charged at the end of the period,
* unless manually deleted. If you’ve
* set the subscription to cancel at the end of the period, any pending prorations are also left
* in place and collected at the end of the period. But if the subscription is set to cancel
* immediately, pending prorations are removed.
*
*
By default, upon subscription cancellation, Stripe stops automatic collection of all
* finalized invoices for the customer. This is intended to prevent unexpected payment attempts
* after the customer has canceled a subscription. However, you can resume automatic collection of
* the invoices manually after subscription cancellation to have us proceed. Or, you could check
* for unpaid invoices before allowing the customer to cancel the subscription at all.
*/
public Subscription cancel(Map params) throws StripeException {
return cancel(params, (RequestOptions) null);
}
/**
* Cancels a customer’s subscription immediately. The customer won’t be charged again for the
* subscription. After it’s canceled, you can no longer update the subscription or its metadata.
*
* Any pending invoice items that you’ve created are still charged at the end of the period,
* unless manually deleted. If you’ve
* set the subscription to cancel at the end of the period, any pending prorations are also left
* in place and collected at the end of the period. But if the subscription is set to cancel
* immediately, pending prorations are removed.
*
*
By default, upon subscription cancellation, Stripe stops automatic collection of all
* finalized invoices for the customer. This is intended to prevent unexpected payment attempts
* after the customer has canceled a subscription. However, you can resume automatic collection of
* the invoices manually after subscription cancellation to have us proceed. Or, you could check
* for unpaid invoices before allowing the customer to cancel the subscription at all.
*/
public Subscription cancel(Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscriptions/%s", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.DELETE, path, params, options);
return getResponseGetter().request(request, Subscription.class);
}
/**
* Cancels a customer’s subscription immediately. The customer won’t be charged again for the
* subscription. After it’s canceled, you can no longer update the subscription or its metadata.
*
* Any pending invoice items that you’ve created are still charged at the end of the period,
* unless manually deleted. If you’ve
* set the subscription to cancel at the end of the period, any pending prorations are also left
* in place and collected at the end of the period. But if the subscription is set to cancel
* immediately, pending prorations are removed.
*
*
By default, upon subscription cancellation, Stripe stops automatic collection of all
* finalized invoices for the customer. This is intended to prevent unexpected payment attempts
* after the customer has canceled a subscription. However, you can resume automatic collection of
* the invoices manually after subscription cancellation to have us proceed. Or, you could check
* for unpaid invoices before allowing the customer to cancel the subscription at all.
*/
public Subscription cancel(SubscriptionCancelParams params) throws StripeException {
return cancel(params, (RequestOptions) null);
}
/**
* Cancels a customer’s subscription immediately. The customer won’t be charged again for the
* subscription. After it’s canceled, you can no longer update the subscription or its metadata.
*
*
Any pending invoice items that you’ve created are still charged at the end of the period,
* unless manually deleted. If you’ve
* set the subscription to cancel at the end of the period, any pending prorations are also left
* in place and collected at the end of the period. But if the subscription is set to cancel
* immediately, pending prorations are removed.
*
*
By default, upon subscription cancellation, Stripe stops automatic collection of all
* finalized invoices for the customer. This is intended to prevent unexpected payment attempts
* after the customer has canceled a subscription. However, you can resume automatic collection of
* the invoices manually after subscription cancellation to have us proceed. Or, you could check
* for unpaid invoices before allowing the customer to cancel the subscription at all.
*/
public Subscription cancel(SubscriptionCancelParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscriptions/%s", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.DELETE,
path,
ApiRequestParams.paramsToMap(params),
options);
return getResponseGetter().request(request, Subscription.class);
}
/**
* Creates a new subscription on an existing customer. Each customer can have up to 500 active or
* scheduled subscriptions.
*
*
When you create a subscription with {@code collection_method=charge_automatically}, the
* first invoice is finalized as part of the request. The {@code payment_behavior} parameter
* determines the exact behavior of the initial payment.
*
*
To start subscriptions where the first invoice always begins in a {@code draft} status, use
* subscription
* schedules instead. Schedules provide the flexibility to model more complex billing
* configurations that change over time.
*/
public static Subscription create(Map params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a new subscription on an existing customer. Each customer can have up to 500 active or
* scheduled subscriptions.
*
* When you create a subscription with {@code collection_method=charge_automatically}, the
* first invoice is finalized as part of the request. The {@code payment_behavior} parameter
* determines the exact behavior of the initial payment.
*
*
To start subscriptions where the first invoice always begins in a {@code draft} status, use
* subscription
* schedules instead. Schedules provide the flexibility to model more complex billing
* configurations that change over time.
*/
public static Subscription create(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/subscriptions";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getGlobalResponseGetter().request(request, Subscription.class);
}
/**
* Creates a new subscription on an existing customer. Each customer can have up to 500 active or
* scheduled subscriptions.
*
* When you create a subscription with {@code collection_method=charge_automatically}, the
* first invoice is finalized as part of the request. The {@code payment_behavior} parameter
* determines the exact behavior of the initial payment.
*
*
To start subscriptions where the first invoice always begins in a {@code draft} status, use
* subscription
* schedules instead. Schedules provide the flexibility to model more complex billing
* configurations that change over time.
*/
public static Subscription create(SubscriptionCreateParams params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a new subscription on an existing customer. Each customer can have up to 500 active or
* scheduled subscriptions.
*
*
When you create a subscription with {@code collection_method=charge_automatically}, the
* first invoice is finalized as part of the request. The {@code payment_behavior} parameter
* determines the exact behavior of the initial payment.
*
*
To start subscriptions where the first invoice always begins in a {@code draft} status, use
* subscription
* schedules instead. Schedules provide the flexibility to model more complex billing
* configurations that change over time.
*/
public static Subscription create(SubscriptionCreateParams params, RequestOptions options)
throws StripeException {
String path = "/v1/subscriptions";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, Subscription.class);
}
/** Removes the currently applied discount on a subscription. */
public Discount deleteDiscount() throws StripeException {
return deleteDiscount((Map) null, (RequestOptions) null);
}
/** Removes the currently applied discount on a subscription. */
public Discount deleteDiscount(Map params) throws StripeException {
return deleteDiscount(params, (RequestOptions) null);
}
/** Removes the currently applied discount on a subscription. */
public Discount deleteDiscount(Map params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscriptions/%s/discount", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.DELETE, path, params, options);
return getResponseGetter().request(request, Discount.class);
}
/**
* By default, returns a list of subscriptions that have not been canceled. In order to list
* canceled subscriptions, specify {@code status=canceled}.
*/
public static SubscriptionCollection list(Map params) throws StripeException {
return list(params, (RequestOptions) null);
}
/**
* By default, returns a list of subscriptions that have not been canceled. In order to list
* canceled subscriptions, specify {@code status=canceled}.
*/
public static SubscriptionCollection list(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/subscriptions";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, SubscriptionCollection.class);
}
/**
* By default, returns a list of subscriptions that have not been canceled. In order to list
* canceled subscriptions, specify {@code status=canceled}.
*/
public static SubscriptionCollection list(SubscriptionListParams params) throws StripeException {
return list(params, (RequestOptions) null);
}
/**
* By default, returns a list of subscriptions that have not been canceled. In order to list
* canceled subscriptions, specify {@code status=canceled}.
*/
public static SubscriptionCollection list(SubscriptionListParams params, RequestOptions options)
throws StripeException {
String path = "/v1/subscriptions";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, SubscriptionCollection.class);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume() throws StripeException {
return resume((Map) null, (RequestOptions) null);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume(RequestOptions options) throws StripeException {
return resume((Map) null, options);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume(Map params) throws StripeException {
return resume(params, (RequestOptions) null);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume(Map params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscriptions/%s/resume", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, Subscription.class);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume(SubscriptionResumeParams params) throws StripeException {
return resume(params, (RequestOptions) null);
}
/**
* Initiates resumption of a paused subscription, optionally resetting the billing cycle anchor
* and creating prorations. If a resumption invoice is generated, it must be paid or marked
* uncollectible before the subscription will be unpaused. If payment succeeds the subscription
* will become {@code active}, and if payment fails the subscription will be {@code past_due}. The
* resumption invoice will void automatically if not paid by the expiration date.
*/
public Subscription resume(SubscriptionResumeParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscriptions/%s/resume", 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, Subscription.class);
}
/** Retrieves the subscription with the given ID. */
public static Subscription retrieve(String subscriptionExposedId) throws StripeException {
return retrieve(subscriptionExposedId, (Map) null, (RequestOptions) null);
}
/** Retrieves the subscription with the given ID. */
public static Subscription retrieve(String subscriptionExposedId, RequestOptions options)
throws StripeException {
return retrieve(subscriptionExposedId, (Map) null, options);
}
/** Retrieves the subscription with the given ID. */
public static Subscription retrieve(
String subscriptionExposedId, Map params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscriptions/%s", ApiResource.urlEncodeId(subscriptionExposedId));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, Subscription.class);
}
/** Retrieves the subscription with the given ID. */
public static Subscription retrieve(
String subscriptionExposedId, SubscriptionRetrieveParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscriptions/%s", ApiResource.urlEncodeId(subscriptionExposedId));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, Subscription.class);
}
/**
* Search for subscriptions 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 SubscriptionSearchResult search(Map params) throws StripeException {
return search(params, (RequestOptions) null);
}
/**
* Search for subscriptions 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 SubscriptionSearchResult search(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/subscriptions/search";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, SubscriptionSearchResult.class);
}
/**
* Search for subscriptions 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 SubscriptionSearchResult search(SubscriptionSearchParams params)
throws StripeException {
return search(params, (RequestOptions) null);
}
/**
* Search for subscriptions 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 SubscriptionSearchResult search(
SubscriptionSearchParams params, RequestOptions options) throws StripeException {
String path = "/v1/subscriptions/search";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, SubscriptionSearchResult.class);
}
/**
* Updates an existing subscription to match the specified parameters. When changing prices or
* quantities, we optionally prorate the price we charge next month to make up for any price
* changes. To preview how the proration is calculated, use the create preview endpoint.
*
* By default, we prorate subscription changes. For example, if a customer signs up on May 1
* for a 100 price, they’ll be billed 100 immediately. If on May 15 they switch to a 200 price,
* then on June 1 they’ll be billed 250 (200 for a renewal of her subscription, plus a 50
* prorating adjustment for half of the previous month’s 100 difference). Similarly, a downgrade
* generates a credit that is applied to the next invoice. We also prorate when you make quantity
* changes.
*
*
Switching prices does not normally change the billing date or generate an immediate charge
* unless:
*
*
*
*
* - The billing interval is changed (for example, from monthly to yearly).
*
- The subscription moves from free to paid.
*
- A trial starts or ends.
*
*
* In these cases, we apply a credit for the unused time on the previous price, immediately
* charge the customer using the new price, and reset the billing date. Learn about how Stripe
* immediately attempts payment for subscription changes.
*
*
If you want to charge for an upgrade immediately, pass {@code proration_behavior} as {@code
* always_invoice} to create prorations, automatically invoice the customer for those proration
* adjustments, and attempt to collect payment. If you pass {@code create_prorations}, the
* prorations are created but not automatically invoiced. If you want to bill the customer for the
* prorations before the subscription’s renewal date, you need to manually invoice the customer.
*
*
If you don’t want to prorate, set the {@code proration_behavior} option to {@code none}.
* With this option, the customer is billed 100 on May 1 and 200 on June 1. Similarly, if you set
* {@code proration_behavior} to {@code none} when switching between different billing intervals
* (for example, from monthly to yearly), we don’t generate any credits for the old subscription’s
* unused time. We still reset the billing date and bill immediately for the new subscription.
*
*
Updating the quantity on a subscription many times in an hour may result in rate limiting. If you need to bill for a
* frequently changing quantity, consider integrating usage-based billing
* instead.
*/
@Override
public Subscription update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates an existing subscription to match the specified parameters. When changing prices or
* quantities, we optionally prorate the price we charge next month to make up for any price
* changes. To preview how the proration is calculated, use the create preview endpoint.
*
* By default, we prorate subscription changes. For example, if a customer signs up on May 1
* for a 100 price, they’ll be billed 100 immediately. If on May 15 they switch to a 200 price,
* then on June 1 they’ll be billed 250 (200 for a renewal of her subscription, plus a 50
* prorating adjustment for half of the previous month’s 100 difference). Similarly, a downgrade
* generates a credit that is applied to the next invoice. We also prorate when you make quantity
* changes.
*
*
Switching prices does not normally change the billing date or generate an immediate charge
* unless:
*
*
*
*
* - The billing interval is changed (for example, from monthly to yearly).
*
- The subscription moves from free to paid.
*
- A trial starts or ends.
*
*
* In these cases, we apply a credit for the unused time on the previous price, immediately
* charge the customer using the new price, and reset the billing date. Learn about how Stripe
* immediately attempts payment for subscription changes.
*
*
If you want to charge for an upgrade immediately, pass {@code proration_behavior} as {@code
* always_invoice} to create prorations, automatically invoice the customer for those proration
* adjustments, and attempt to collect payment. If you pass {@code create_prorations}, the
* prorations are created but not automatically invoiced. If you want to bill the customer for the
* prorations before the subscription’s renewal date, you need to manually invoice the customer.
*
*
If you don’t want to prorate, set the {@code proration_behavior} option to {@code none}.
* With this option, the customer is billed 100 on May 1 and 200 on June 1. Similarly, if you set
* {@code proration_behavior} to {@code none} when switching between different billing intervals
* (for example, from monthly to yearly), we don’t generate any credits for the old subscription’s
* unused time. We still reset the billing date and bill immediately for the new subscription.
*
*
Updating the quantity on a subscription many times in an hour may result in rate limiting. If you need to bill for a
* frequently changing quantity, consider integrating usage-based billing
* instead.
*/
@Override
public Subscription update(Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscriptions/%s", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, Subscription.class);
}
/**
* Updates an existing subscription to match the specified parameters. When changing prices or
* quantities, we optionally prorate the price we charge next month to make up for any price
* changes. To preview how the proration is calculated, use the create preview endpoint.
*
* By default, we prorate subscription changes. For example, if a customer signs up on May 1
* for a 100 price, they’ll be billed 100 immediately. If on May 15 they switch to a 200 price,
* then on June 1 they’ll be billed 250 (200 for a renewal of her subscription, plus a 50
* prorating adjustment for half of the previous month’s 100 difference). Similarly, a downgrade
* generates a credit that is applied to the next invoice. We also prorate when you make quantity
* changes.
*
*
Switching prices does not normally change the billing date or generate an immediate charge
* unless:
*
*
*
*
* - The billing interval is changed (for example, from monthly to yearly).
*
- The subscription moves from free to paid.
*
- A trial starts or ends.
*
*
* In these cases, we apply a credit for the unused time on the previous price, immediately
* charge the customer using the new price, and reset the billing date. Learn about how Stripe
* immediately attempts payment for subscription changes.
*
*
If you want to charge for an upgrade immediately, pass {@code proration_behavior} as {@code
* always_invoice} to create prorations, automatically invoice the customer for those proration
* adjustments, and attempt to collect payment. If you pass {@code create_prorations}, the
* prorations are created but not automatically invoiced. If you want to bill the customer for the
* prorations before the subscription’s renewal date, you need to manually invoice the customer.
*
*
If you don’t want to prorate, set the {@code proration_behavior} option to {@code none}.
* With this option, the customer is billed 100 on May 1 and 200 on June 1. Similarly, if you set
* {@code proration_behavior} to {@code none} when switching between different billing intervals
* (for example, from monthly to yearly), we don’t generate any credits for the old subscription’s
* unused time. We still reset the billing date and bill immediately for the new subscription.
*
*
Updating the quantity on a subscription many times in an hour may result in rate limiting. If you need to bill for a
* frequently changing quantity, consider integrating usage-based billing
* instead.
*/
public Subscription update(SubscriptionUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates an existing subscription to match the specified parameters. When changing prices or
* quantities, we optionally prorate the price we charge next month to make up for any price
* changes. To preview how the proration is calculated, use the create preview endpoint.
*
*
By default, we prorate subscription changes. For example, if a customer signs up on May 1
* for a 100 price, they’ll be billed 100 immediately. If on May 15 they switch to a 200 price,
* then on June 1 they’ll be billed 250 (200 for a renewal of her subscription, plus a 50
* prorating adjustment for half of the previous month’s 100 difference). Similarly, a downgrade
* generates a credit that is applied to the next invoice. We also prorate when you make quantity
* changes.
*
*
Switching prices does not normally change the billing date or generate an immediate charge
* unless:
*
*
*
*
* - The billing interval is changed (for example, from monthly to yearly).
*
- The subscription moves from free to paid.
*
- A trial starts or ends.
*
*
* In these cases, we apply a credit for the unused time on the previous price, immediately
* charge the customer using the new price, and reset the billing date. Learn about how Stripe
* immediately attempts payment for subscription changes.
*
*
If you want to charge for an upgrade immediately, pass {@code proration_behavior} as {@code
* always_invoice} to create prorations, automatically invoice the customer for those proration
* adjustments, and attempt to collect payment. If you pass {@code create_prorations}, the
* prorations are created but not automatically invoiced. If you want to bill the customer for the
* prorations before the subscription’s renewal date, you need to manually invoice the customer.
*
*
If you don’t want to prorate, set the {@code proration_behavior} option to {@code none}.
* With this option, the customer is billed 100 on May 1 and 200 on June 1. Similarly, if you set
* {@code proration_behavior} to {@code none} when switching between different billing intervals
* (for example, from monthly to yearly), we don’t generate any credits for the old subscription’s
* unused time. We still reset the billing date and bill immediately for the new subscription.
*
*
Updating the quantity on a subscription many times in an hour may result in rate limiting. If you need to bill for a
* frequently changing quantity, consider integrating usage-based billing
* instead.
*/
public Subscription update(SubscriptionUpdateParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscriptions/%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, Subscription.class);
}
/**
* For more details about AutomaticTax, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AutomaticTax extends StripeObject {
/** Whether Stripe automatically computes tax on this subscription. */
@SerializedName("enabled")
Boolean enabled;
/**
* The account that's liable for tax. If set, the business address and tax registrations
* required to perform the tax calculation are loaded from this account. The tax transaction is
* returned in the report of the connected account.
*/
@SerializedName("liability")
Liability liability;
/**
* For more details about Liability, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Liability extends StripeObject {
/** The connected account being referenced when {@code type} is {@code account}. */
@SerializedName("account")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField account;
/**
* Type of the account referenced.
*
* One of {@code account}, or {@code self}.
*/
@SerializedName("type")
String type;
/** Get ID of expandable {@code account} object. */
public String getAccount() {
return (this.account != null) ? this.account.getId() : null;
}
public void setAccount(String id) {
this.account = ApiResource.setExpandableFieldId(id, this.account);
}
/** Get expanded {@code account}. */
public Account getAccountObject() {
return (this.account != null) ? this.account.getExpanded() : null;
}
public void setAccountObject(Account expandableObject) {
this.account = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
}
/**
* For more details about BillingCycleAnchorConfig, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class BillingCycleAnchorConfig extends StripeObject {
/** The day of the month of the billing_cycle_anchor. */
@SerializedName("day_of_month")
Long dayOfMonth;
/** The hour of the day of the billing_cycle_anchor. */
@SerializedName("hour")
Long hour;
/** The minute of the hour of the billing_cycle_anchor. */
@SerializedName("minute")
Long minute;
/** The month to start full cycle billing periods. */
@SerializedName("month")
Long month;
/** The second of the minute of the billing_cycle_anchor. */
@SerializedName("second")
Long second;
}
/**
* For more details about BillingThresholds, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class BillingThresholds extends StripeObject {
/** Monetary threshold that triggers the subscription to create an invoice. */
@SerializedName("amount_gte")
Long amountGte;
/**
* Indicates if the {@code billing_cycle_anchor} should be reset when a threshold is reached. If
* true, {@code billing_cycle_anchor} will be updated to the date/time the threshold was last
* reached; otherwise, the value will remain unchanged. This value may not be {@code true} if
* the subscription contains items with plans that have {@code aggregate_usage=last_ever}.
*/
@SerializedName("reset_billing_cycle_anchor")
Boolean resetBillingCycleAnchor;
}
/**
* For more details about CancellationDetails, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class CancellationDetails extends StripeObject {
/**
* Additional comments about why the user canceled the subscription, if the subscription was
* canceled explicitly by the user.
*/
@SerializedName("comment")
String comment;
/**
* The customer submitted reason for why they canceled, if the subscription was canceled
* explicitly by the user.
*
* One of {@code customer_service}, {@code low_quality}, {@code missing_features}, {@code
* other}, {@code switched_service}, {@code too_complex}, {@code too_expensive}, or {@code
* unused}.
*/
@SerializedName("feedback")
String feedback;
/**
* Why this subscription was canceled.
*
*
One of {@code cancellation_requested}, {@code payment_disputed}, or {@code
* payment_failed}.
*/
@SerializedName("reason")
String reason;
}
/**
* For more details about InvoiceSettings, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class InvoiceSettings extends StripeObject {
/**
* The account tax IDs associated with the subscription. Will be set on invoices generated by
* the subscription.
*/
@SerializedName("account_tax_ids")
List> accountTaxIds;
@SerializedName("issuer")
Issuer issuer;
/** Get IDs of expandable {@code accountTaxIds} object list. */
public List getAccountTaxIds() {
return (this.accountTaxIds != null)
? this.accountTaxIds.stream().map(x -> x.getId()).collect(Collectors.toList())
: null;
}
public void setAccountTaxIds(List ids) {
if (ids == null) {
this.accountTaxIds = null;
return;
}
if (this.accountTaxIds != null
&& this.accountTaxIds.stream()
.map(x -> x.getId())
.collect(Collectors.toList())
.equals(ids)) {
// noop if the ids are equal to what are already present
return;
}
this.accountTaxIds =
(ids != null)
? ids.stream()
.map(id -> new ExpandableField(id, null))
.collect(Collectors.toList())
: null;
}
/** Get expanded {@code accountTaxIds}. */
public List getAccountTaxIdObjects() {
return (this.accountTaxIds != null)
? this.accountTaxIds.stream().map(x -> x.getExpanded()).collect(Collectors.toList())
: null;
}
public void setAccountTaxIdObjects(List objs) {
this.accountTaxIds =
objs != null
? objs.stream()
.map(x -> new ExpandableField(x.getId(), x))
.collect(Collectors.toList())
: null;
}
/**
* For more details about Issuer, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Issuer extends StripeObject {
/** The connected account being referenced when {@code type} is {@code account}. */
@SerializedName("account")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField account;
/**
* Type of the account referenced.
*
* One of {@code account}, or {@code self}.
*/
@SerializedName("type")
String type;
/** Get ID of expandable {@code account} object. */
public String getAccount() {
return (this.account != null) ? this.account.getId() : null;
}
public void setAccount(String id) {
this.account = ApiResource.setExpandableFieldId(id, this.account);
}
/** Get expanded {@code account}. */
public Account getAccountObject() {
return (this.account != null) ? this.account.getExpanded() : null;
}
public void setAccountObject(Account expandableObject) {
this.account = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
}
/**
* For more details about LastPriceMigrationError, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class LastPriceMigrationError extends StripeObject {
/** The time at which the price migration encountered an error. */
@SerializedName("errored_at")
Long erroredAt;
/** The involved price pairs in each failed transition. */
@SerializedName("failed_transitions")
List failedTransitions;
/**
* The type of error encountered by the price migration.
*
* Equal to {@code price_uniqueness_violation}.
*/
@SerializedName("type")
String type;
/**
* For more details about FailedTransition, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class FailedTransition extends StripeObject {
/** The original price to be migrated. */
@SerializedName("source_price")
String sourcePrice;
/** The intended resulting price of the migration. */
@SerializedName("target_price")
String targetPrice;
}
}
/**
* The Pause Collection settings determine how we will pause collection for this subscription and
* for how long the subscription should be paused.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PauseCollection extends StripeObject {
/**
* The payment collection behavior for this subscription while paused. One of {@code
* keep_as_draft}, {@code mark_uncollectible}, or {@code void}.
*/
@SerializedName("behavior")
String behavior;
/** The time after which the subscription will resume collecting payments. */
@SerializedName("resumes_at")
Long resumesAt;
}
/**
* For more details about PaymentSettings, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PaymentSettings extends StripeObject {
/** Payment-method-specific configuration to provide to invoices created by the subscription. */
@SerializedName("payment_method_options")
PaymentMethodOptions paymentMethodOptions;
/**
* The list of payment method types to provide to every invoice created by the subscription. If
* not set, Stripe attempts to automatically determine the types to use by looking at the
* invoice’s default payment method, the subscription’s default payment method, the customer’s
* default payment method, and your invoice template settings.
*/
@SerializedName("payment_method_types")
List paymentMethodTypes;
/**
* Configure whether Stripe updates {@code subscription.default_payment_method} when payment
* succeeds. Defaults to {@code off}.
*
* One of {@code off}, or {@code on_subscription}.
*/
@SerializedName("save_default_payment_method")
String saveDefaultPaymentMethod;
/**
* For more details about PaymentMethodOptions, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PaymentMethodOptions extends StripeObject {
/**
* This sub-hash contains details about the Canadian pre-authorized debit payment method
* options to pass to invoices created by the subscription.
*/
@SerializedName("acss_debit")
AcssDebit acssDebit;
/**
* This sub-hash contains details about the Bancontact payment method options to pass to
* invoices created by the subscription.
*/
@SerializedName("bancontact")
Bancontact bancontact;
/**
* This sub-hash contains details about the Card payment method options to pass to invoices
* created by the subscription.
*/
@SerializedName("card")
Card card;
/**
* This sub-hash contains details about the Bank transfer payment method options to pass to
* invoices created by the subscription.
*/
@SerializedName("customer_balance")
CustomerBalance customerBalance;
/**
* This sub-hash contains details about the Indonesia bank transfer payment method options to
* pass to invoices created by the subscription.
*/
@SerializedName("id_bank_transfer")
IdBankTransfer idBankTransfer;
/**
* This sub-hash contains details about the Konbini payment method options to pass to invoices
* created by the subscription.
*/
@SerializedName("konbini")
Konbini konbini;
/**
* This sub-hash contains details about the SEPA Direct Debit payment method options to pass
* to invoices created by the subscription.
*/
@SerializedName("sepa_debit")
SepaDebit sepaDebit;
/**
* This sub-hash contains details about the ACH direct debit payment method options to pass to
* invoices created by the subscription.
*/
@SerializedName("us_bank_account")
UsBankAccount usBankAccount;
/**
* For more details about AcssDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AcssDebit extends StripeObject {
@SerializedName("mandate_options")
MandateOptions mandateOptions;
/**
* Bank account verification method.
*
*
One of {@code automatic}, {@code instant}, or {@code microdeposits}.
*/
@SerializedName("verification_method")
String verificationMethod;
/**
* For more details about MandateOptions, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class MandateOptions extends StripeObject {
/**
* Transaction type of the mandate.
*
*
One of {@code business}, or {@code personal}.
*/
@SerializedName("transaction_type")
String transactionType;
}
}
/**
* For more details about Bancontact, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Bancontact extends StripeObject {
/**
* Preferred language of the Bancontact authorization page that the customer is redirected
* to.
*
*
One of {@code de}, {@code en}, {@code fr}, or {@code nl}.
*/
@SerializedName("preferred_language")
String preferredLanguage;
}
/**
* For more details about Card, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Card extends StripeObject {
@SerializedName("mandate_options")
MandateOptions mandateOptions;
/**
* Selected network to process this Subscription on. Depends on the available networks of
* the card attached to the Subscription. Can be only set confirm-time.
*/
@SerializedName("network")
String network;
/**
* We strongly recommend that you rely on our SCA Engine to automatically prompt your
* customers for authentication based on risk level and other requirements.
* However, if you wish to request 3D Secure based on logic from your own fraud engine,
* provide this option. Read our guide on manually
* requesting 3D Secure for more information on how this configuration interacts with
* Radar and our SCA Engine.
*
*
One of {@code any}, {@code automatic}, or {@code challenge}.
*/
@SerializedName("request_three_d_secure")
String requestThreeDSecure;
/**
* For more details about MandateOptions, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class MandateOptions extends StripeObject {
/** Amount to be charged for future payments. */
@SerializedName("amount")
Long amount;
/**
* One of {@code fixed} or {@code maximum}. If {@code fixed}, the {@code amount} param
* refers to the exact amount to be charged in future payments. If {@code maximum}, the
* amount charged can be up to the value passed for the {@code amount} param.
*/
@SerializedName("amount_type")
String amountType;
/**
* A description of the mandate or subscription that is meant to be displayed to the
* customer.
*/
@SerializedName("description")
String description;
}
}
/**
* For more details about CustomerBalance, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class CustomerBalance extends StripeObject {
@SerializedName("bank_transfer")
BankTransfer bankTransfer;
/**
* The funding method type to be used when there are not enough funds in the customer
* balance. Permitted values include: {@code bank_transfer}.
*
*
Equal to {@code bank_transfer}.
*/
@SerializedName("funding_type")
String fundingType;
/**
* For more details about BankTransfer, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class BankTransfer extends StripeObject {
@SerializedName("eu_bank_transfer")
EuBankTransfer euBankTransfer;
/**
* The bank transfer type that can be used for funding. Permitted values include: {@code
* eu_bank_transfer}, {@code gb_bank_transfer}, {@code jp_bank_transfer}, {@code
* mx_bank_transfer}, or {@code us_bank_transfer}.
*/
@SerializedName("type")
String type;
/**
* For more details about EuBankTransfer, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class EuBankTransfer extends StripeObject {
/**
* The desired country code of the bank account information. Permitted values include:
* {@code BE}, {@code DE}, {@code ES}, {@code FR}, {@code IE}, or {@code NL}.
*
*
One of {@code BE}, {@code DE}, {@code ES}, {@code FR}, {@code IE}, or {@code NL}.
*/
@SerializedName("country")
String country;
}
}
}
/**
* For more details about IdBankTransfer, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class IdBankTransfer extends StripeObject {}
/**
* For more details about Konbini, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Konbini extends StripeObject {}
/**
* For more details about SepaDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class SepaDebit extends StripeObject {}
/**
* For more details about UsBankAccount, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class UsBankAccount extends StripeObject {
@SerializedName("financial_connections")
FinancialConnections financialConnections;
/**
* Bank account verification method.
*
*
One of {@code automatic}, {@code instant}, or {@code microdeposits}.
*/
@SerializedName("verification_method")
String verificationMethod;
/**
* For more details about FinancialConnections, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class FinancialConnections extends StripeObject {
@SerializedName("filters")
Filters filters;
/**
* The list of permissions to request. The {@code payment_method} permission must be
* included.
*/
@SerializedName("permissions")
List permissions;
/** Data features requested to be retrieved upon account creation. */
@SerializedName("prefetch")
List prefetch;
/**
* For more details about Filters, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Filters extends StripeObject {
/**
* The account subcategories to use to filter for possible accounts to link. Valid
* subcategories are {@code checking} and {@code savings}.
*/
@SerializedName("account_subcategories")
List accountSubcategories;
/** The institution to use to filter for possible accounts to link. */
@SerializedName("institution")
String institution;
}
}
}
}
}
/**
* For more details about PendingInvoiceItemInterval, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PendingInvoiceItemInterval extends StripeObject {
/**
* Specifies invoicing frequency. Either {@code day}, {@code week}, {@code month} or {@code
* year}.
*
* One of {@code day}, {@code month}, {@code week}, or {@code year}.
*/
@SerializedName("interval")
String interval;
/**
* The number of intervals between invoices. For example, {@code interval=month} and {@code
* interval_count=3} bills every 3 months. Maximum of one year interval allowed (1 year, 12
* months, or 52 weeks).
*/
@SerializedName("interval_count")
Long intervalCount;
}
/**
* Pending Updates store the changes pending from a previous update that will be applied to the
* Subscription upon successful payment.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PendingUpdate extends StripeObject {
/**
* If the update is applied, determines the date of the first full invoice, and, for plans with
* {@code month} or {@code year} intervals, the day of the month for subsequent invoices. The
* timestamp is in UTC format.
*/
@SerializedName("billing_cycle_anchor")
Long billingCycleAnchor;
/**
* The point after which the changes reflected by this update will be discarded and no longer
* applied.
*/
@SerializedName("expires_at")
Long expiresAt;
/** The number of iterations of prebilling to apply. */
@SerializedName("prebilling_iterations")
Long prebillingIterations;
/**
* List of subscription items, each with an attached plan, that will be set if the update is
* applied.
*/
@SerializedName("subscription_items")
List subscriptionItems;
/**
* Unix timestamp representing the end of the trial period the customer will get before being
* charged for the first time, if the update is applied.
*/
@SerializedName("trial_end")
Long trialEnd;
/**
* Indicates if a plan's {@code trial_period_days} should be applied to the subscription.
* Setting {@code trial_end} per subscription is preferred, and this defaults to {@code false}.
* Setting this flag to {@code true} together with {@code trial_end} is not allowed. See Using trial periods on
* subscriptions to learn more.
*/
@SerializedName("trial_from_plan")
Boolean trialFromPlan;
}
/** Prebilling stores the time period and invoice for a Subscription billed in advance. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Prebilling extends StripeObject {
/** ID of the prebilling invoice. */
@SerializedName("invoice")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField invoice;
/** The end of the last period for which the invoice pre-bills. */
@SerializedName("period_end")
Long periodEnd;
/** The start of the first period for which the invoice pre-bills. */
@SerializedName("period_start")
Long periodStart;
/**
* Whether to cancel or preserve {@code prebilling} if the subscription is updated during the
* prebilled period.
*
* One of {@code prebill}, or {@code reset}.
*/
@SerializedName("update_behavior")
String updateBehavior;
/** Get ID of expandable {@code invoice} object. */
public String getInvoice() {
return (this.invoice != null) ? this.invoice.getId() : null;
}
public void setInvoice(String id) {
this.invoice = ApiResource.setExpandableFieldId(id, this.invoice);
}
/** Get expanded {@code invoice}. */
public Invoice getInvoiceObject() {
return (this.invoice != null) ? this.invoice.getExpanded() : null;
}
public void setInvoiceObject(Invoice expandableObject) {
this.invoice = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
/**
* For more details about TransferData, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class TransferData extends StripeObject {
/**
* A non-negative decimal between 0 and 100, with at most two decimal places. This represents
* the percentage of the subscription invoice total that will be transferred to the destination
* account. By default, the entire amount is transferred to the destination.
*/
@SerializedName("amount_percent")
BigDecimal amountPercent;
/** The account where funds from the payment will be transferred to upon payment success. */
@SerializedName("destination")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField destination;
/** Get ID of expandable {@code destination} object. */
public String getDestination() {
return (this.destination != null) ? this.destination.getId() : null;
}
public void setDestination(String id) {
this.destination = ApiResource.setExpandableFieldId(id, this.destination);
}
/** Get expanded {@code destination}. */
public Account getDestinationObject() {
return (this.destination != null) ? this.destination.getExpanded() : null;
}
public void setDestinationObject(Account expandableObject) {
this.destination = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
/** Configures how this subscription behaves during the trial period. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class TrialSettings extends StripeObject {
/** Defines how a subscription behaves when a free trial ends. */
@SerializedName("end_behavior")
EndBehavior endBehavior;
/** Defines how a subscription behaves when a free trial ends. */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class EndBehavior extends StripeObject {
/**
* Indicates how the subscription should change when the trial ends if the user did not
* provide a payment method.
*
* One of {@code cancel}, {@code create_invoice}, or {@code pause}.
*/
@SerializedName("missing_payment_method")
String missingPaymentMethod;
}
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(application, responseGetter);
trySetResponseGetter(automaticTax, responseGetter);
trySetResponseGetter(billingCycleAnchorConfig, responseGetter);
trySetResponseGetter(billingThresholds, responseGetter);
trySetResponseGetter(cancellationDetails, responseGetter);
trySetResponseGetter(customer, responseGetter);
trySetResponseGetter(defaultPaymentMethod, responseGetter);
trySetResponseGetter(defaultSource, responseGetter);
trySetResponseGetter(discount, responseGetter);
trySetResponseGetter(invoiceSettings, responseGetter);
trySetResponseGetter(items, responseGetter);
trySetResponseGetter(lastPriceMigrationError, responseGetter);
trySetResponseGetter(latestInvoice, responseGetter);
trySetResponseGetter(onBehalfOf, responseGetter);
trySetResponseGetter(pauseCollection, responseGetter);
trySetResponseGetter(paymentSettings, responseGetter);
trySetResponseGetter(pendingInvoiceItemInterval, responseGetter);
trySetResponseGetter(pendingSetupIntent, responseGetter);
trySetResponseGetter(pendingUpdate, responseGetter);
trySetResponseGetter(prebilling, responseGetter);
trySetResponseGetter(schedule, responseGetter);
trySetResponseGetter(testClock, responseGetter);
trySetResponseGetter(transferData, responseGetter);
trySetResponseGetter(trialSettings, responseGetter);
}
}