com.stripe.model.issuing.Dispute Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model.issuing;
import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.BalanceTransaction;
import com.stripe.model.BalanceTransactionSource;
import com.stripe.model.ExpandableField;
import com.stripe.model.File;
import com.stripe.model.MetadataStore;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiMode;
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.issuing.DisputeCreateParams;
import com.stripe.param.issuing.DisputeListParams;
import com.stripe.param.issuing.DisputeRetrieveParams;
import com.stripe.param.issuing.DisputeSubmitParams;
import com.stripe.param.issuing.DisputeUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* As a card issuer, you can dispute transactions that
* the cardholder does not recognize, suspects to be fraudulent, or has other issues with.
*
* Related guide: Issuing
* disputes
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class Dispute extends ApiResource
implements MetadataStore, BalanceTransactionSource {
/**
* Disputed amount in the card's currency and in the smallest currency unit. Usually the
* amount of the {@code transaction}, but can differ (usually because of currency fluctuation).
*/
@SerializedName("amount")
Long amount;
/** List of balance transactions associated with the dispute. */
@SerializedName("balance_transactions")
List balanceTransactions;
/** Time at which the object was created. Measured in seconds since the Unix epoch. */
@SerializedName("created")
Long created;
/** The currency the {@code transaction} was made in. */
@SerializedName("currency")
String currency;
@SerializedName("evidence")
Evidence evidence;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* 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;
/**
* The enum that describes the dispute loss outcome. If the dispute is not lost, this field will
* be absent. New enum values may be added in the future, so be sure to handle unknown values.
*
* One of {@code cardholder_authentication_issuer_liability}, {@code
* eci5_token_transaction_with_tavv}, {@code excess_disputes_in_timeframe}, {@code
* has_not_met_the_minimum_dispute_amount_requirements}, {@code invalid_duplicate_dispute}, {@code
* invalid_incorrect_amount_dispute}, {@code invalid_no_authorization}, {@code
* invalid_use_of_disputes}, {@code merchandise_delivered_or_shipped}, {@code
* merchandise_or_service_as_described}, {@code not_cancelled}, {@code other}, {@code
* refund_issued}, {@code submitted_beyond_allowable_time_limit}, {@code
* transaction_3ds_required}, {@code transaction_approved_after_prior_fraud_dispute}, {@code
* transaction_authorized}, {@code transaction_electronically_read}, {@code
* transaction_qualifies_for_visa_easy_payment_service}, or {@code transaction_unattended}.
*/
@SerializedName("loss_reason")
String lossReason;
/**
* 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;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code issuing.dispute}.
*/
@SerializedName("object")
String object;
/**
* Current status of the dispute.
*
*
One of {@code expired}, {@code lost}, {@code submitted}, {@code unsubmitted}, or {@code
* won}.
*/
@SerializedName("status")
String status;
/** The transaction being disputed. */
@SerializedName("transaction")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField transaction;
/**
* Treasury details related to this dispute if
* it was created on a [FinancialAccount](/docs/api/treasury/financial_accounts
*/
@SerializedName("treasury")
Treasury treasury;
/** Get ID of expandable {@code transaction} object. */
public String getTransaction() {
return (this.transaction != null) ? this.transaction.getId() : null;
}
public void setTransaction(String id) {
this.transaction = ApiResource.setExpandableFieldId(id, this.transaction);
}
/** Get expanded {@code transaction}. */
public Transaction getTransactionObject() {
return (this.transaction != null) ? this.transaction.getExpanded() : null;
}
public void setTransactionObject(Transaction expandableObject) {
this.transaction = new ExpandableField(expandableObject.getId(), expandableObject);
}
/**
* Creates an Issuing {@code Dispute} object. Individual pieces of evidence within the {@code
* evidence} object are optional at this point. Stripe only validates that required evidence is
* present during submission. Refer to Dispute
* reasons and evidence for more details about evidence requirements.
*/
public static Dispute create(Map params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates an Issuing {@code Dispute} object. Individual pieces of evidence within the {@code
* evidence} object are optional at this point. Stripe only validates that required evidence is
* present during submission. Refer to Dispute
* reasons and evidence for more details about evidence requirements.
*/
public static Dispute create(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/issuing/disputes";
ApiRequest request =
new ApiRequest(
BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1);
return getGlobalResponseGetter().request(request, Dispute.class);
}
/**
* Creates an Issuing {@code Dispute} object. Individual pieces of evidence within the {@code
* evidence} object are optional at this point. Stripe only validates that required evidence is
* present during submission. Refer to Dispute
* reasons and evidence for more details about evidence requirements.
*/
public static Dispute create(DisputeCreateParams params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates an Issuing {@code Dispute} object. Individual pieces of evidence within the {@code
* evidence} object are optional at this point. Stripe only validates that required evidence is
* present during submission. Refer to Dispute
* reasons and evidence for more details about evidence requirements.
*/
public static Dispute create(DisputeCreateParams params, RequestOptions options)
throws StripeException {
String path = "/v1/issuing/disputes";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options,
ApiMode.V1);
return getGlobalResponseGetter().request(request, Dispute.class);
}
/**
* Returns a list of Issuing {@code Dispute} objects. The objects are sorted in descending order
* by creation date, with the most recently created object appearing first.
*/
public static DisputeCollection list(Map params) throws StripeException {
return list(params, (RequestOptions) null);
}
/**
* Returns a list of Issuing {@code Dispute} objects. The objects are sorted in descending order
* by creation date, with the most recently created object appearing first.
*/
public static DisputeCollection list(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/issuing/disputes";
ApiRequest request =
new ApiRequest(
BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options, ApiMode.V1);
return getGlobalResponseGetter().request(request, DisputeCollection.class);
}
/**
* Returns a list of Issuing {@code Dispute} objects. The objects are sorted in descending order
* by creation date, with the most recently created object appearing first.
*/
public static DisputeCollection list(DisputeListParams params) throws StripeException {
return list(params, (RequestOptions) null);
}
/**
* Returns a list of Issuing {@code Dispute} objects. The objects are sorted in descending order
* by creation date, with the most recently created object appearing first.
*/
public static DisputeCollection list(DisputeListParams params, RequestOptions options)
throws StripeException {
String path = "/v1/issuing/disputes";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options,
ApiMode.V1);
return getGlobalResponseGetter().request(request, DisputeCollection.class);
}
/** Retrieves an Issuing {@code Dispute} object. */
public static Dispute retrieve(String dispute) throws StripeException {
return retrieve(dispute, (Map) null, (RequestOptions) null);
}
/** Retrieves an Issuing {@code Dispute} object. */
public static Dispute retrieve(String dispute, RequestOptions options) throws StripeException {
return retrieve(dispute, (Map) null, options);
}
/** Retrieves an Issuing {@code Dispute} object. */
public static Dispute retrieve(String dispute, Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/issuing/disputes/%s", ApiResource.urlEncodeId(dispute));
ApiRequest request =
new ApiRequest(
BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options, ApiMode.V1);
return getGlobalResponseGetter().request(request, Dispute.class);
}
/** Retrieves an Issuing {@code Dispute} object. */
public static Dispute retrieve(
String dispute, DisputeRetrieveParams params, RequestOptions options) throws StripeException {
String path = String.format("/v1/issuing/disputes/%s", ApiResource.urlEncodeId(dispute));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options,
ApiMode.V1);
return getGlobalResponseGetter().request(request, Dispute.class);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit() throws StripeException {
return submit((Map) null, (RequestOptions) null);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit(RequestOptions options) throws StripeException {
return submit((Map) null, options);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit(Map params) throws StripeException {
return submit(params, (RequestOptions) null);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit(Map params, RequestOptions options) throws StripeException {
String path =
String.format("/v1/issuing/disputes/%s/submit", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(
BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1);
return getResponseGetter().request(request, Dispute.class);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit(DisputeSubmitParams params) throws StripeException {
return submit(params, (RequestOptions) null);
}
/**
* Submits an Issuing {@code Dispute} to the card network. Stripe validates that all evidence
* fields required for the dispute’s reason are present. For more details, see Dispute
* reasons and evidence.
*/
public Dispute submit(DisputeSubmitParams params, RequestOptions options) throws StripeException {
String path =
String.format("/v1/issuing/disputes/%s/submit", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options,
ApiMode.V1);
return getResponseGetter().request(request, Dispute.class);
}
/**
* Updates the specified Issuing {@code Dispute} object by setting the values of the parameters
* passed. Any parameters not provided will be left unchanged. Properties on the {@code evidence}
* object can be unset by passing in an empty string.
*/
@Override
public Dispute update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates the specified Issuing {@code Dispute} object by setting the values of the parameters
* passed. Any parameters not provided will be left unchanged. Properties on the {@code evidence}
* object can be unset by passing in an empty string.
*/
@Override
public Dispute update(Map params, RequestOptions options) throws StripeException {
String path = String.format("/v1/issuing/disputes/%s", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(
BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options, ApiMode.V1);
return getResponseGetter().request(request, Dispute.class);
}
/**
* Updates the specified Issuing {@code Dispute} object by setting the values of the parameters
* passed. Any parameters not provided will be left unchanged. Properties on the {@code evidence}
* object can be unset by passing in an empty string.
*/
public Dispute update(DisputeUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates the specified Issuing {@code Dispute} object by setting the values of the parameters
* passed. Any parameters not provided will be left unchanged. Properties on the {@code evidence}
* object can be unset by passing in an empty string.
*/
public Dispute update(DisputeUpdateParams params, RequestOptions options) throws StripeException {
String path = String.format("/v1/issuing/disputes/%s", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options,
ApiMode.V1);
return getResponseGetter().request(request, Dispute.class);
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Evidence extends StripeObject {
@SerializedName("canceled")
Canceled canceled;
@SerializedName("duplicate")
Duplicate duplicate;
@SerializedName("fraudulent")
Fraudulent fraudulent;
@SerializedName("merchandise_not_as_described")
MerchandiseNotAsDescribed merchandiseNotAsDescribed;
@SerializedName("no_valid_authorization")
NoValidAuthorization noValidAuthorization;
@SerializedName("not_received")
NotReceived notReceived;
@SerializedName("other")
Other other;
/**
* The reason for filing the dispute. Its value will match the field containing the evidence.
*
* One of {@code canceled}, {@code duplicate}, {@code fraudulent}, {@code
* merchandise_not_as_described}, {@code no_valid_authorization}, {@code not_received}, {@code
* other}, or {@code service_not_as_described}.
*/
@SerializedName("reason")
String reason;
@SerializedName("service_not_as_described")
ServiceNotAsDescribed serviceNotAsDescribed;
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Canceled extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Date when order was canceled. */
@SerializedName("canceled_at")
Long canceledAt;
/** Whether the cardholder was provided with a cancellation policy. */
@SerializedName("cancellation_policy_provided")
Boolean cancellationPolicyProvided;
/** Reason for canceling the order. */
@SerializedName("cancellation_reason")
String cancellationReason;
/** Date when the cardholder expected to receive the product. */
@SerializedName("expected_at")
Long expectedAt;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Description of the merchandise or service that was purchased. */
@SerializedName("product_description")
String productDescription;
/**
* Whether the product was a merchandise or service.
*
* One of {@code merchandise}, or {@code service}.
*/
@SerializedName("product_type")
String productType;
/**
* Result of cardholder's attempt to return the product.
*
*
One of {@code merchant_rejected}, or {@code successful}.
*/
@SerializedName("return_status")
String returnStatus;
/** Date when the product was returned or attempted to be returned. */
@SerializedName("returned_at")
Long returnedAt;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Duplicate extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/**
* (ID of a file upload) Copy of the
* card statement showing that the product had already been paid for.
*/
@SerializedName("card_statement")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField cardStatement;
/**
* (ID of a file upload) Copy of the
* receipt showing that the product had been paid for in cash.
*/
@SerializedName("cash_receipt")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField cashReceipt;
/**
* (ID of a file upload) Image of the
* front and back of the check that was used to pay for the product.
*/
@SerializedName("check_image")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField checkImage;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/**
* Transaction (e.g., ipi_...) that the disputed transaction is a duplicate of. Of the two or
* more transactions that are copies of each other, this is original undisputed one.
*/
@SerializedName("original_transaction")
String originalTransaction;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code cardStatement} object. */
public String getCardStatement() {
return (this.cardStatement != null) ? this.cardStatement.getId() : null;
}
public void setCardStatement(String id) {
this.cardStatement = ApiResource.setExpandableFieldId(id, this.cardStatement);
}
/** Get expanded {@code cardStatement}. */
public File getCardStatementObject() {
return (this.cardStatement != null) ? this.cardStatement.getExpanded() : null;
}
public void setCardStatementObject(File expandableObject) {
this.cardStatement = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code cashReceipt} object. */
public String getCashReceipt() {
return (this.cashReceipt != null) ? this.cashReceipt.getId() : null;
}
public void setCashReceipt(String id) {
this.cashReceipt = ApiResource.setExpandableFieldId(id, this.cashReceipt);
}
/** Get expanded {@code cashReceipt}. */
public File getCashReceiptObject() {
return (this.cashReceipt != null) ? this.cashReceipt.getExpanded() : null;
}
public void setCashReceiptObject(File expandableObject) {
this.cashReceipt = new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Get ID of expandable {@code checkImage} object. */
public String getCheckImage() {
return (this.checkImage != null) ? this.checkImage.getId() : null;
}
public void setCheckImage(String id) {
this.checkImage = ApiResource.setExpandableFieldId(id, this.checkImage);
}
/** Get expanded {@code checkImage}. */
public File getCheckImageObject() {
return (this.checkImage != null) ? this.checkImage.getExpanded() : null;
}
public void setCheckImageObject(File expandableObject) {
this.checkImage = new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Fraudulent extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class MerchandiseNotAsDescribed extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Date when the product was received. */
@SerializedName("received_at")
Long receivedAt;
/** Description of the cardholder's attempt to return the product. */
@SerializedName("return_description")
String returnDescription;
/**
* Result of cardholder's attempt to return the product.
*
* One of {@code merchant_rejected}, or {@code successful}.
*/
@SerializedName("return_status")
String returnStatus;
/** Date when the product was returned or attempted to be returned. */
@SerializedName("returned_at")
Long returnedAt;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class NoValidAuthorization extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class NotReceived extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Date when the cardholder expected to receive the product. */
@SerializedName("expected_at")
Long expectedAt;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Description of the merchandise or service that was purchased. */
@SerializedName("product_description")
String productDescription;
/**
* Whether the product was a merchandise or service.
*
* One of {@code merchandise}, or {@code service}.
*/
@SerializedName("product_type")
String productType;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Other extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Description of the merchandise or service that was purchased. */
@SerializedName("product_description")
String productDescription;
/**
* Whether the product was a merchandise or service.
*
* One of {@code merchandise}, or {@code service}.
*/
@SerializedName("product_type")
String productType;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class ServiceNotAsDescribed extends StripeObject {
/**
* (ID of a file upload) Additional
* documentation supporting the dispute.
*/
@SerializedName("additional_documentation")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField additionalDocumentation;
/** Date when order was canceled. */
@SerializedName("canceled_at")
Long canceledAt;
/** Reason for canceling the order. */
@SerializedName("cancellation_reason")
String cancellationReason;
/** Explanation of why the cardholder is disputing this transaction. */
@SerializedName("explanation")
String explanation;
/** Date when the product was received. */
@SerializedName("received_at")
Long receivedAt;
/** Get ID of expandable {@code additionalDocumentation} object. */
public String getAdditionalDocumentation() {
return (this.additionalDocumentation != null) ? this.additionalDocumentation.getId() : null;
}
public void setAdditionalDocumentation(String id) {
this.additionalDocumentation =
ApiResource.setExpandableFieldId(id, this.additionalDocumentation);
}
/** Get expanded {@code additionalDocumentation}. */
public File getAdditionalDocumentationObject() {
return (this.additionalDocumentation != null)
? this.additionalDocumentation.getExpanded()
: null;
}
public void setAdditionalDocumentationObject(File expandableObject) {
this.additionalDocumentation =
new ExpandableField(expandableObject.getId(), expandableObject);
}
}
}
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Treasury extends StripeObject {
/**
* The Treasury DebitReversal
* representing this Issuing dispute
*/
@SerializedName("debit_reversal")
String debitReversal;
/**
* The Treasury ReceivedDebit
* that is being disputed.
*/
@SerializedName("received_debit")
String receivedDebit;
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(evidence, responseGetter);
trySetResponseGetter(transaction, responseGetter);
trySetResponseGetter(treasury, responseGetter);
}
}