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

com.stripe.model.Dispute 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.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.DisputeCloseParams;
import com.stripe.param.DisputeListParams;
import com.stripe.param.DisputeRetrieveParams;
import com.stripe.param.DisputeUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * A dispute occurs when a customer questions your charge with their card issuer. When this happens,
 * you have the opportunity to respond to the dispute with evidence that shows that the charge is
 * legitimate.
 *
 * 

Related guide: Disputes and fraud */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Dispute extends ApiResource implements MetadataStore, BalanceTransactionSource { /** * Disputed amount. Usually the amount of the charge, but it can differ (usually because of * currency fluctuation or because only part of the order is disputed). */ @SerializedName("amount") Long amount; /** * List of zero, one, or two balance transactions that show funds withdrawn and reinstated to your * Stripe account as a result of this dispute. */ @SerializedName("balance_transactions") List balanceTransactions; /** ID of the charge that's disputed. */ @SerializedName("charge") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField charge; /** 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; /** List of eligibility types that are included in {@code enhanced_evidence}. */ @SerializedName("enhanced_eligibility_types") List enhancedEligibilityTypes; @SerializedName("evidence") Evidence evidence; @SerializedName("evidence_details") EvidenceDetails evidenceDetails; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * If true, it's still possible to refund the disputed payment. After the payment has been fully * refunded, no further funds are withdrawn from your Stripe account as a result of this dispute. */ @SerializedName("is_charge_refundable") Boolean isChargeRefundable; /** * 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; /** Network-dependent reason code for the dispute. */ @SerializedName("network_reason_code") String networkReasonCode; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code dispute}. */ @SerializedName("object") String object; /** ID of the PaymentIntent that's disputed. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; @SerializedName("payment_method_details") PaymentMethodDetails paymentMethodDetails; /** * Reason given by cardholder for dispute. Possible values are {@code bank_cannot_process}, {@code * check_returned}, {@code credit_not_processed}, {@code customer_initiated}, {@code * debit_not_authorized}, {@code duplicate}, {@code fraudulent}, {@code general}, {@code * incorrect_account_details}, {@code insufficient_funds}, {@code product_not_received}, {@code * product_unacceptable}, {@code subscription_canceled}, or {@code unrecognized}. Learn more about * dispute reasons. */ @SerializedName("reason") String reason; /** * Current status of dispute. Possible values are {@code warning_needs_response}, {@code * warning_under_review}, {@code warning_closed}, {@code needs_response}, {@code under_review}, * {@code won}, or {@code lost}. * *

One of {@code lost}, {@code needs_response}, {@code under_review}, {@code warning_closed}, * {@code warning_needs_response}, {@code warning_under_review}, or {@code won}. */ @SerializedName("status") String status; /** Get ID of expandable {@code charge} object. */ public String getCharge() { return (this.charge != null) ? this.charge.getId() : null; } public void setCharge(String id) { this.charge = ApiResource.setExpandableFieldId(id, this.charge); } /** Get expanded {@code charge}. */ public Charge getChargeObject() { return (this.charge != null) ? this.charge.getExpanded() : null; } public void setChargeObject(Charge expandableObject) { this.charge = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code paymentIntent} object. */ public String getPaymentIntent() { return (this.paymentIntent != null) ? this.paymentIntent.getId() : null; } public void setPaymentIntent(String id) { this.paymentIntent = ApiResource.setExpandableFieldId(id, this.paymentIntent); } /** Get expanded {@code paymentIntent}. */ public PaymentIntent getPaymentIntentObject() { return (this.paymentIntent != null) ? this.paymentIntent.getExpanded() : null; } public void setPaymentIntentObject(PaymentIntent expandableObject) { this.paymentIntent = new ExpandableField(expandableObject.getId(), expandableObject); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close() throws StripeException { return close((Map) null, (RequestOptions) null); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close(RequestOptions options) throws StripeException { return close((Map) null, options); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close(Map params) throws StripeException { return close(params, (RequestOptions) null); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%s/close", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Dispute.class); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close(DisputeCloseParams params) throws StripeException { return close(params, (RequestOptions) null); } /** * Closing the dispute for a charge indicates that you do not have any evidence to submit and are * essentially dismissing the dispute, acknowledging it as lost. * *

The status of the dispute will change from {@code needs_response} to {@code lost}. * Closing a dispute is irreversible. */ public Dispute close(DisputeCloseParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%s/close", 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, Dispute.class); } /** Returns a list of your disputes. */ public static DisputeCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of your disputes. */ public static DisputeCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/disputes"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, DisputeCollection.class); } /** Returns a list of your disputes. */ public static DisputeCollection list(DisputeListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of your disputes. */ public static DisputeCollection list(DisputeListParams params, RequestOptions options) throws StripeException { String path = "/v1/disputes"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, DisputeCollection.class); } /** Retrieves the dispute with the given ID. */ public static Dispute retrieve(String dispute) throws StripeException { return retrieve(dispute, (Map) null, (RequestOptions) null); } /** Retrieves the dispute with the given ID. */ public static Dispute retrieve(String dispute, RequestOptions options) throws StripeException { return retrieve(dispute, (Map) null, options); } /** Retrieves the dispute with the given ID. */ public static Dispute retrieve(String dispute, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%s", ApiResource.urlEncodeId(dispute)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Dispute.class); } /** Retrieves the dispute with the given ID. */ public static Dispute retrieve( String dispute, DisputeRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%s", ApiResource.urlEncodeId(dispute)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Dispute.class); } /** * When you get a dispute, contacting your customer is always the best first step. If that doesn’t * work, you can submit evidence to help us resolve the dispute in your favor. You can do this in * your dashboard, but if you prefer, you can * use the API to submit evidence programmatically. * *

Depending on your dispute type, different evidence fields will give you a better chance of * winning your dispute. To figure out which evidence fields to provide, see our guide to dispute types. */ @Override public Dispute update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * When you get a dispute, contacting your customer is always the best first step. If that doesn’t * work, you can submit evidence to help us resolve the dispute in your favor. You can do this in * your dashboard, but if you prefer, you can * use the API to submit evidence programmatically. * *

Depending on your dispute type, different evidence fields will give you a better chance of * winning your dispute. To figure out which evidence fields to provide, see our guide to dispute types. */ @Override public Dispute update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Dispute.class); } /** * When you get a dispute, contacting your customer is always the best first step. If that doesn’t * work, you can submit evidence to help us resolve the dispute in your favor. You can do this in * your dashboard, but if you prefer, you can * use the API to submit evidence programmatically. * *

Depending on your dispute type, different evidence fields will give you a better chance of * winning your dispute. To figure out which evidence fields to provide, see our guide to dispute types. */ public Dispute update(DisputeUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * When you get a dispute, contacting your customer is always the best first step. If that doesn’t * work, you can submit evidence to help us resolve the dispute in your favor. You can do this in * your dashboard, but if you prefer, you can * use the API to submit evidence programmatically. * *

Depending on your dispute type, different evidence fields will give you a better chance of * winning your dispute. To figure out which evidence fields to provide, see our guide to dispute types. */ public Dispute update(DisputeUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/disputes/%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, Dispute.class); } /** * For more details about Evidence, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Evidence extends StripeObject { /** * Any server or activity logs showing proof that the customer accessed or downloaded the * purchased digital product. This information should include IP addresses, corresponding * timestamps, and any detailed recorded activity. */ @SerializedName("access_activity_log") String accessActivityLog; /** The billing address provided by the customer. */ @SerializedName("billing_address") String billingAddress; /** * (ID of a file upload) Your * subscription cancellation policy, as shown to the customer. */ @SerializedName("cancellation_policy") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField cancellationPolicy; /** * An explanation of how and when the customer was shown your refund policy prior to purchase. */ @SerializedName("cancellation_policy_disclosure") String cancellationPolicyDisclosure; /** A justification for why the customer's subscription was not canceled. */ @SerializedName("cancellation_rebuttal") String cancellationRebuttal; /** * (ID of a file upload) Any * communication with the customer that you feel is relevant to your case. Examples include * emails proving that the customer received the product or service, or demonstrating their use * of or satisfaction with the product or service. */ @SerializedName("customer_communication") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField customerCommunication; /** The email address of the customer. */ @SerializedName("customer_email_address") String customerEmailAddress; /** The name of the customer. */ @SerializedName("customer_name") String customerName; /** The IP address that the customer used when making the purchase. */ @SerializedName("customer_purchase_ip") String customerPurchaseIp; /** * (ID of a file upload) A relevant * document or contract showing the customer's signature. */ @SerializedName("customer_signature") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField customerSignature; /** * (ID of a file upload) Documentation * for the prior charge that can uniquely identify the charge, such as a receipt, shipping * label, work order, etc. This document should be paired with a similar document from the * disputed payment that proves the two payments are separate. */ @SerializedName("duplicate_charge_documentation") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField duplicateChargeDocumentation; /** * An explanation of the difference between the disputed charge versus the prior charge that * appears to be a duplicate. */ @SerializedName("duplicate_charge_explanation") String duplicateChargeExplanation; /** * The Stripe ID for the prior charge which appears to be a duplicate of the disputed charge. */ @SerializedName("duplicate_charge_id") String duplicateChargeId; @SerializedName("enhanced_evidence") EnhancedEvidence enhancedEvidence; /** A description of the product or service that was sold. */ @SerializedName("product_description") String productDescription; /** * (ID of a file upload) Any receipt or * message sent to the customer notifying them of the charge. */ @SerializedName("receipt") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField receipt; /** * (ID of a file upload) Your refund * policy, as shown to the customer. */ @SerializedName("refund_policy") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField refundPolicy; /** * Documentation demonstrating that the customer was shown your refund policy prior to purchase. */ @SerializedName("refund_policy_disclosure") String refundPolicyDisclosure; /** A justification for why the customer is not entitled to a refund. */ @SerializedName("refund_refusal_explanation") String refundRefusalExplanation; /** * The date on which the customer received or began receiving the purchased service, in a clear * human-readable format. */ @SerializedName("service_date") String serviceDate; /** * (ID of a file upload) Documentation * showing proof that a service was provided to the customer. This could include a copy of a * signed contract, work order, or other form of written agreement. */ @SerializedName("service_documentation") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField serviceDocumentation; /** * The address to which a physical product was shipped. You should try to include as complete * address information as possible. */ @SerializedName("shipping_address") String shippingAddress; /** * The delivery service that shipped a physical product, such as Fedex, UPS, USPS, etc. If * multiple carriers were used for this purchase, please separate them with commas. */ @SerializedName("shipping_carrier") String shippingCarrier; /** * The date on which a physical product began its route to the shipping address, in a clear * human-readable format. */ @SerializedName("shipping_date") String shippingDate; /** * (ID of a file upload) Documentation * showing proof that a product was shipped to the customer at the same address the customer * provided to you. This could include a copy of the shipment receipt, shipping label, etc. It * should show the customer's full shipping address, if possible. */ @SerializedName("shipping_documentation") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField shippingDocumentation; /** * The tracking number for a physical product, obtained from the delivery service. If multiple * tracking numbers were generated for this purchase, please separate them with commas. */ @SerializedName("shipping_tracking_number") String shippingTrackingNumber; /** * (ID of a file upload) Any additional * evidence or statements. */ @SerializedName("uncategorized_file") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField uncategorizedFile; /** Any additional evidence or statements. */ @SerializedName("uncategorized_text") String uncategorizedText; /** Get ID of expandable {@code cancellationPolicy} object. */ public String getCancellationPolicy() { return (this.cancellationPolicy != null) ? this.cancellationPolicy.getId() : null; } public void setCancellationPolicy(String id) { this.cancellationPolicy = ApiResource.setExpandableFieldId(id, this.cancellationPolicy); } /** Get expanded {@code cancellationPolicy}. */ public File getCancellationPolicyObject() { return (this.cancellationPolicy != null) ? this.cancellationPolicy.getExpanded() : null; } public void setCancellationPolicyObject(File expandableObject) { this.cancellationPolicy = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code customerCommunication} object. */ public String getCustomerCommunication() { return (this.customerCommunication != null) ? this.customerCommunication.getId() : null; } public void setCustomerCommunication(String id) { this.customerCommunication = ApiResource.setExpandableFieldId(id, this.customerCommunication); } /** Get expanded {@code customerCommunication}. */ public File getCustomerCommunicationObject() { return (this.customerCommunication != null) ? this.customerCommunication.getExpanded() : null; } public void setCustomerCommunicationObject(File expandableObject) { this.customerCommunication = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code customerSignature} object. */ public String getCustomerSignature() { return (this.customerSignature != null) ? this.customerSignature.getId() : null; } public void setCustomerSignature(String id) { this.customerSignature = ApiResource.setExpandableFieldId(id, this.customerSignature); } /** Get expanded {@code customerSignature}. */ public File getCustomerSignatureObject() { return (this.customerSignature != null) ? this.customerSignature.getExpanded() : null; } public void setCustomerSignatureObject(File expandableObject) { this.customerSignature = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code duplicateChargeDocumentation} object. */ public String getDuplicateChargeDocumentation() { return (this.duplicateChargeDocumentation != null) ? this.duplicateChargeDocumentation.getId() : null; } public void setDuplicateChargeDocumentation(String id) { this.duplicateChargeDocumentation = ApiResource.setExpandableFieldId(id, this.duplicateChargeDocumentation); } /** Get expanded {@code duplicateChargeDocumentation}. */ public File getDuplicateChargeDocumentationObject() { return (this.duplicateChargeDocumentation != null) ? this.duplicateChargeDocumentation.getExpanded() : null; } public void setDuplicateChargeDocumentationObject(File expandableObject) { this.duplicateChargeDocumentation = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code receipt} object. */ public String getReceipt() { return (this.receipt != null) ? this.receipt.getId() : null; } public void setReceipt(String id) { this.receipt = ApiResource.setExpandableFieldId(id, this.receipt); } /** Get expanded {@code receipt}. */ public File getReceiptObject() { return (this.receipt != null) ? this.receipt.getExpanded() : null; } public void setReceiptObject(File expandableObject) { this.receipt = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code refundPolicy} object. */ public String getRefundPolicy() { return (this.refundPolicy != null) ? this.refundPolicy.getId() : null; } public void setRefundPolicy(String id) { this.refundPolicy = ApiResource.setExpandableFieldId(id, this.refundPolicy); } /** Get expanded {@code refundPolicy}. */ public File getRefundPolicyObject() { return (this.refundPolicy != null) ? this.refundPolicy.getExpanded() : null; } public void setRefundPolicyObject(File expandableObject) { this.refundPolicy = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code serviceDocumentation} object. */ public String getServiceDocumentation() { return (this.serviceDocumentation != null) ? this.serviceDocumentation.getId() : null; } public void setServiceDocumentation(String id) { this.serviceDocumentation = ApiResource.setExpandableFieldId(id, this.serviceDocumentation); } /** Get expanded {@code serviceDocumentation}. */ public File getServiceDocumentationObject() { return (this.serviceDocumentation != null) ? this.serviceDocumentation.getExpanded() : null; } public void setServiceDocumentationObject(File expandableObject) { this.serviceDocumentation = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code shippingDocumentation} object. */ public String getShippingDocumentation() { return (this.shippingDocumentation != null) ? this.shippingDocumentation.getId() : null; } public void setShippingDocumentation(String id) { this.shippingDocumentation = ApiResource.setExpandableFieldId(id, this.shippingDocumentation); } /** Get expanded {@code shippingDocumentation}. */ public File getShippingDocumentationObject() { return (this.shippingDocumentation != null) ? this.shippingDocumentation.getExpanded() : null; } public void setShippingDocumentationObject(File expandableObject) { this.shippingDocumentation = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code uncategorizedFile} object. */ public String getUncategorizedFile() { return (this.uncategorizedFile != null) ? this.uncategorizedFile.getId() : null; } public void setUncategorizedFile(String id) { this.uncategorizedFile = ApiResource.setExpandableFieldId(id, this.uncategorizedFile); } /** Get expanded {@code uncategorizedFile}. */ public File getUncategorizedFileObject() { return (this.uncategorizedFile != null) ? this.uncategorizedFile.getExpanded() : null; } public void setUncategorizedFileObject(File expandableObject) { this.uncategorizedFile = new ExpandableField(expandableObject.getId(), expandableObject); } /** * For more details about EnhancedEvidence, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class EnhancedEvidence extends StripeObject { @SerializedName("visa_compelling_evidence_3") VisaCompellingEvidence3 visaCompellingEvidence3; @SerializedName("visa_compliance") VisaCompliance visaCompliance; /** * For more details about VisaCompellingEvidence3, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class VisaCompellingEvidence3 extends StripeObject { /** Disputed transaction details for Visa Compelling Evidence 3.0 evidence submission. */ @SerializedName("disputed_transaction") DisputedTransaction disputedTransaction; /** * List of exactly two prior undisputed transaction objects for Visa Compelling Evidence 3.0 * evidence submission. */ @SerializedName("prior_undisputed_transactions") List priorUndisputedTransactions; /** * For more details about DisputedTransaction, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class DisputedTransaction extends StripeObject { /** * User Account ID used to log into business platform. Must be recognizable by the user. */ @SerializedName("customer_account_id") String customerAccountId; /** * Unique identifier of the cardholder’s device derived from a combination of at least two * hardware and software attributes. Must be at least 20 characters. */ @SerializedName("customer_device_fingerprint") String customerDeviceFingerprint; /** * Unique identifier of the cardholder’s device such as a device serial number (e.g., * International Mobile Equipment Identity [IMEI]). Must be at least 15 characters. */ @SerializedName("customer_device_id") String customerDeviceId; /** The email address of the customer. */ @SerializedName("customer_email_address") String customerEmailAddress; /** The IP address that the customer used when making the purchase. */ @SerializedName("customer_purchase_ip") String customerPurchaseIp; /** * Categorization of disputed payment. * *

One of {@code merchandise}, or {@code services}. */ @SerializedName("merchandise_or_services") String merchandiseOrServices; /** A description of the product or service that was sold. */ @SerializedName("product_description") String productDescription; /** * The address to which a physical product was shipped. All fields are required for Visa * Compelling Evidence 3.0 evidence submission. */ @SerializedName("shipping_address") ShippingAddress shippingAddress; /** * For more details about ShippingAddress, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ShippingAddress 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, county, province, or region. */ @SerializedName("state") String state; } } /** * For more details about PriorUndisputedTransaction, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class PriorUndisputedTransaction extends StripeObject { /** Stripe charge ID for the Visa Compelling Evidence 3.0 eligible prior charge. */ @SerializedName("charge") String charge; /** * User Account ID used to log into business platform. Must be recognizable by the user. */ @SerializedName("customer_account_id") String customerAccountId; /** * Unique identifier of the cardholder’s device derived from a combination of at least two * hardware and software attributes. Must be at least 20 characters. */ @SerializedName("customer_device_fingerprint") String customerDeviceFingerprint; /** * Unique identifier of the cardholder’s device such as a device serial number (e.g., * International Mobile Equipment Identity [IMEI]). Must be at least 15 characters. */ @SerializedName("customer_device_id") String customerDeviceId; /** The email address of the customer. */ @SerializedName("customer_email_address") String customerEmailAddress; /** The IP address that the customer used when making the purchase. */ @SerializedName("customer_purchase_ip") String customerPurchaseIp; /** A description of the product or service that was sold. */ @SerializedName("product_description") String productDescription; /** * The address to which a physical product was shipped. All fields are required for Visa * Compelling Evidence 3.0 evidence submission. */ @SerializedName("shipping_address") ShippingAddress shippingAddress; /** * For more details about ShippingAddress, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ShippingAddress 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, county, province, or region. */ @SerializedName("state") String state; } } } /** * For more details about VisaCompliance, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class VisaCompliance extends StripeObject { /** * A field acknowledging the fee incurred when countering a Visa compliance dispute. If this * field is set to true, evidence can be submitted for the compliance dispute. Stripe * collects a 500 USD (or local equivalent) amount to cover the network costs associated * with resolving compliance disputes. Stripe refunds the 500 USD network fee if you win the * dispute. */ @SerializedName("fee_acknowledged") Boolean feeAcknowledged; } } } /** * For more details about EvidenceDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class EvidenceDetails extends StripeObject { /** * Date by which evidence must be submitted in order to successfully challenge dispute. Will be * 0 if the customer's bank or credit card company doesn't allow a response for this particular * dispute. */ @SerializedName("due_by") Long dueBy; @SerializedName("enhanced_eligibility") EnhancedEligibility enhancedEligibility; /** Whether evidence has been staged for this dispute. */ @SerializedName("has_evidence") Boolean hasEvidence; /** * Whether the last evidence submission was submitted past the due date. Defaults to {@code * false} if no evidence submissions have occurred. If {@code true}, then delivery of the latest * evidence is not guaranteed. */ @SerializedName("past_due") Boolean pastDue; /** * The number of times evidence has been submitted. Typically, you may only submit evidence * once. */ @SerializedName("submission_count") Long submissionCount; /** * For more details about EnhancedEligibility, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class EnhancedEligibility extends StripeObject { @SerializedName("visa_compelling_evidence_3") VisaCompellingEvidence3 visaCompellingEvidence3; @SerializedName("visa_compliance") VisaCompliance visaCompliance; /** * For more details about VisaCompellingEvidence3, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class VisaCompellingEvidence3 extends StripeObject { /** * List of actions required to qualify dispute for Visa Compelling Evidence 3.0 evidence * submission. */ @SerializedName("required_actions") List requiredActions; /** * Visa Compelling Evidence 3.0 eligibility status. * *

One of {@code not_qualified}, {@code qualified}, or {@code requires_action}. */ @SerializedName("status") String status; } /** * For more details about VisaCompliance, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class VisaCompliance extends StripeObject { /** * Visa compliance eligibility status. * *

One of {@code fee_acknowledged}, or {@code requires_fee_acknowledgement}. */ @SerializedName("status") String status; } } } /** * For more details about PaymentMethodDetails, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class PaymentMethodDetails extends StripeObject { @SerializedName("amazon_pay") AmazonPay amazonPay; @SerializedName("card") Card card; @SerializedName("klarna") Klarna klarna; @SerializedName("paypal") Paypal paypal; /** * Payment method type. * *

One of {@code amazon_pay}, {@code card}, {@code klarna}, or {@code paypal}. */ @SerializedName("type") String type; /** * For more details about AmazonPay, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AmazonPay extends StripeObject { /** * The AmazonPay dispute type, chargeback or claim * *

One of {@code chargeback}, or {@code claim}. */ @SerializedName("dispute_type") String disputeType; } /** * For more details about Card, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Card extends StripeObject { /** * Card brand. Can be {@code amex}, {@code diners}, {@code discover}, {@code eftpos_au}, * {@code jcb}, {@code link}, {@code mastercard}, {@code unionpay}, {@code visa}, or {@code * unknown}. */ @SerializedName("brand") String brand; /** * The type of dispute opened. Different case types may have varying fees and financial * impact. * *

One of {@code chargeback}, or {@code inquiry}. */ @SerializedName("case_type") String caseType; /** * The card network's specific dispute reason code, which maps to one of Stripe's primary * dispute categories to simplify response guidance. The Network code map * lists all available dispute reason codes by network. */ @SerializedName("network_reason_code") String networkReasonCode; } /** * For more details about Klarna, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Klarna extends StripeObject { /** The reason for the dispute as defined by Klarna. */ @SerializedName("reason_code") String reasonCode; } /** * For more details about Paypal, please refer to the API * Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Paypal extends StripeObject { /** The ID of the dispute in PayPal. */ @SerializedName("case_id") String caseId; /** The reason for the dispute as defined by PayPal. */ @SerializedName("reason_code") String reasonCode; } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(charge, responseGetter); trySetResponseGetter(evidence, responseGetter); trySetResponseGetter(evidenceDetails, responseGetter); trySetResponseGetter(paymentIntent, responseGetter); trySetResponseGetter(paymentMethodDetails, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy