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

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

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

import com.google.gson.annotations.SerializedName;
import com.stripe.Stripe;
import com.stripe.exception.StripeException;
import com.stripe.model.testhelpers.TestClock;
import com.stripe.net.ApiResource;
import com.stripe.net.RequestOptions;
import com.stripe.param.CustomerBalanceTransactionsParams;
import com.stripe.param.CustomerCreateFundingInstructionsParams;
import com.stripe.param.CustomerCreateParams;
import com.stripe.param.CustomerFundCashBalanceParams;
import com.stripe.param.CustomerListParams;
import com.stripe.param.CustomerListPaymentMethodsParams;
import com.stripe.param.CustomerRetrieveParams;
import com.stripe.param.CustomerRetrievePaymentMethodParams;
import com.stripe.param.CustomerSearchParams;
import com.stripe.param.CustomerUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * This object represents a customer of your business. It lets you create recurring charges and
 * track payments that belong to the same customer.
 *
 * 

Related guide: Save a card * during payment */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Customer extends ApiResource implements HasId, MetadataStore { /** The customer's address. */ @SerializedName("address") Address address; /** * Current balance, if any, being stored on the customer. If negative, the customer has credit to * apply to their next invoice. If positive, the customer has an amount owed that will be added to * their next invoice. The balance does not refer to any unpaid invoices; it solely takes into * account amounts that have yet to be successfully applied to any invoice. This balance is only * taken into account as invoices are finalized. */ @SerializedName("balance") Long balance; /** * The current funds being held by Stripe on behalf of the customer. These funds can be applied * towards payment intents with source "cash_balance". The settings[reconciliation_mode] * field describes whether these funds are applied to such payment intents manually or * automatically. */ @SerializedName("cash_balance") CashBalance cashBalance; /** Time at which the object was created. Measured in seconds since the Unix epoch. */ @SerializedName("created") Long created; /** * Three-letter ISO code for the currency the * customer can be charged in for recurring billing purposes. */ @SerializedName("currency") String currency; /** * ID of the default payment source for the customer. * *

If you are using payment methods created via the PaymentMethods API, see the invoice_settings.default_payment_method * field instead. */ @SerializedName("default_source") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField defaultSource; /** Always true for a deleted object. */ @SerializedName("deleted") Boolean deleted; /** * When the customer's latest invoice is billed by charging automatically, {@code delinquent} is * {@code true} if the invoice's latest charge failed. When the customer's latest invoice is * billed by sending an invoice, {@code delinquent} is {@code true} if the invoice isn't paid by * its due date. * *

If an invoice is marked uncollectible by dunning, {@code delinquent} * doesn't get reset to {@code false}. */ @SerializedName("delinquent") Boolean delinquent; /** An arbitrary string attached to the object. Often useful for displaying to users. */ @SerializedName("description") String description; /** Describes the current discount active on the customer, if there is one. */ @SerializedName("discount") Discount discount; /** The customer's email address. */ @SerializedName("email") String email; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * The current multi-currency balances, if any, being stored on the customer. If positive in a * currency, the customer has a credit to apply to their next invoice denominated in that * currency. If negative, the customer has an amount owed that will be added to their next invoice * denominated in that currency. These balances do not refer to any unpaid invoices. They solely * track amounts that have yet to be successfully applied to any invoice. A balance in a * particular currency is only applied to any invoice as an invoice in that currency is finalized. */ @SerializedName("invoice_credit_balance") Map invoiceCreditBalance; /** The prefix for the customer used to generate unique invoice numbers. */ @SerializedName("invoice_prefix") String invoicePrefix; @SerializedName("invoice_settings") InvoiceSettings invoiceSettings; /** * 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; /** The customer's full name or business name. */ @SerializedName("name") String name; /** The suffix of the customer's next invoice number, e.g., 0001. */ @SerializedName("next_invoice_sequence") Long nextInvoiceSequence; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code customer}. */ @SerializedName("object") String object; /** The customer's phone number. */ @SerializedName("phone") String phone; /** The customer's preferred locales (languages), ordered by preference. */ @SerializedName("preferred_locales") List preferredLocales; /** * Mailing and shipping address for the customer. Appears on invoices emailed to this customer. */ @SerializedName("shipping") ShippingDetails shipping; /** The customer's payment sources, if any. */ @SerializedName("sources") PaymentSourceCollection sources; /** The customer's current subscriptions, if any. */ @SerializedName("subscriptions") SubscriptionCollection subscriptions; @SerializedName("tax") Tax tax; /** * Describes the customer's tax exemption status. One of {@code none}, {@code exempt}, or {@code * reverse}. When set to {@code reverse}, invoice and receipt PDFs include the text * "Reverse charge". */ @SerializedName("tax_exempt") String taxExempt; /** The customer's tax IDs. */ @SerializedName("tax_ids") TaxIdCollection taxIds; /** ID of the test clock this customer belongs to. */ @SerializedName("test_clock") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField testClock; /** 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 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); } /** * Returns a list of transactions that updated the customer’s balances. */ public CustomerBalanceTransactionCollection balanceTransactions() throws StripeException { return balanceTransactions((Map) null, (RequestOptions) null); } /** * Returns a list of transactions that updated the customer’s balances. */ public CustomerBalanceTransactionCollection balanceTransactions(Map params) throws StripeException { return balanceTransactions(params, (RequestOptions) null); } /** * Returns a list of transactions that updated the customer’s balances. */ public CustomerBalanceTransactionCollection balanceTransactions( Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/balance_transactions", ApiResource.urlEncodeId(this.getId()))); return ApiResource.requestCollection( url, params, CustomerBalanceTransactionCollection.class, options); } /** * Returns a list of transactions that updated the customer’s balances. */ public CustomerBalanceTransactionCollection balanceTransactions( CustomerBalanceTransactionsParams params) throws StripeException { return balanceTransactions(params, (RequestOptions) null); } /** * Returns a list of transactions that updated the customer’s balances. */ public CustomerBalanceTransactionCollection balanceTransactions( CustomerBalanceTransactionsParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/balance_transactions", ApiResource.urlEncodeId(this.getId()))); return ApiResource.requestCollection( url, params, CustomerBalanceTransactionCollection.class, options); } /** Creates a new customer object. */ public static Customer create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new customer object. */ public static Customer create(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers"); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, Customer.class, options); } /** Creates a new customer object. */ public static Customer create(CustomerCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new customer object. */ public static Customer create(CustomerCreateParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers"); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, Customer.class, options); } /** * Retrieve funding instructions for a customer cash balance. If funding instructions do not yet * exist for the customer, new funding instructions will be created. If funding instructions have * already been created for a given customer, the same funding instructions will be retrieved. In * other words, we will return the same funding instructions each time. */ public FundingInstructions createFundingInstructions(Map params) throws StripeException { return createFundingInstructions(params, (RequestOptions) null); } /** * Retrieve funding instructions for a customer cash balance. If funding instructions do not yet * exist for the customer, new funding instructions will be created. If funding instructions have * already been created for a given customer, the same funding instructions will be retrieved. In * other words, we will return the same funding instructions each time. */ public FundingInstructions createFundingInstructions( Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/funding_instructions", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, FundingInstructions.class, options); } /** * Retrieve funding instructions for a customer cash balance. If funding instructions do not yet * exist for the customer, new funding instructions will be created. If funding instructions have * already been created for a given customer, the same funding instructions will be retrieved. In * other words, we will return the same funding instructions each time. */ public FundingInstructions createFundingInstructions( CustomerCreateFundingInstructionsParams params) throws StripeException { return createFundingInstructions(params, (RequestOptions) null); } /** * Retrieve funding instructions for a customer cash balance. If funding instructions do not yet * exist for the customer, new funding instructions will be created. If funding instructions have * already been created for a given customer, the same funding instructions will be retrieved. In * other words, we will return the same funding instructions each time. */ public FundingInstructions createFundingInstructions( CustomerCreateFundingInstructionsParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/funding_instructions", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, FundingInstructions.class, options); } /** * Permanently deletes a customer. It cannot be undone. Also immediately cancels any active * subscriptions on the customer. */ public Customer delete() throws StripeException { return delete((Map) null, (RequestOptions) null); } /** * Permanently deletes a customer. It cannot be undone. Also immediately cancels any active * subscriptions on the customer. */ public Customer delete(RequestOptions options) throws StripeException { return delete((Map) null, options); } /** * Permanently deletes a customer. It cannot be undone. Also immediately cancels any active * subscriptions on the customer. */ public Customer delete(Map params) throws StripeException { return delete(params, (RequestOptions) null); } /** * Permanently deletes a customer. It cannot be undone. Also immediately cancels any active * subscriptions on the customer. */ public Customer delete(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.DELETE, url, params, Customer.class, options); } /** Removes the currently applied discount on a customer. */ public Discount deleteDiscount() throws StripeException { return deleteDiscount((Map) null, (RequestOptions) null); } /** Removes the currently applied discount on a customer. */ public Discount deleteDiscount(Map params) throws StripeException { return deleteDiscount(params, (RequestOptions) null); } /** Removes the currently applied discount on a customer. */ public Discount deleteDiscount(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s/discount", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.DELETE, url, params, Discount.class, options); } /** * Returns a list of your customers. The customers are returned sorted by creation date, with the * most recent customers appearing first. */ public static CustomerCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of your customers. The customers are returned sorted by creation date, with the * most recent customers appearing first. */ public static CustomerCollection list(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers"); return ApiResource.requestCollection(url, params, CustomerCollection.class, options); } /** * Returns a list of your customers. The customers are returned sorted by creation date, with the * most recent customers appearing first. */ public static CustomerCollection list(CustomerListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of your customers. The customers are returned sorted by creation date, with the * most recent customers appearing first. */ public static CustomerCollection list(CustomerListParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers"); return ApiResource.requestCollection(url, params, CustomerCollection.class, options); } /** Returns a list of PaymentMethods for a given Customer. */ public PaymentMethodCollection listPaymentMethods() throws StripeException { return listPaymentMethods((Map) null, (RequestOptions) null); } /** Returns a list of PaymentMethods for a given Customer. */ public PaymentMethodCollection listPaymentMethods(Map params) throws StripeException { return listPaymentMethods(params, (RequestOptions) null); } /** Returns a list of PaymentMethods for a given Customer. */ public PaymentMethodCollection listPaymentMethods( Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/payment_methods", ApiResource.urlEncodeId(this.getId()))); return ApiResource.requestCollection(url, params, PaymentMethodCollection.class, options); } /** Returns a list of PaymentMethods for a given Customer. */ public PaymentMethodCollection listPaymentMethods(CustomerListPaymentMethodsParams params) throws StripeException { return listPaymentMethods(params, (RequestOptions) null); } /** Returns a list of PaymentMethods for a given Customer. */ public PaymentMethodCollection listPaymentMethods( CustomerListPaymentMethodsParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/payment_methods", ApiResource.urlEncodeId(this.getId()))); return ApiResource.requestCollection(url, params, PaymentMethodCollection.class, options); } /** Retrieves a Customer object. */ public static Customer retrieve(String customer) throws StripeException { return retrieve(customer, (Map) null, (RequestOptions) null); } /** Retrieves a Customer object. */ public static Customer retrieve(String customer, RequestOptions options) throws StripeException { return retrieve(customer, (Map) null, options); } /** Retrieves a Customer object. */ public static Customer retrieve( String customer, Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s", ApiResource.urlEncodeId(customer))); return ApiResource.request(ApiResource.RequestMethod.GET, url, params, Customer.class, options); } /** Retrieves a Customer object. */ public static Customer retrieve( String customer, CustomerRetrieveParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s", ApiResource.urlEncodeId(customer))); return ApiResource.request(ApiResource.RequestMethod.GET, url, params, Customer.class, options); } /** Retrieves a PaymentMethod object for a given Customer. */ public PaymentMethod retrievePaymentMethod( String paymentMethod, Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/payment_methods/%s", ApiResource.urlEncodeId(this.getId()), ApiResource.urlEncodeId(paymentMethod))); return ApiResource.request( ApiResource.RequestMethod.GET, url, params, PaymentMethod.class, options); } /** Retrieves a PaymentMethod object for a given Customer. */ public PaymentMethod retrievePaymentMethod( String paymentMethod, CustomerRetrievePaymentMethodParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/customers/%s/payment_methods/%s", ApiResource.urlEncodeId(this.getId()), ApiResource.urlEncodeId(paymentMethod))); return ApiResource.request( ApiResource.RequestMethod.GET, url, params, PaymentMethod.class, options); } /** * Search for customers 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 CustomerSearchResult search(Map params) throws StripeException { return search(params, (RequestOptions) null); } /** * Search for customers 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 CustomerSearchResult search(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers/search"); return ApiResource.requestSearchResult(url, params, CustomerSearchResult.class, options); } /** * Search for customers 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 CustomerSearchResult search(CustomerSearchParams params) throws StripeException { return search(params, (RequestOptions) null); } /** * Search for customers 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 CustomerSearchResult search(CustomerSearchParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/customers/search"); return ApiResource.requestSearchResult(url, params, CustomerSearchResult.class, options); } /** * Updates the specified customer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. For example, if you pass the source * parameter, that becomes the customer’s active source (e.g., a card) to be used for all charges * in the future. When you update a customer to a new valid card source by passing the * source parameter: for each of the customer’s current subscriptions, if the * subscription bills automatically and is in the {@code past_due} state, then the latest open * invoice for the subscription with automatic collection enabled will be retried. This retry will * not count as an automatic retry, and will not affect the next regularly scheduled payment for * the invoice. Changing the default_source for a customer will not trigger this * behavior. * *

This request accepts mostly the same arguments as the customer creation call. */ @Override public Customer update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified customer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. For example, if you pass the source * parameter, that becomes the customer’s active source (e.g., a card) to be used for all charges * in the future. When you update a customer to a new valid card source by passing the * source parameter: for each of the customer’s current subscriptions, if the * subscription bills automatically and is in the {@code past_due} state, then the latest open * invoice for the subscription with automatic collection enabled will be retried. This retry will * not count as an automatic retry, and will not affect the next regularly scheduled payment for * the invoice. Changing the default_source for a customer will not trigger this * behavior. * *

