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

com.stripe.model.Quote 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.QuoteAcceptParams;
import com.stripe.param.QuoteCancelParams;
import com.stripe.param.QuoteCreateParams;
import com.stripe.param.QuoteFinalizeQuoteParams;
import com.stripe.param.QuoteListComputedUpfrontLineItemsParams;
import com.stripe.param.QuoteListLineItemsParams;
import com.stripe.param.QuoteListLinesParams;
import com.stripe.param.QuoteListParams;
import com.stripe.param.QuoteListPreviewInvoiceLinesParams;
import com.stripe.param.QuoteMarkDraftParams;
import com.stripe.param.QuoteMarkStaleParams;
import com.stripe.param.QuotePdfParams;
import com.stripe.param.QuoteReestimateParams;
import com.stripe.param.QuoteRetrieveParams;
import com.stripe.param.QuoteUpdateParams;
import java.io.InputStream;
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;

/**
 * A Quote is a way to model prices that you'd like to provide to a customer. Once accepted, it will
 * automatically create an invoice, subscription or subscription schedule.
 */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class Quote extends ApiResource implements HasId, MetadataStore {
  /**
   * Allow quote lines to have {@code starts_at} in the past if collection is paused between {@code
   * starts_at} and now.
   */
  @SerializedName("allow_backdated_lines")
  Boolean allowBackdatedLines;

  /** Total before any discounts or taxes are applied. */
  @SerializedName("amount_subtotal")
  Long amountSubtotal;

  /** Total after discounts and taxes are applied. */
  @SerializedName("amount_total")
  Long amountTotal;

  /** ID of the Connect Application that created the quote. */
  @SerializedName("application")
  @Getter(lombok.AccessLevel.NONE)
  @Setter(lombok.AccessLevel.NONE)
  ExpandableField application;

  /**
   * The amount of the application fee (if any) that will be requested to be applied to the payment
   * and transferred to the application owner's Stripe account. Only applicable if there are no line
   * items with recurring prices on the quote.
   */
  @SerializedName("application_fee_amount")
  Long applicationFeeAmount;

  /**
   * 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. Only applicable if there are line items with recurring prices on the
   * quote.
   */
  @SerializedName("application_fee_percent")
  BigDecimal applicationFeePercent;

  @SerializedName("automatic_tax")
  AutomaticTax automaticTax;

  /**
   * Either {@code charge_automatically}, or {@code send_invoice}. When charging automatically,
   * Stripe will attempt to pay invoices at the end of the subscription cycle or on finalization
   * using the default payment method attached to the subscription or customer. When sending an
   * invoice, Stripe will email your customer an invoice with payment instructions and mark the
   * subscription as {@code active}. Defaults to {@code charge_automatically}.
   *
   * 

One of {@code charge_automatically}, or {@code send_invoice}. */ @SerializedName("collection_method") String collectionMethod; @SerializedName("computed") Computed computed; /** 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; /** * The customer which this quote belongs to. A customer is required before finalizing the quote. * Once specified, it cannot be changed. */ @SerializedName("customer") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField customer; /** The tax rates applied to this quote. */ @SerializedName("default_tax_rates") List> defaultTaxRates; /** A description that will be displayed on the quote PDF. */ @SerializedName("description") String description; /** The discounts applied to this quote. */ @SerializedName("discounts") List> discounts; /** * The date on which the quote will be canceled if in {@code open} or {@code draft} status. * Measured in seconds since the Unix epoch. */ @SerializedName("expires_at") Long expiresAt; /** A footer that will be displayed on the quote PDF. */ @SerializedName("footer") String footer; /** * Details of the quote that was cloned. See the cloning documentation for more details. */ @SerializedName("from_quote") FromQuote fromQuote; /** A header that will be displayed on the quote PDF. */ @SerializedName("header") String header; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** The invoice that was created from this quote. */ @SerializedName("invoice") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField invoice; @SerializedName("invoice_settings") InvoiceSettings invoiceSettings; /** A list of items the customer is being quoted for. */ @SerializedName("line_items") LineItemCollection lineItems; /** * A list of quote lines on the quote. These * lines describe changes, in the order provided, that will be used to create new subscription * schedules or update existing subscription schedules when the quote is accepted. */ @SerializedName("lines") List lines; /** * 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; /** * A unique number that identifies this particular quote. This number is assigned once the quote * is finalized. */ @SerializedName("number") String number; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code quote}. */ @SerializedName("object") String object; /** * The account on behalf of which to charge. See the Connect * documentation for details. */ @SerializedName("on_behalf_of") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField onBehalfOf; /** * The status of the quote. * *

One of {@code accepted}, {@code accepting}, {@code canceled}, {@code draft}, {@code open}, * or {@code stale}. */ @SerializedName("status") String status; /** Details on when and why a quote has been marked as stale or canceled. */ @SerializedName("status_details") StatusDetails statusDetails; @SerializedName("status_transitions") StatusTransitions statusTransitions; /** The subscription that was created or updated from this quote. */ @SerializedName("subscription") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField subscription; @SerializedName("subscription_data") SubscriptionData subscriptionData; /** * List representing overrides for {@code subscription_data} configurations for specific * subscription schedules. */ @SerializedName("subscription_data_overrides") List subscriptionDataOverrides; /** The subscription schedule that was created or updated from this quote. */ @SerializedName("subscription_schedule") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField subscriptionSchedule; /** The subscription schedules that were created or updated from this quote. */ @SerializedName("subscription_schedules") List subscriptionSchedules; /** ID of the test clock this quote belongs to. */ @SerializedName("test_clock") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField testClock; @SerializedName("total_details") TotalDetails totalDetails; /** * The account (if any) the payments will be attributed to for tax reporting, and where funds from * each payment will be transferred to for each of the invoices. */ @SerializedName("transfer_data") TransferData transferData; /** 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 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); } /** 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 subscription} object. */ public String getSubscription() { return (this.subscription != null) ? this.subscription.getId() : null; } public void setSubscription(String id) { this.subscription = ApiResource.setExpandableFieldId(id, this.subscription); } /** Get expanded {@code subscription}. */ public Subscription getSubscriptionObject() { return (this.subscription != null) ? this.subscription.getExpanded() : null; } public void setSubscriptionObject(Subscription expandableObject) { this.subscription = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code subscriptionSchedule} object. */ public String getSubscriptionSchedule() { return (this.subscriptionSchedule != null) ? this.subscriptionSchedule.getId() : null; } public void setSubscriptionSchedule(String id) { this.subscriptionSchedule = ApiResource.setExpandableFieldId(id, this.subscriptionSchedule); } /** Get expanded {@code subscriptionSchedule}. */ public com.stripe.model.SubscriptionSchedule getSubscriptionScheduleObject() { return (this.subscriptionSchedule != null) ? this.subscriptionSchedule.getExpanded() : null; } public void setSubscriptionScheduleObject( com.stripe.model.SubscriptionSchedule expandableObject) { this.subscriptionSchedule = 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 defaultTaxRates} object list. */ public List getDefaultTaxRates() { return (this.defaultTaxRates != null) ? this.defaultTaxRates.stream().map(x -> x.getId()).collect(Collectors.toList()) : null; } public void setDefaultTaxRates(List ids) { if (ids == null) { this.defaultTaxRates = null; return; } if (this.defaultTaxRates != null && this.defaultTaxRates.stream() .map(x -> x.getId()) .collect(Collectors.toList()) .equals(ids)) { // noop if the ids are equal to what are already present return; } this.defaultTaxRates = (ids != null) ? ids.stream() .map(id -> new ExpandableField(id, null)) .collect(Collectors.toList()) : null; } /** Get expanded {@code defaultTaxRates}. */ public List getDefaultTaxRateObjects() { return (this.defaultTaxRates != null) ? this.defaultTaxRates.stream().map(x -> x.getExpanded()).collect(Collectors.toList()) : null; } public void setDefaultTaxRateObjects(List objs) { this.defaultTaxRates = objs != null ? objs.stream() .map(x -> new ExpandableField(x.getId(), x)) .collect(Collectors.toList()) : null; } /** 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; } /** Accepts the specified quote. */ public Quote accept() throws StripeException { return accept((Map) null, (RequestOptions) null); } /** Accepts the specified quote. */ public Quote accept(RequestOptions options) throws StripeException { return accept((Map) null, options); } /** Accepts the specified quote. */ public Quote accept(Map params) throws StripeException { return accept(params, (RequestOptions) null); } /** Accepts the specified quote. */ public Quote accept(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/accept", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Accepts the specified quote. */ public Quote accept(QuoteAcceptParams params) throws StripeException { return accept(params, (RequestOptions) null); } /** Accepts the specified quote. */ public Quote accept(QuoteAcceptParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/accept", 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, Quote.class); } /** Cancels the quote. */ public Quote cancel() throws StripeException { return cancel((Map) null, (RequestOptions) null); } /** Cancels the quote. */ public Quote cancel(RequestOptions options) throws StripeException { return cancel((Map) null, options); } /** Cancels the quote. */ public Quote cancel(Map params) throws StripeException { return cancel(params, (RequestOptions) null); } /** Cancels the quote. */ public Quote cancel(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/cancel", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Cancels the quote. */ public Quote cancel(QuoteCancelParams params) throws StripeException { return cancel(params, (RequestOptions) null); } /** Cancels the quote. */ public Quote cancel(QuoteCancelParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/cancel", 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, Quote.class); } /** * A quote models prices and services for a customer. Default options for {@code header}, {@code * description}, {@code footer}, and {@code expires_at} can be set in the dashboard via the quote template. */ public static Quote create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** * A quote models prices and services for a customer. Default options for {@code header}, {@code * description}, {@code footer}, and {@code expires_at} can be set in the dashboard via the quote template. */ public static Quote create(Map params, RequestOptions options) throws StripeException { String path = "/v1/quotes"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Quote.class); } /** * A quote models prices and services for a customer. Default options for {@code header}, {@code * description}, {@code footer}, and {@code expires_at} can be set in the dashboard via the quote template. */ public static Quote create(QuoteCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** * A quote models prices and services for a customer. Default options for {@code header}, {@code * description}, {@code footer}, and {@code expires_at} can be set in the dashboard via the quote template. */ public static Quote create(QuoteCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/quotes"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Quote.class); } /** Finalizes the quote. */ public Quote finalizeQuote() throws StripeException { return finalizeQuote((Map) null, (RequestOptions) null); } /** Finalizes the quote. */ public Quote finalizeQuote(RequestOptions options) throws StripeException { return finalizeQuote((Map) null, options); } /** Finalizes the quote. */ public Quote finalizeQuote(Map params) throws StripeException { return finalizeQuote(params, (RequestOptions) null); } /** Finalizes the quote. */ public Quote finalizeQuote(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/finalize", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Finalizes the quote. */ public Quote finalizeQuote(QuoteFinalizeQuoteParams params) throws StripeException { return finalizeQuote(params, (RequestOptions) null); } /** Finalizes the quote. */ public Quote finalizeQuote(QuoteFinalizeQuoteParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/finalize", 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, Quote.class); } /** Returns a list of your quotes. */ public static QuoteCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of your quotes. */ public static QuoteCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/quotes"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, QuoteCollection.class); } /** Returns a list of your quotes. */ public static QuoteCollection list(QuoteListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of your quotes. */ public static QuoteCollection list(QuoteListParams params, RequestOptions options) throws StripeException { String path = "/v1/quotes"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, QuoteCollection.class); } /** * When retrieving a quote, there is an includable computed.upfront.line_items * property containing the first handful of those items. There is also a URL where you can * retrieve the full (paginated) list of upfront line items. */ public LineItemCollection listComputedUpfrontLineItems() throws StripeException { return listComputedUpfrontLineItems((Map) null, (RequestOptions) null); } /** * When retrieving a quote, there is an includable computed.upfront.line_items * property containing the first handful of those items. There is also a URL where you can * retrieve the full (paginated) list of upfront line items. */ public LineItemCollection listComputedUpfrontLineItems(Map params) throws StripeException { return listComputedUpfrontLineItems(params, (RequestOptions) null); } /** * When retrieving a quote, there is an includable computed.upfront.line_items * property containing the first handful of those items. There is also a URL where you can * retrieve the full (paginated) list of upfront line items. */ public LineItemCollection listComputedUpfrontLineItems( Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/quotes/%s/computed_upfront_line_items", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().request(request, LineItemCollection.class); } /** * When retrieving a quote, there is an includable computed.upfront.line_items * property containing the first handful of those items. There is also a URL where you can * retrieve the full (paginated) list of upfront line items. */ public LineItemCollection listComputedUpfrontLineItems( QuoteListComputedUpfrontLineItemsParams params) throws StripeException { return listComputedUpfrontLineItems(params, (RequestOptions) null); } /** * When retrieving a quote, there is an includable computed.upfront.line_items * property containing the first handful of those items. There is also a URL where you can * retrieve the full (paginated) list of upfront line items. */ public LineItemCollection listComputedUpfrontLineItems( QuoteListComputedUpfrontLineItemsParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/quotes/%s/computed_upfront_line_items", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, LineItemCollection.class); } /** * When retrieving a quote, there is an includable line_items property containing * the first handful of those items. There is also a URL where you can retrieve the full * (paginated) list of line items. */ public LineItemCollection listLineItems() throws StripeException { return listLineItems((Map) null, (RequestOptions) null); } /** * When retrieving a quote, there is an includable line_items property containing * the first handful of those items. There is also a URL where you can retrieve the full * (paginated) list of line items. */ public LineItemCollection listLineItems(Map params) throws StripeException { return listLineItems(params, (RequestOptions) null); } /** * When retrieving a quote, there is an includable line_items property containing * the first handful of those items. There is also a URL where you can retrieve the full * (paginated) list of line items. */ public LineItemCollection listLineItems(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/line_items", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().request(request, LineItemCollection.class); } /** * When retrieving a quote, there is an includable line_items property containing * the first handful of those items. There is also a URL where you can retrieve the full * (paginated) list of line items. */ public LineItemCollection listLineItems(QuoteListLineItemsParams params) throws StripeException { return listLineItems(params, (RequestOptions) null); } /** * When retrieving a quote, there is an includable line_items property containing * the first handful of those items. There is also a URL where you can retrieve the full * (paginated) list of line items. */ public LineItemCollection listLineItems(QuoteListLineItemsParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/line_items", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, LineItemCollection.class); } /** * Retrieves a paginated list of lines for a quote. These lines describe changes that will be used * to create new subscription schedules or update existing subscription schedules when the quote * is accepted. */ public QuoteLineCollection listLines() throws StripeException { return listLines((Map) null, (RequestOptions) null); } /** * Retrieves a paginated list of lines for a quote. These lines describe changes that will be used * to create new subscription schedules or update existing subscription schedules when the quote * is accepted. */ public QuoteLineCollection listLines(Map params) throws StripeException { return listLines(params, (RequestOptions) null); } /** * Retrieves a paginated list of lines for a quote. These lines describe changes that will be used * to create new subscription schedules or update existing subscription schedules when the quote * is accepted. */ public QuoteLineCollection listLines(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/lines", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().request(request, QuoteLineCollection.class); } /** * Retrieves a paginated list of lines for a quote. These lines describe changes that will be used * to create new subscription schedules or update existing subscription schedules when the quote * is accepted. */ public QuoteLineCollection listLines(QuoteListLinesParams params) throws StripeException { return listLines(params, (RequestOptions) null); } /** * Retrieves a paginated list of lines for a quote. These lines describe changes that will be used * to create new subscription schedules or update existing subscription schedules when the quote * is accepted. */ public QuoteLineCollection listLines(QuoteListLinesParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/lines", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, QuoteLineCollection.class); } /** Preview the invoice line items that would be generated by accepting the quote. */ public InvoiceLineItemCollection listPreviewInvoiceLines(String previewInvoice) throws StripeException { return listPreviewInvoiceLines( previewInvoice, (Map) null, (RequestOptions) null); } /** Preview the invoice line items that would be generated by accepting the quote. */ public InvoiceLineItemCollection listPreviewInvoiceLines( String previewInvoice, Map params) throws StripeException { return listPreviewInvoiceLines(previewInvoice, params, (RequestOptions) null); } /** Preview the invoice line items that would be generated by accepting the quote. */ public InvoiceLineItemCollection listPreviewInvoiceLines( String previewInvoice, Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/quotes/%s/preview_invoices/%s/lines", ApiResource.urlEncodeId(this.getId()), ApiResource.urlEncodeId(previewInvoice)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().request(request, InvoiceLineItemCollection.class); } /** Preview the invoice line items that would be generated by accepting the quote. */ public InvoiceLineItemCollection listPreviewInvoiceLines( String previewInvoice, QuoteListPreviewInvoiceLinesParams params) throws StripeException { return listPreviewInvoiceLines(previewInvoice, params, (RequestOptions) null); } /** Preview the invoice line items that would be generated by accepting the quote. */ public InvoiceLineItemCollection listPreviewInvoiceLines( String previewInvoice, QuoteListPreviewInvoiceLinesParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/quotes/%s/preview_invoices/%s/lines", ApiResource.urlEncodeId(this.getId()), ApiResource.urlEncodeId(previewInvoice)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, InvoiceLineItemCollection.class); } /** Converts a stale quote to draft. */ public Quote markDraft() throws StripeException { return markDraft((Map) null, (RequestOptions) null); } /** Converts a stale quote to draft. */ public Quote markDraft(RequestOptions options) throws StripeException { return markDraft((Map) null, options); } /** Converts a stale quote to draft. */ public Quote markDraft(Map params) throws StripeException { return markDraft(params, (RequestOptions) null); } /** Converts a stale quote to draft. */ public Quote markDraft(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/mark_draft", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Converts a stale quote to draft. */ public Quote markDraft(QuoteMarkDraftParams params) throws StripeException { return markDraft(params, (RequestOptions) null); } /** Converts a stale quote to draft. */ public Quote markDraft(QuoteMarkDraftParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/mark_draft", 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, Quote.class); } /** Converts a draft or open quote to stale. */ public Quote markStale() throws StripeException { return markStale((Map) null, (RequestOptions) null); } /** Converts a draft or open quote to stale. */ public Quote markStale(RequestOptions options) throws StripeException { return markStale((Map) null, options); } /** Converts a draft or open quote to stale. */ public Quote markStale(Map params) throws StripeException { return markStale(params, (RequestOptions) null); } /** Converts a draft or open quote to stale. */ public Quote markStale(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/mark_stale", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Converts a draft or open quote to stale. */ public Quote markStale(QuoteMarkStaleParams params) throws StripeException { return markStale(params, (RequestOptions) null); } /** Converts a draft or open quote to stale. */ public Quote markStale(QuoteMarkStaleParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/mark_stale", 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, Quote.class); } /** * Download the PDF for a finalized quote. Explanation for special handling can be found here */ public InputStream pdf() throws StripeException { return pdf((Map) null, (RequestOptions) null); } /** * Download the PDF for a finalized quote. Explanation for special handling can be found here */ public InputStream pdf(Map params) throws StripeException { return pdf(params, (RequestOptions) null); } /** * Download the PDF for a finalized quote. Explanation for special handling can be found here */ public InputStream pdf(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/pdf", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.FILES, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().requestStream(request); } /** * Download the PDF for a finalized quote. Explanation for special handling can be found here */ public InputStream pdf(QuotePdfParams params) throws StripeException { return pdf(params, (RequestOptions) null); } /** * Download the PDF for a finalized quote. Explanation for special handling can be found here */ public InputStream pdf(QuotePdfParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/pdf", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.FILES, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().requestStream(request); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate() throws StripeException { return reestimate((Map) null, (RequestOptions) null); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate(RequestOptions options) throws StripeException { return reestimate((Map) null, options); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate(Map params) throws StripeException { return reestimate(params, (RequestOptions) null); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/reestimate", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate(QuoteReestimateParams params) throws StripeException { return reestimate(params, (RequestOptions) null); } /** Recompute the upcoming invoice estimate for the quote. */ public Quote reestimate(QuoteReestimateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s/reestimate", 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, Quote.class); } /** Retrieves the quote with the given ID. */ public static Quote retrieve(String quote) throws StripeException { return retrieve(quote, (Map) null, (RequestOptions) null); } /** Retrieves the quote with the given ID. */ public static Quote retrieve(String quote, RequestOptions options) throws StripeException { return retrieve(quote, (Map) null, options); } /** Retrieves the quote with the given ID. */ public static Quote retrieve(String quote, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s", ApiResource.urlEncodeId(quote)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Quote.class); } /** Retrieves the quote with the given ID. */ public static Quote retrieve(String quote, QuoteRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s", ApiResource.urlEncodeId(quote)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Quote.class); } /** A quote models prices and services for a customer. */ @Override public Quote update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** A quote models prices and services for a customer. */ @Override public Quote update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Quote.class); } /** A quote models prices and services for a customer. */ public Quote update(QuoteUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** A quote models prices and services for a customer. */ public Quote update(QuoteUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/quotes/%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, Quote.class); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AutomaticTax extends StripeObject { /** Automatically calculate taxes. */ @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; /** * The status of the most recent automated tax calculation for this quote. * *

One of {@code complete}, {@code failed}, or {@code requires_location_inputs}. */ @SerializedName("status") String status; @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); } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Computed extends StripeObject { /** * Details of the most recent reestimate of the quote's preview schedules and upcoming invoices, * including the status of Stripe's calculation. */ @SerializedName("last_reestimation_details") LastReestimationDetails lastReestimationDetails; /** * The definitive totals and line items the customer will be charged on a recurring basis. Takes * into account the line items with recurring prices and discounts with {@code duration=forever} * coupons only. Defaults to {@code null} if no inputted line items with recurring prices. */ @SerializedName("recurring") Recurring recurring; /** The time at which the quote's estimated schedules and upcoming invoices were generated. */ @SerializedName("updated_at") Long updatedAt; @SerializedName("upfront") Upfront upfront; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LastReestimationDetails extends StripeObject { /** * When {@code status} is {@code failed}, provides details about the quote reestimation * failure. */ @SerializedName("failed") Failed failed; /** * Latest status of the reestimation. * *

One of {@code failed}, {@code in_progress}, or {@code succeeded}. */ @SerializedName("status") String status; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Failed extends StripeObject { /** * The failure {@code code} is more granular than the {@code reason} provided and may * correspond to a Stripe error code. For automation errors, this field is one of: {@code * reverse_api_failure}, {@code reverse_api_deadline_exceeeded}, or {@code * reverse_api_response_validation_error}, which are Stripe error codes and map to the error * {@code message} field. */ @SerializedName("failure_code") String failureCode; /** * Information derived from the {@code failure_code} or a freeform message that explains the * error as a human-readable English string. For example, "margin ID is not a valid * ID". */ @SerializedName("message") String message; /** * The reason the reestimation failed. * *

One of {@code automation_failure}, or {@code internal_error}. */ @SerializedName("reason") String reason; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Recurring extends StripeObject { /** Total before any discounts or taxes are applied. */ @SerializedName("amount_subtotal") Long amountSubtotal; /** Total after discounts and taxes are applied. */ @SerializedName("amount_total") Long amountTotal; /** * 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; @SerializedName("total_details") TotalDetails totalDetails; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TotalDetails extends StripeObject { /** This is the sum of all the discounts. */ @SerializedName("amount_discount") Long amountDiscount; /** This is the sum of all the shipping amounts. */ @SerializedName("amount_shipping") Long amountShipping; /** This is the sum of all the tax amounts. */ @SerializedName("amount_tax") Long amountTax; @SerializedName("breakdown") Breakdown breakdown; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Breakdown extends StripeObject { /** The aggregated discounts. */ @SerializedName("discounts") List discounts; /** The aggregated tax amounts by rate. */ @SerializedName("taxes") List taxes; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Discount extends StripeObject { /** The amount discounted. */ @SerializedName("amount") Long amount; /** * A discount represents the actual application of a coupon or promotion code. It contains * information about when the discount began, when it will end, and what it is applied * to. * *

Related guide: Applying discounts to * subscriptions */ @SerializedName("discount") com.stripe.model.Discount discount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tax extends StripeObject { /** Amount of tax applied for this rate. */ @SerializedName("amount") Long amount; /** * Tax rates can be applied to invoices, subscriptions and Checkout * Sessions to collect tax. * *

Related guide: Tax * rates */ @SerializedName("rate") TaxRate rate; /** * The reasoning behind this tax, for example, if the product is tax exempt. The * possible values for this field may be extended as new tax rules are supported. * *

One of {@code customer_exempt}, {@code not_collecting}, {@code * not_subject_to_tax}, {@code not_supported}, {@code portion_product_exempt}, {@code * portion_reduced_rated}, {@code portion_standard_rated}, {@code product_exempt}, * {@code product_exempt_holiday}, {@code proportionally_rated}, {@code reduced_rated}, * {@code reverse_charge}, {@code standard_rated}, {@code taxable_basis_reduced}, or * {@code zero_rated}. */ @SerializedName("taxability_reason") String taxabilityReason; /** The amount on which tax is calculated, in cents (or local equivalent). */ @SerializedName("taxable_amount") Long taxableAmount; } } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Upfront extends StripeObject { /** Total before any discounts or taxes are applied. */ @SerializedName("amount_subtotal") Long amountSubtotal; /** Total after discounts and taxes are applied. */ @SerializedName("amount_total") Long amountTotal; /** * The line items that will appear on the next invoice after this quote is accepted. This does * not include pending invoice items that exist on the customer but may still be included in * the next invoice. */ @SerializedName("line_items") LineItemCollection lineItems; @SerializedName("total_details") TotalDetails totalDetails; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TotalDetails extends StripeObject { /** This is the sum of all the discounts. */ @SerializedName("amount_discount") Long amountDiscount; /** This is the sum of all the shipping amounts. */ @SerializedName("amount_shipping") Long amountShipping; /** This is the sum of all the tax amounts. */ @SerializedName("amount_tax") Long amountTax; @SerializedName("breakdown") Breakdown breakdown; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Breakdown extends StripeObject { /** The aggregated discounts. */ @SerializedName("discounts") List discounts; /** The aggregated tax amounts by rate. */ @SerializedName("taxes") List taxes; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Discount extends StripeObject { /** The amount discounted. */ @SerializedName("amount") Long amount; /** * A discount represents the actual application of a coupon or promotion code. It contains * information about when the discount began, when it will end, and what it is applied * to. * *

Related guide: Applying discounts to * subscriptions */ @SerializedName("discount") com.stripe.model.Discount discount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tax extends StripeObject { /** Amount of tax applied for this rate. */ @SerializedName("amount") Long amount; /** * Tax rates can be applied to invoices, subscriptions and Checkout * Sessions to collect tax. * *

Related guide: Tax * rates */ @SerializedName("rate") TaxRate rate; /** * The reasoning behind this tax, for example, if the product is tax exempt. The * possible values for this field may be extended as new tax rules are supported. * *

One of {@code customer_exempt}, {@code not_collecting}, {@code * not_subject_to_tax}, {@code not_supported}, {@code portion_product_exempt}, {@code * portion_reduced_rated}, {@code portion_standard_rated}, {@code product_exempt}, * {@code product_exempt_holiday}, {@code proportionally_rated}, {@code reduced_rated}, * {@code reverse_charge}, {@code standard_rated}, {@code taxable_basis_reduced}, or * {@code zero_rated}. */ @SerializedName("taxability_reason") String taxabilityReason; /** The amount on which tax is calculated, in cents (or local equivalent). */ @SerializedName("taxable_amount") Long taxableAmount; } } } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class FromQuote extends StripeObject { /** Whether this quote is a revision of a different quote. */ @SerializedName("is_revision") Boolean isRevision; /** The quote that was cloned. */ @SerializedName("quote") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField quote; /** Get ID of expandable {@code quote} object. */ public String getQuote() { return (this.quote != null) ? this.quote.getId() : null; } public void setQuote(String id) { this.quote = ApiResource.setExpandableFieldId(id, this.quote); } /** Get expanded {@code quote}. */ public Quote getQuoteObject() { return (this.quote != null) ? this.quote.getExpanded() : null; } public void setQuoteObject(Quote expandableObject) { this.quote = new ExpandableField(expandableObject.getId(), expandableObject); } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class InvoiceSettings extends StripeObject { /** * Number of days within which a customer must pay invoices generated by this quote. This value * will be {@code null} for quotes where {@code collection_method=charge_automatically}. */ @SerializedName("days_until_due") Long daysUntilDue; @SerializedName("issuer") Issuer issuer; @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); } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class StatusDetails extends StripeObject { @SerializedName("canceled") Canceled canceled; @SerializedName("stale") Stale stale; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Canceled extends StripeObject { /** * The reason this quote was marked as canceled. * *

One of {@code canceled}, {@code quote_accepted}, {@code quote_expired}, {@code * quote_superseded}, or {@code subscription_canceled}. */ @SerializedName("reason") String reason; /** * Time at which the quote was marked as canceled. Measured in seconds since the Unix epoch. */ @SerializedName("transitioned_at") Long transitionedAt; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Stale extends StripeObject { /** Time at which the quote expires. Measured in seconds since the Unix epoch. */ @SerializedName("expires_at") Long expiresAt; /** The most recent reason this quote was marked as stale. */ @SerializedName("last_reason") LastReason lastReason; /** Time at which the stale reason was updated. Measured in seconds since the Unix epoch. */ @SerializedName("last_updated_at") Long lastUpdatedAt; /** Time at which the quote was marked as stale. Measured in seconds since the Unix epoch. */ @SerializedName("transitioned_at") Long transitionedAt; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LastReason extends StripeObject { /** The ID of the line that is invalid if the stale reason type is {@code line_invalid}. */ @SerializedName("line_invalid") String lineInvalid; /** * The IDs of the lines that are invalid if the stale reason type is {@code lines_invalid}. */ @SerializedName("lines_invalid") List linesInvalid; /** The user supplied mark stale reason. */ @SerializedName("marked_stale") String markedStale; /** The ID of the subscription that was canceled. */ @SerializedName("subscription_canceled") String subscriptionCanceled; @SerializedName("subscription_changed") SubscriptionChanged subscriptionChanged; /** The ID of the subscription that was expired. */ @SerializedName("subscription_expired") String subscriptionExpired; /** The ID of the subscription schedule that was canceled. */ @SerializedName("subscription_schedule_canceled") String subscriptionScheduleCanceled; @SerializedName("subscription_schedule_changed") SubscriptionScheduleChanged subscriptionScheduleChanged; /** The ID of the subscription schedule that was released. */ @SerializedName("subscription_schedule_released") String subscriptionScheduleReleased; /** * The reason the quote was marked as stale. * *

One of {@code accept_failed_validations}, {@code bill_on_acceptance_invalid}, {@code * line_invalid}, {@code lines_invalid}, {@code marked_stale}, {@code * subscription_canceled}, {@code subscription_changed}, {@code subscription_expired}, * {@code subscription_schedule_canceled}, {@code subscription_schedule_changed}, or {@code * subscription_schedule_released}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LinesInvalid extends StripeObject { /** The timestamp at which the lines were marked as invalid. */ @SerializedName("invalid_at") Long invalidAt; /** The list of lines that became invalid at the given timestamp. */ @SerializedName("lines") List lines; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SubscriptionChanged extends StripeObject { /** The subscription's state before the quote was marked as stale. */ @SerializedName("previous_subscription") Subscription previousSubscription; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SubscriptionScheduleChanged extends StripeObject { /** The subscription schedule's state before the quote was marked as stale. */ @SerializedName("previous_subscription_schedule") com.stripe.model.SubscriptionSchedule previousSubscriptionSchedule; } } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class StatusTransitions extends StripeObject { /** The time that the quote was accepted. Measured in seconds since Unix epoch. */ @SerializedName("accepted_at") Long acceptedAt; /** The time that the quote was canceled. Measured in seconds since Unix epoch. */ @SerializedName("canceled_at") Long canceledAt; /** The time that the quote was finalized. Measured in seconds since Unix epoch. */ @SerializedName("finalized_at") Long finalizedAt; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SubscriptionData extends StripeObject { /** Describes the period to bill for upon accepting the quote. */ @SerializedName("bill_on_acceptance") BillOnAcceptance billOnAcceptance; /** * Configures when the subscription schedule generates prorations for phase transitions. * Possible values are {@code prorate_on_next_phase} or {@code prorate_up_front} with the * default being {@code prorate_on_next_phase}. {@code prorate_on_next_phase} will apply phase * changes and generate prorations at transition time. {@code prorate_up_front} will bill for * all phases within the current billing cycle up front. * *

One of {@code prorate_on_next_phase}, or {@code prorate_up_front}. */ @SerializedName("billing_behavior") String billingBehavior; /** * Whether the subscription will always start a new billing period when the quote is accepted. * *

Equal to {@code reset}. */ @SerializedName("billing_cycle_anchor") String billingCycleAnchor; /** * 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; /** * When creating a new subscription, the date of which the subscription schedule will start * after the quote is accepted. This date is ignored if it is in the past when the quote is * accepted. Measured in seconds since the Unix epoch. */ @SerializedName("effective_date") Long effectiveDate; /** * Behavior of the subscription schedule and underlying subscription when it ends. * *

One of {@code cancel}, or {@code release}. */ @SerializedName("end_behavior") String endBehavior; /** The id of the subscription that will be updated when the quote is accepted. */ @SerializedName("from_subscription") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField fromSubscription; /** * Set of key-value pairs that will set * metadata on the subscription or subscription schedule when the quote is accepted. If a * recurring price is included in {@code line_items}, this field will be passed to the resulting * subscription's {@code metadata} field. If {@code subscription_data.effective_date} is used, * this field will be passed to the resulting subscription schedule's {@code phases.metadata} * field. Unlike object-level metadata, this field is declarative. Updates will clear prior * values. */ @SerializedName("metadata") Map metadata; /** * If specified, the invoicing for the given billing cycle iterations will be processed when the * quote is accepted. Cannot be used with {@code effective_date}. */ @SerializedName("prebilling") Prebilling prebilling; /** * Determines how to handle prorations when the * quote is accepted. * *

One of {@code always_invoice}, {@code create_prorations}, or {@code none}. */ @SerializedName("proration_behavior") String prorationBehavior; /** * Integer representing the number of trial period days before the customer is charged for the * first time. */ @SerializedName("trial_period_days") Long trialPeriodDays; /** Get ID of expandable {@code fromSubscription} object. */ public String getFromSubscription() { return (this.fromSubscription != null) ? this.fromSubscription.getId() : null; } public void setFromSubscription(String id) { this.fromSubscription = ApiResource.setExpandableFieldId(id, this.fromSubscription); } /** Get expanded {@code fromSubscription}. */ public Subscription getFromSubscriptionObject() { return (this.fromSubscription != null) ? this.fromSubscription.getExpanded() : null; } public void setFromSubscriptionObject(Subscription expandableObject) { this.fromSubscription = new ExpandableField(expandableObject.getId(), expandableObject); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillOnAcceptance extends StripeObject { /** The start of the period to bill from when the Quote is accepted. */ @SerializedName("bill_from") BillFrom billFrom; /** The end of the period to bill until when the Quote is accepted. */ @SerializedName("bill_until") BillUntil billUntil; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillFrom extends StripeObject { /** The materialized time. */ @SerializedName("computed") Long computed; /** The timestamp the given line starts at. */ @SerializedName("line_starts_at") LineStartsAt lineStartsAt; /** A precise Unix timestamp. */ @SerializedName("timestamp") Long timestamp; /** * The type of method to specify the {@code bill_from} time. * *

One of {@code line_starts_at}, {@code now}, {@code pause_collection_start}, {@code * quote_acceptance_date}, or {@code timestamp}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LineStartsAt extends StripeObject implements HasId { /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillUntil extends StripeObject { /** The materialized time. */ @SerializedName("computed") Long computed; /** Time span for the quote line starting from the {@code starts_at} date. */ @SerializedName("duration") Duration duration; /** The timestamp the given line ends at. */ @SerializedName("line_ends_at") LineEndsAt lineEndsAt; /** A precise Unix timestamp. */ @SerializedName("timestamp") Long timestamp; /** * The type of method to specify the {@code bill_until} time. * *

One of {@code duration}, {@code line_ends_at}, {@code schedule_end}, {@code * timestamp}, or {@code upcoming_invoice}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Duration extends StripeObject { /** * Specifies a type of interval unit. 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, as an whole number greater than 0. Stripe multiplies this by * the interval type to get the overall duration. */ @SerializedName("interval_count") Long intervalCount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LineEndsAt extends StripeObject implements HasId { /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Prebilling extends StripeObject { @SerializedName("iterations") Long iterations; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SubscriptionDataOverride extends StripeObject { @SerializedName("applies_to") AppliesTo appliesTo; /** Describes the period to bill for upon accepting the quote. */ @SerializedName("bill_on_acceptance") BillOnAcceptance billOnAcceptance; /** * Configures when the subscription schedule generates prorations for phase transitions. * Possible values are {@code prorate_on_next_phase} or {@code prorate_up_front} with the * default being {@code prorate_on_next_phase}. {@code prorate_on_next_phase} will apply phase * changes and generate prorations at transition time. {@code prorate_up_front} will bill for * all phases within the current billing cycle up front. * *

One of {@code prorate_on_next_phase}, or {@code prorate_up_front}. */ @SerializedName("billing_behavior") String billingBehavior; /** * The customer which this quote belongs to. A customer is required before finalizing the quote. * Once specified, it cannot be changed. */ @SerializedName("customer") String customer; /** * 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; /** * Behavior of the subscription schedule and underlying subscription when it ends. * *

One of {@code cancel}, or {@code release}. */ @SerializedName("end_behavior") String endBehavior; /** * Determines how to handle prorations when the * quote is accepted. * *

One of {@code always_invoice}, {@code create_prorations}, or {@code none}. */ @SerializedName("proration_behavior") String prorationBehavior; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AppliesTo extends StripeObject { /** * A custom string that identifies a new subscription schedule being created upon quote * acceptance. All quote lines with the same {@code new_reference} field will be applied to * the creation of a new subscription schedule. */ @SerializedName("new_reference") String newReference; /** The ID of the schedule the line applies to. */ @SerializedName("subscription_schedule") String subscriptionSchedule; /** * Describes whether the quote line is affecting a new schedule or an existing schedule. * *

One of {@code new_reference}, or {@code subscription_schedule}. */ @SerializedName("type") String type; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillOnAcceptance extends StripeObject { /** The start of the period to bill from when the Quote is accepted. */ @SerializedName("bill_from") BillFrom billFrom; /** The end of the period to bill until when the Quote is accepted. */ @SerializedName("bill_until") BillUntil billUntil; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillFrom extends StripeObject { /** The materialized time. */ @SerializedName("computed") Long computed; /** The timestamp the given line starts at. */ @SerializedName("line_starts_at") LineStartsAt lineStartsAt; /** A precise Unix timestamp. */ @SerializedName("timestamp") Long timestamp; /** * The type of method to specify the {@code bill_from} time. * *

One of {@code line_starts_at}, {@code now}, {@code pause_collection_start}, {@code * quote_acceptance_date}, or {@code timestamp}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LineStartsAt extends StripeObject implements HasId { /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BillUntil extends StripeObject { /** The materialized time. */ @SerializedName("computed") Long computed; /** Time span for the quote line starting from the {@code starts_at} date. */ @SerializedName("duration") Duration duration; /** The timestamp the given line ends at. */ @SerializedName("line_ends_at") LineEndsAt lineEndsAt; /** A precise Unix timestamp. */ @SerializedName("timestamp") Long timestamp; /** * The type of method to specify the {@code bill_until} time. * *

One of {@code duration}, {@code line_ends_at}, {@code schedule_end}, {@code * timestamp}, or {@code upcoming_invoice}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Duration extends StripeObject { /** * Specifies a type of interval unit. 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, as an whole number greater than 0. Stripe multiplies this by * the interval type to get the overall duration. */ @SerializedName("interval_count") Long intervalCount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LineEndsAt extends StripeObject implements HasId { /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; } } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SubscriptionSchedule extends StripeObject { @SerializedName("applies_to") AppliesTo appliesTo; /** The subscription schedule that was created or updated from this quote. */ @SerializedName("subscription_schedule") String subscriptionSchedule; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AppliesTo extends StripeObject { /** * A custom string that identifies a new subscription schedule being created upon quote * acceptance. All quote lines with the same {@code new_reference} field will be applied to * the creation of a new subscription schedule. */ @SerializedName("new_reference") String newReference; /** The ID of the schedule the line applies to. */ @SerializedName("subscription_schedule") String subscriptionSchedule; /** * Describes whether the quote line is affecting a new schedule or an existing schedule. * *

One of {@code new_reference}, or {@code subscription_schedule}. */ @SerializedName("type") String type; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TotalDetails extends StripeObject { /** This is the sum of all the discounts. */ @SerializedName("amount_discount") Long amountDiscount; /** This is the sum of all the shipping amounts. */ @SerializedName("amount_shipping") Long amountShipping; /** This is the sum of all the tax amounts. */ @SerializedName("amount_tax") Long amountTax; @SerializedName("breakdown") Breakdown breakdown; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Breakdown extends StripeObject { /** The aggregated discounts. */ @SerializedName("discounts") List discounts; /** The aggregated tax amounts by rate. */ @SerializedName("taxes") List taxes; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Discount extends StripeObject { /** The amount discounted. */ @SerializedName("amount") Long amount; /** * A discount represents the actual application of a coupon or promotion code. It contains * information about when the discount began, when it will end, and what it is applied to. * *

Related guide: Applying discounts to * subscriptions */ @SerializedName("discount") com.stripe.model.Discount discount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tax extends StripeObject { /** Amount of tax applied for this rate. */ @SerializedName("amount") Long amount; /** * Tax rates can be applied to invoices, subscriptions and Checkout * Sessions to collect tax. * *

Related guide: Tax rates */ @SerializedName("rate") TaxRate rate; /** * The reasoning behind this tax, for example, if the product is tax exempt. The possible * values for this field may be extended as new tax rules are supported. * *

One of {@code customer_exempt}, {@code not_collecting}, {@code not_subject_to_tax}, * {@code not_supported}, {@code portion_product_exempt}, {@code portion_reduced_rated}, * {@code portion_standard_rated}, {@code product_exempt}, {@code product_exempt_holiday}, * {@code proportionally_rated}, {@code reduced_rated}, {@code reverse_charge}, {@code * standard_rated}, {@code taxable_basis_reduced}, or {@code zero_rated}. */ @SerializedName("taxability_reason") String taxabilityReason; /** The amount on which tax is calculated, in cents (or local equivalent). */ @SerializedName("taxable_amount") Long taxableAmount; } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TransferData extends StripeObject { /** * The amount in cents (or local equivalent) that will be transferred to the destination account * when the invoice is paid. By default, the entire amount is transferred to the destination. */ @SerializedName("amount") Long amount; /** * 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 will be 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); } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(application, responseGetter); trySetResponseGetter(automaticTax, responseGetter); trySetResponseGetter(computed, responseGetter); trySetResponseGetter(customer, responseGetter); trySetResponseGetter(fromQuote, responseGetter); trySetResponseGetter(invoice, responseGetter); trySetResponseGetter(invoiceSettings, responseGetter); trySetResponseGetter(lineItems, responseGetter); trySetResponseGetter(onBehalfOf, responseGetter); trySetResponseGetter(statusDetails, responseGetter); trySetResponseGetter(statusTransitions, responseGetter); trySetResponseGetter(subscription, responseGetter); trySetResponseGetter(subscriptionData, responseGetter); trySetResponseGetter(subscriptionSchedule, responseGetter); trySetResponseGetter(testClock, responseGetter); trySetResponseGetter(totalDetails, responseGetter); trySetResponseGetter(transferData, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy