com.stripe.model.Mandate 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.MandateRetrieveParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* A Mandate is a record of the permission that your customer gives you to debit their payment
* method.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class Mandate extends ApiResource implements HasId {
@SerializedName("customer_acceptance")
CustomerAcceptance customerAcceptance;
/** 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;
@SerializedName("multi_use")
MultiUse multiUse;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code mandate}.
*/
@SerializedName("object")
String object;
/** The account (if any) that the mandate is intended for. */
@SerializedName("on_behalf_of")
String onBehalfOf;
/** ID of the payment method associated with this mandate. */
@SerializedName("payment_method")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField paymentMethod;
@SerializedName("payment_method_details")
PaymentMethodDetails paymentMethodDetails;
@SerializedName("single_use")
SingleUse singleUse;
/**
* The mandate status indicates whether or not you can use it to initiate a payment.
*
* One of {@code active}, {@code inactive}, or {@code pending}.
*/
@SerializedName("status")
String status;
/**
* The type of the mandate.
*
*
One of {@code multi_use}, or {@code single_use}.
*/
@SerializedName("type")
String type;
/** Get ID of expandable {@code paymentMethod} object. */
public String getPaymentMethod() {
return (this.paymentMethod != null) ? this.paymentMethod.getId() : null;
}
public void setPaymentMethod(String id) {
this.paymentMethod = ApiResource.setExpandableFieldId(id, this.paymentMethod);
}
/** Get expanded {@code paymentMethod}. */
public PaymentMethod getPaymentMethodObject() {
return (this.paymentMethod != null) ? this.paymentMethod.getExpanded() : null;
}
public void setPaymentMethodObject(PaymentMethod expandableObject) {
this.paymentMethod =
new ExpandableField(expandableObject.getId(), expandableObject);
}
/** Retrieves a Mandate object. */
public static Mandate retrieve(String mandate) throws StripeException {
return retrieve(mandate, (Map) null, (RequestOptions) null);
}
/** Retrieves a Mandate object. */
public static Mandate retrieve(String mandate, RequestOptions options) throws StripeException {
return retrieve(mandate, (Map) null, options);
}
/** Retrieves a Mandate object. */
public static Mandate retrieve(String mandate, Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/mandates/%s", ApiResource.urlEncodeId(mandate));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, Mandate.class);
}
/** Retrieves a Mandate object. */
public static Mandate retrieve(
String mandate, MandateRetrieveParams params, RequestOptions options) throws StripeException {
String path = String.format("/v1/mandates/%s", ApiResource.urlEncodeId(mandate));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, Mandate.class);
}
/**
* For more details about CustomerAcceptance, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class CustomerAcceptance extends StripeObject {
/** The time that the customer accepts the mandate. */
@SerializedName("accepted_at")
Long acceptedAt;
@SerializedName("offline")
Offline offline;
@SerializedName("online")
Online online;
/**
* The mandate includes the type of customer acceptance information, such as: {@code online} or
* {@code offline}.
*
* One of {@code offline}, or {@code online}.
*/
@SerializedName("type")
String type;
/**
* For more details about Offline, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Offline extends StripeObject {}
/**
* For more details about Online, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Online extends StripeObject {
/** The customer accepts the mandate from this IP address. */
@SerializedName("ip_address")
String ipAddress;
/** The customer accepts the mandate using the user agent of the browser. */
@SerializedName("user_agent")
String userAgent;
}
}
/**
* For more details about MultiUse, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class MultiUse extends StripeObject {}
/**
* For more details about PaymentMethodDetails, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class PaymentMethodDetails extends StripeObject {
@SerializedName("acss_debit")
AcssDebit acssDebit;
@SerializedName("amazon_pay")
AmazonPay amazonPay;
@SerializedName("au_becs_debit")
AuBecsDebit auBecsDebit;
@SerializedName("bacs_debit")
BacsDebit bacsDebit;
@SerializedName("card")
Card card;
@SerializedName("cashapp")
Cashapp cashapp;
@SerializedName("kakao_pay")
KakaoPay kakaoPay;
@SerializedName("kr_card")
KrCard krCard;
@SerializedName("link")
Link link;
@SerializedName("paypal")
Paypal paypal;
@SerializedName("payto")
Payto payto;
@SerializedName("revolut_pay")
RevolutPay revolutPay;
@SerializedName("sepa_debit")
SepaDebit sepaDebit;
/**
* This mandate corresponds with a specific payment method type. The {@code
* payment_method_details} includes an additional hash with the same name and contains mandate
* information that's specific to that payment method.
*/
@SerializedName("type")
String type;
@SerializedName("us_bank_account")
UsBankAccount usBankAccount;
/**
* For more details about AcssDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AcssDebit extends StripeObject {
/** List of Stripe products where this mandate can be selected automatically. */
@SerializedName("default_for")
List defaultFor;
/**
* Description of the interval. Only required if the 'payment_schedule' parameter is
* 'interval' or 'combined'.
*/
@SerializedName("interval_description")
String intervalDescription;
/**
* Payment schedule for the mandate.
*
* One of {@code combined}, {@code interval}, or {@code sporadic}.
*/
@SerializedName("payment_schedule")
String paymentSchedule;
/**
* Transaction type of the mandate.
*
*
One of {@code business}, or {@code personal}.
*/
@SerializedName("transaction_type")
String transactionType;
}
/**
* For more details about AmazonPay, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AmazonPay extends StripeObject {}
/**
* For more details about AuBecsDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class AuBecsDebit extends StripeObject {
/**
* The URL of the mandate. This URL generally contains sensitive information about the
* customer and should be shared with them exclusively.
*/
@SerializedName("url")
String url;
}
/**
* For more details about BacsDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class BacsDebit extends StripeObject {
/**
* The status of the mandate on the Bacs network. Can be one of {@code pending}, {@code
* revoked}, {@code refused}, or {@code accepted}.
*/
@SerializedName("network_status")
String networkStatus;
/** The unique reference identifying the mandate on the Bacs network. */
@SerializedName("reference")
String reference;
/**
* When the mandate is revoked on the Bacs network this field displays the reason for the
* revocation.
*
*
One of {@code account_closed}, {@code bank_account_restricted}, {@code
* bank_ownership_changed}, {@code could_not_process}, or {@code debit_not_authorized}.
*/
@SerializedName("revocation_reason")
String revocationReason;
/** The URL that will contain the mandate that the customer has signed. */
@SerializedName("url")
String url;
}
/**
* For more details about Card, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Card extends StripeObject {}
/**
* For more details about Cashapp, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Cashapp extends StripeObject {}
/**
* For more details about KakaoPay, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class KakaoPay extends StripeObject {}
/**
* For more details about KrCard, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class KrCard extends StripeObject {}
/**
* For more details about Link, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Link extends StripeObject {}
/**
* For more details about Paypal, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Paypal extends StripeObject {
/**
* The PayPal Billing Agreement ID (BAID). This is an ID generated by PayPal which represents
* the mandate between the merchant and the customer.
*/
@SerializedName("billing_agreement_id")
String billingAgreementId;
/**
* Uniquely identifies this particular PayPal account. You can use this attribute to check
* whether two PayPal accounts are the same.
*/
@SerializedName("fingerprint")
String fingerprint;
/** PayPal account PayerID. This identifier uniquely identifies the PayPal customer. */
@SerializedName("payer_id")
String payerId;
/**
* Owner's verified email. Values are verified or provided by PayPal directly (if supported)
* at the time of authorization or settlement. They cannot be set or mutated.
*/
@SerializedName("verified_email")
String verifiedEmail;
}
/**
* For more details about Payto, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Payto extends StripeObject {
/**
* Amount that will be collected. It is required when {@code amount_type} is {@code fixed}.
*/
@SerializedName("amount")
Long amount;
/**
* The type of amount that will be collected. The amount charged must be exact or up to the
* value of {@code amount} param for {@code fixed} or {@code maximum} type respectively.
*
*
One of {@code fixed}, or {@code maximum}.
*/
@SerializedName("amount_type")
String amountType;
/**
* Date, in YYYY-MM-DD format, after which payments will not be collected. Defaults to no end
* date.
*/
@SerializedName("end_date")
String endDate;
/**
* The periodicity at which payments will be collected.
*
*
One of {@code adhoc}, {@code annual}, {@code daily}, {@code fortnightly}, {@code
* monthly}, {@code quarterly}, {@code semi_annual}, or {@code weekly}.
*/
@SerializedName("payment_schedule")
String paymentSchedule;
/**
* The number of payments that will be made during a payment period. Defaults to 1 except for
* when {@code payment_schedule} is {@code adhoc}. In that case, it defaults to no limit.
*/
@SerializedName("payments_per_period")
Long paymentsPerPeriod;
/**
* The purpose for which payments are made. Defaults to retail.
*
*
One of {@code dependant_support}, {@code government}, {@code loan}, {@code mortgage},
* {@code other}, {@code pension}, {@code personal}, {@code retail}, {@code salary}, {@code
* tax}, or {@code utility}.
*/
@SerializedName("purpose")
String purpose;
/**
* Date, in YYYY-MM-DD format, from which payments will be collected. Defaults to confirmation
* time.
*/
@SerializedName("start_date")
String startDate;
}
/**
* For more details about RevolutPay, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class RevolutPay extends StripeObject {}
/**
* For more details about SepaDebit, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class SepaDebit extends StripeObject {
/** The unique reference of the mandate. */
@SerializedName("reference")
String reference;
/**
* The URL of the mandate. This URL generally contains sensitive information about the
* customer and should be shared with them exclusively.
*/
@SerializedName("url")
String url;
}
/**
* For more details about UsBankAccount, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class UsBankAccount extends StripeObject {
/**
* Mandate collection method
*
*
Equal to {@code paper}.
*/
@SerializedName("collection_method")
String collectionMethod;
}
}
/**
* For more details about SingleUse, please refer to the API
* Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class SingleUse extends StripeObject {
/** The amount of the payment on a single use mandate. */
@SerializedName("amount")
Long amount;
/** The currency of the payment on a single use mandate. */
@SerializedName("currency")
String currency;
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(customerAcceptance, responseGetter);
trySetResponseGetter(multiUse, responseGetter);
trySetResponseGetter(paymentMethod, responseGetter);
trySetResponseGetter(paymentMethodDetails, responseGetter);
trySetResponseGetter(singleUse, responseGetter);
}
}