This request accepts mostly the same arguments as the customer creation call. */ @Override public Customer update(Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, Customer.class, options); } /** * Updates the specified customer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. For example, if you pass the source * parameter, that becomes the customer’s active source (e.g., a card) to be used for all charges * in the future. When you update a customer to a new valid card source by passing the * source parameter: for each of the customer’s current subscriptions, if the * subscription bills automatically and is in the {@code past_due} state, then the latest open * invoice for the subscription with automatic collection enabled will be retried. This retry will * not count as an automatic retry, and will not affect the next regularly scheduled payment for * the invoice. Changing the default_source for a customer will not trigger this * behavior. * *

This request accepts mostly the same arguments as the customer creation call. */ public Customer update(CustomerUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified customer by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. For example, if you pass the source * parameter, that becomes the customer’s active source (e.g., a card) to be used for all charges * in the future. When you update a customer to a new valid card source by passing the * source parameter: for each of the customer’s current subscriptions, if the * subscription bills automatically and is in the {@code past_due} state, then the latest open * invoice for the subscription with automatic collection enabled will be retried. This retry will * not count as an automatic retry, and will not affect the next regularly scheduled payment for * the invoice. Changing the default_source for a customer will not trigger this * behavior. * *

This request accepts mostly the same arguments as the customer creation call. */ public Customer update(CustomerUpdateParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format("/v1/customers/%s", ApiResource.urlEncodeId(this.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, Customer.class, options); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class InvoiceSettings extends StripeObject { /** Default custom fields to be displayed on invoices for this customer. */ @SerializedName("custom_fields") List customFields; /** * ID of a payment method that's attached to the customer, to be used as the customer's default * payment method for subscriptions and invoices. */ @SerializedName("default_payment_method") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField defaultPaymentMethod; /** Default footer to be displayed on invoices for this customer. */ @SerializedName("footer") String footer; /** Default options for invoice PDF rendering for this customer. */ @SerializedName("rendering_options") RenderingOptions renderingOptions; /** 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); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CustomField extends StripeObject { /** The name of the custom field. */ @SerializedName("name") String name; /** The value of the custom field. */ @SerializedName("value") String value; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class RenderingOptions extends StripeObject { /** How line-item prices and amounts will be displayed with respect to tax on invoice PDFs. */ @SerializedName("amount_tax_display") String amountTaxDisplay; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tax extends StripeObject { /** * Surfaces if automatic tax computation is possible given the current customer location * information. * *

One of {@code failed}, {@code not_collecting}, {@code supported}, or {@code * unrecognized_location}. */ @SerializedName("automatic_tax") String automaticTax; /** A recent IP address of the customer used for tax reporting and tax location inference. */ @SerializedName("ip_address") String ipAddress; /** The customer's location as identified by Stripe Tax. */ @SerializedName("location") Location location; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Location extends StripeObject { /** The customer's country as identified by Stripe Tax. */ @SerializedName("country") String country; /** * The data source used to infer the customer's location. * *

One of {@code billing_address}, {@code ip_address}, {@code payment_method}, or {@code * shipping_destination}. */ @SerializedName("source") String source; /** The customer's state, county, province, or region as identified by Stripe Tax. */ @SerializedName("state") String state; } } public TestHelpers getTestHelpers() { return new TestHelpers(this); } public static class TestHelpers { private final Customer resource; private TestHelpers(Customer resource) { this.resource = resource; } /** Create an incoming testmode bank transfer. */ public CustomerCashBalanceTransaction fundCashBalance(Map params) throws StripeException { return fundCashBalance(params, (RequestOptions) null); } /** Create an incoming testmode bank transfer. */ public CustomerCashBalanceTransaction fundCashBalance( Map params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/test_helpers/customers/%s/fund_cash_balance", ApiResource.urlEncodeId(this.resource.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, CustomerCashBalanceTransaction.class, options); } /** Create an incoming testmode bank transfer. */ public CustomerCashBalanceTransaction fundCashBalance(CustomerFundCashBalanceParams params) throws StripeException { return fundCashBalance(params, (RequestOptions) null); } /** Create an incoming testmode bank transfer. */ public CustomerCashBalanceTransaction fundCashBalance( CustomerFundCashBalanceParams params, RequestOptions options) throws StripeException { String url = ApiResource.fullUrl( Stripe.getApiBase(), options, String.format( "/v1/test_helpers/customers/%s/fund_cash_balance", ApiResource.urlEncodeId(this.resource.getId()))); return ApiResource.request( ApiResource.RequestMethod.POST, url, params, CustomerCashBalanceTransaction.class, options); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy