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.Stripe;
import com.stripe.exception.StripeException;
import com.stripe.net.ApiResource;
import com.stripe.net.RequestOptions;
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're given the opportunity to respond to the dispute with evidence that shows that the charge
* is legitimate. You can find more information about the dispute process in our Disputes and Fraud documentation.
*
* 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 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 was 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;
@SerializedName("evidence")
Evidence evidence;
@SerializedName("evidence_details")
EvidenceDetails evidenceDetails;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* If true, it is still possible to refund the disputed payment. Once the payment has been fully
* refunded, no further funds will be 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 was disputed. */
@SerializedName("payment_intent")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField paymentIntent;
/**
* 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}. Read 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 charge_refunded}, {@code won}, or {@code lost}.
*
* One of {@code charge_refunded}, {@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 url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s/close", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(ApiResource.RequestMethod.POST, url, params, Dispute.class, 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(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 url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s/close", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(ApiResource.RequestMethod.POST, url, params, Dispute.class, options);
}
/** 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 url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/disputes");
return ApiResource.requestCollection(url, params, DisputeCollection.class, options);
}
/** 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 url = ApiResource.fullUrl(Stripe.getApiBase(), options, "/v1/disputes");
return ApiResource.requestCollection(url, params, DisputeCollection.class, options);
}
/** 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 url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s", ApiResource.urlEncodeId(dispute)));
return ApiResource.request(ApiResource.RequestMethod.GET, url, params, Dispute.class, options);
}
/** Retrieves the dispute with the given ID. */
public static Dispute retrieve(
String dispute, DisputeRetrieveParams params, RequestOptions options) throws StripeException {
String url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s", ApiResource.urlEncodeId(dispute)));
return ApiResource.request(ApiResource.RequestMethod.GET, url, params, Dispute.class, options);
}
/**
* 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 url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(ApiResource.RequestMethod.POST, url, params, Dispute.class, options);
}
/**
* 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 url =
ApiResource.fullUrl(
Stripe.getApiBase(),
options,
String.format("/v1/disputes/%s", ApiResource.urlEncodeId(this.getId())));
return ApiResource.request(ApiResource.RequestMethod.POST, url, params, Dispute.class, options);
}
@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;
/** 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);
}
}
@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;
/** 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;
}
}