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

com.stripe.model.tax.Calculation Maven / Gradle / Ivy

The newest version!
// File generated from our OpenAPI spec
package com.stripe.model.tax;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.HasId;
import com.stripe.model.StripeObject;
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.tax.CalculationCreateParams;
import com.stripe.param.tax.CalculationListLineItemsParams;
import com.stripe.param.tax.CalculationRetrieveParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * A Tax Calculation allows you to calculate the tax to collect from your customer.
 *
 * 

Related guide: Calculate tax in your custom * payment flow */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Calculation extends ApiResource implements HasId { /** * Total amount after taxes in the smallest currency unit. */ @SerializedName("amount_total") Long amountTotal; /** * Three-letter ISO currency code, * in lowercase. Must be a supported currency. */ @SerializedName("currency") String currency; /** * The ID of an existing Customer used * for the resource. */ @SerializedName("customer") String customer; @SerializedName("customer_details") CustomerDetails customerDetails; /** Timestamp of date at which the tax calculation will expire. */ @SerializedName("expires_at") Long expiresAt; /** Unique identifier for the calculation. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** The list of items the customer is purchasing. */ @SerializedName("line_items") CalculationLineItemCollection lineItems; /** * 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; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code tax.calculation}. */ @SerializedName("object") String object; /** The details of the ship from location, such as the address. */ @SerializedName("ship_from_details") ShipFromDetails shipFromDetails; /** The shipping cost details for the calculation. */ @SerializedName("shipping_cost") ShippingCost shippingCost; /** The amount of tax to be collected on top of the line item prices. */ @SerializedName("tax_amount_exclusive") Long taxAmountExclusive; /** The amount of tax already included in the line item prices. */ @SerializedName("tax_amount_inclusive") Long taxAmountInclusive; /** Breakdown of individual tax amounts that add up to the total. */ @SerializedName("tax_breakdown") List taxBreakdown; /** Timestamp of date at which the tax rules and rates in effect applies for the calculation. */ @SerializedName("tax_date") Long taxDate; /** Calculates tax based on the input and returns a Tax {@code Calculation} object. */ public static Calculation create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** Calculates tax based on the input and returns a Tax {@code Calculation} object. */ public static Calculation create(Map params, RequestOptions options) throws StripeException { String path = "/v1/tax/calculations"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Calculation.class); } /** Calculates tax based on the input and returns a Tax {@code Calculation} object. */ public static Calculation create(CalculationCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** Calculates tax based on the input and returns a Tax {@code Calculation} object. */ public static Calculation create(CalculationCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/tax/calculations"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Calculation.class); } /** * Retrieves the line items of a tax calculation as a collection, if the calculation hasn’t * expired. */ public CalculationLineItemCollection listLineItems() throws StripeException { return listLineItems((Map) null, (RequestOptions) null); } /** * Retrieves the line items of a tax calculation as a collection, if the calculation hasn’t * expired. */ public CalculationLineItemCollection listLineItems(Map params) throws StripeException { return listLineItems(params, (RequestOptions) null); } /** * Retrieves the line items of a tax calculation as a collection, if the calculation hasn’t * expired. */ public CalculationLineItemCollection listLineItems( Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/tax/calculations/%s/line_items", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getResponseGetter().request(request, CalculationLineItemCollection.class); } /** * Retrieves the line items of a tax calculation as a collection, if the calculation hasn’t * expired. */ public CalculationLineItemCollection listLineItems(CalculationListLineItemsParams params) throws StripeException { return listLineItems(params, (RequestOptions) null); } /** * Retrieves the line items of a tax calculation as a collection, if the calculation hasn’t * expired. */ public CalculationLineItemCollection listLineItems( CalculationListLineItemsParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/tax/calculations/%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, CalculationLineItemCollection.class); } /** Retrieves a Tax {@code Calculation} object, if the calculation hasn’t expired. */ public static Calculation retrieve(String calculation) throws StripeException { return retrieve(calculation, (Map) null, (RequestOptions) null); } /** Retrieves a Tax {@code Calculation} object, if the calculation hasn’t expired. */ public static Calculation retrieve(String calculation, RequestOptions options) throws StripeException { return retrieve(calculation, (Map) null, options); } /** Retrieves a Tax {@code Calculation} object, if the calculation hasn’t expired. */ public static Calculation retrieve( String calculation, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/tax/calculations/%s", ApiResource.urlEncodeId(calculation)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Calculation.class); } /** Retrieves a Tax {@code Calculation} object, if the calculation hasn’t expired. */ public static Calculation retrieve( String calculation, CalculationRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/tax/calculations/%s", ApiResource.urlEncodeId(calculation)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Calculation.class); } /** * For more details about CustomerDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CustomerDetails extends StripeObject { /** The customer's postal address (for example, home or business location). */ @SerializedName("address") Address address; /** * The type of customer address provided. * *

One of {@code billing}, or {@code shipping}. */ @SerializedName("address_source") String addressSource; /** The customer's IP address (IPv4 or IPv6). */ @SerializedName("ip_address") String ipAddress; /** The customer's tax IDs (for example, EU VAT numbers). */ @SerializedName("tax_ids") List taxIds; /** * The taxability override used for taxation. * *

One of {@code customer_exempt}, {@code none}, or {@code reverse_charge}. */ @SerializedName("taxability_override") String taxabilityOverride; /** * For more details about Address, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Address extends StripeObject { /** City, district, suburb, town, or village. */ @SerializedName("city") String city; /** * Two-letter country code (ISO * 3166-1 alpha-2). */ @SerializedName("country") String country; /** Address line 1 (e.g., street, PO Box, or company name). */ @SerializedName("line1") String line1; /** Address line 2 (e.g., apartment, suite, unit, or building). */ @SerializedName("line2") String line2; /** ZIP or postal code. */ @SerializedName("postal_code") String postalCode; /** * State/province as an ISO 3166-2 * subdivision code, without country prefix. Example: "NY" or "TX". */ @SerializedName("state") String state; } /** * For more details about TaxId, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TaxId extends StripeObject { /** * The type of the tax ID, one of {@code ad_nrt}, {@code ar_cuit}, {@code eu_vat}, {@code * bo_tin}, {@code br_cnpj}, {@code br_cpf}, {@code cn_tin}, {@code co_nit}, {@code cr_tin}, * {@code do_rcn}, {@code ec_ruc}, {@code eu_oss_vat}, {@code hr_oib}, {@code pe_ruc}, {@code * ro_tin}, {@code rs_pib}, {@code sv_nit}, {@code uy_ruc}, {@code ve_rif}, {@code vn_tin}, * {@code gb_vat}, {@code nz_gst}, {@code au_abn}, {@code au_arn}, {@code in_gst}, {@code * no_vat}, {@code no_voec}, {@code za_vat}, {@code ch_vat}, {@code mx_rfc}, {@code sg_uen}, * {@code ru_inn}, {@code ru_kpp}, {@code ca_bn}, {@code hk_br}, {@code es_cif}, {@code * tw_vat}, {@code th_vat}, {@code jp_cn}, {@code jp_rn}, {@code jp_trn}, {@code li_uid}, * {@code li_vat}, {@code my_itn}, {@code us_ein}, {@code kr_brn}, {@code ca_qst}, {@code * ca_gst_hst}, {@code ca_pst_bc}, {@code ca_pst_mb}, {@code ca_pst_sk}, {@code my_sst}, * {@code sg_gst}, {@code ae_trn}, {@code cl_tin}, {@code sa_vat}, {@code id_npwp}, {@code * my_frp}, {@code il_vat}, {@code ge_vat}, {@code ua_vat}, {@code is_vat}, {@code bg_uic}, * {@code hu_tin}, {@code si_tin}, {@code ke_pin}, {@code tr_tin}, {@code eg_tin}, {@code * ph_tin}, {@code al_tin}, {@code bh_vat}, {@code kz_bin}, {@code ng_tin}, {@code om_vat}, * {@code de_stn}, {@code ch_uid}, {@code tz_vat}, {@code uz_vat}, {@code uz_tin}, {@code * md_vat}, {@code ma_vat}, {@code by_tin}, {@code ao_tin}, {@code bs_tin}, {@code bb_tin}, * {@code cd_nif}, {@code mr_nif}, {@code me_pib}, {@code zw_tin}, {@code ba_tin}, {@code * gn_nif}, {@code mk_vat}, {@code sr_fin}, {@code sn_ninea}, {@code am_tin}, {@code np_pan}, * {@code tj_tin}, {@code ug_tin}, {@code zm_tin}, {@code kh_tin}, or {@code unknown}. */ @SerializedName("type") String type; /** The value of the tax ID. */ @SerializedName("value") String value; } } /** * For more details about ShipFromDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ShipFromDetails extends StripeObject { @SerializedName("address") Address address; /** * For more details about Address, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Address extends StripeObject { /** City, district, suburb, town, or village. */ @SerializedName("city") String city; /** * Two-letter country code (ISO * 3166-1 alpha-2). */ @SerializedName("country") String country; /** Address line 1 (e.g., street, PO Box, or company name). */ @SerializedName("line1") String line1; /** Address line 2 (e.g., apartment, suite, unit, or building). */ @SerializedName("line2") String line2; /** ZIP or postal code. */ @SerializedName("postal_code") String postalCode; /** * State/province as an ISO 3166-2 * subdivision code, without country prefix. Example: "NY" or "TX". */ @SerializedName("state") String state; } } /** * For more details about ShippingCost, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ShippingCost extends StripeObject { /** * The shipping amount in the smallest * currency unit. If {@code tax_behavior=inclusive}, then this amount includes taxes. * Otherwise, taxes were calculated on top of this amount. */ @SerializedName("amount") Long amount; /** * The amount of tax calculated for shipping, in the smallest currency unit. */ @SerializedName("amount_tax") Long amountTax; /** * The ID of an existing ShippingRate. */ @SerializedName("shipping_rate") String shippingRate; /** * Specifies whether the {@code amount} includes taxes. If {@code tax_behavior=inclusive}, then * the amount includes taxes. * *

One of {@code exclusive}, or {@code inclusive}. */ @SerializedName("tax_behavior") String taxBehavior; /** Detailed account of taxes relevant to shipping cost. */ @SerializedName("tax_breakdown") List taxBreakdown; /** * The tax code ID used for shipping. */ @SerializedName("tax_code") String taxCode; /** * For more details about TaxBreakdown, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TaxBreakdown extends StripeObject { /** * The amount of tax, in the smallest currency unit. */ @SerializedName("amount") Long amount; @SerializedName("jurisdiction") Jurisdiction jurisdiction; /** * Indicates whether the jurisdiction was determined by the origin (merchant's address) or * destination (customer's address). * *

One of {@code destination}, or {@code origin}. */ @SerializedName("sourcing") String sourcing; /** * Details regarding the rate for this tax. This field will be {@code null} when the tax is * not imposed, for example if the product is exempt from tax. */ @SerializedName("tax_rate_details") TaxRateDetails taxRateDetails; /** * 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 the smallest currency unit. */ @SerializedName("taxable_amount") Long taxableAmount; /** * For more details about Jurisdiction, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Jurisdiction extends StripeObject { /** * Two-letter country code (ISO * 3166-1 alpha-2). */ @SerializedName("country") String country; /** A human-readable name for the jurisdiction imposing the tax. */ @SerializedName("display_name") String displayName; /** * Indicates the level of the jurisdiction imposing the tax. * *

One of {@code city}, {@code country}, {@code county}, {@code district}, or {@code * state}. */ @SerializedName("level") String level; /** * ISO 3166-2 subdivision code, * without country prefix. For example, "NY" for New York, United States. */ @SerializedName("state") String state; } /** * For more details about TaxRateDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TaxRateDetails extends StripeObject { /** * A localized display name for tax type, intended to be human-readable. For example, * "Local Sales and Use Tax", "Value-added tax (VAT)", or * "Umsatzsteuer (USt.)". */ @SerializedName("display_name") String displayName; /** * The tax rate percentage as a string. For example, 8.5% is represented as "8.5". */ @SerializedName("percentage_decimal") String percentageDecimal; /** * The tax type, such as {@code vat} or {@code sales_tax}. * *

One of {@code amusement_tax}, {@code communications_tax}, {@code gst}, {@code hst}, * {@code igst}, {@code jct}, {@code lease_tax}, {@code pst}, {@code qst}, {@code * retail_delivery_fee}, {@code rst}, {@code sales_tax}, {@code service_tax}, or {@code * vat}. */ @SerializedName("tax_type") String taxType; } } } /** * For more details about TaxBreakdown, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TaxBreakdown extends StripeObject { /** * The amount of tax, in the smallest * currency unit. */ @SerializedName("amount") Long amount; /** Specifies whether the tax amount is included in the line item amount. */ @SerializedName("inclusive") Boolean inclusive; @SerializedName("tax_rate_details") TaxRateDetails taxRateDetails; /** * The reasoning behind this tax, for example, if the product is tax exempt. We might extend the * possible values for this field to support new tax rules. * *

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 the smallest currency unit. */ @SerializedName("taxable_amount") Long taxableAmount; /** * For more details about TaxRateDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class TaxRateDetails extends StripeObject { /** * Two-letter country code (ISO * 3166-1 alpha-2). */ @SerializedName("country") String country; /** * The amount of the tax rate when the {@code rate_type} is {@code flat_amount}. Tax rates * with {@code rate_type} {@code percentage} can vary based on the transaction, resulting in * this field being {@code null}. This field exposes the amount and currency of the flat tax * rate. */ @SerializedName("flat_amount") FlatAmount flatAmount; /** The tax rate percentage as a string. For example, 8.5% is represented as {@code "8.5"}. */ @SerializedName("percentage_decimal") String percentageDecimal; /** * Indicates the type of tax rate applied to the taxable amount. This value can be {@code * null} when no tax applies to the location. * *

One of {@code flat_amount}, or {@code percentage}. */ @SerializedName("rate_type") String rateType; /** State, county, province, or region. */ @SerializedName("state") String state; /** * The tax type, such as {@code vat} or {@code sales_tax}. * *

One of {@code amusement_tax}, {@code communications_tax}, {@code gst}, {@code hst}, * {@code igst}, {@code jct}, {@code lease_tax}, {@code pst}, {@code qst}, {@code * retail_delivery_fee}, {@code rst}, {@code sales_tax}, {@code service_tax}, or {@code vat}. */ @SerializedName("tax_type") String taxType; /** * The amount of the tax rate when the {@code rate_type`` is }flat_amount{@code . Tax rates * with }rate_type{@code }percentage{@code can vary based on the transaction, resulting in * this field being}null`. This field exposes the amount and currency of the flat tax rate. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class FlatAmount extends StripeObject { /** * Amount of the tax when the {@code rate_type} is {@code flat_amount}. This positive * integer represents how much to charge in the smallest currency unit (e.g., 100 cents to * charge $1.00 or 100 to charge ¥100, a zero-decimal currency). The amount value supports * up to eight digits (e.g., a value of 99999999 for a USD charge of $999,999.99). */ @SerializedName("amount") Long amount; /** Three-letter ISO currency code, in lowercase. */ @SerializedName("currency") String currency; } } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(customerDetails, responseGetter); trySetResponseGetter(lineItems, responseGetter); trySetResponseGetter(shipFromDetails, responseGetter); trySetResponseGetter(shippingCost, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy