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

com.stripe.model.SourceMandateNotification Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model;

import com.google.gson.annotations.SerializedName;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * Source mandate notifications should be created when a notification related to a source mandate
 * must be sent to the payer. They will trigger a webhook or deliver an email to the customer.
 */
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class SourceMandateNotification extends StripeObject implements HasId {
  @SerializedName("acss_debit")
  AcssDebit acssDebit;

  /**
   * A positive integer in the smallest currency unit (that is, 100 cents for $1.00, or 1 for ¥1,
   * Japanese Yen being a zero-decimal currency) representing the amount associated with the mandate
   * notification. The amount is expressed in the currency of the underlying source. Required if the
   * notification type is {@code debit_initiated}.
   */
  @SerializedName("amount")
  Long amount;

  @SerializedName("bacs_debit")
  BacsDebit bacsDebit;

  /** Time at which the object was created. Measured in seconds since the Unix epoch. */
  @SerializedName("created")
  Long created;

  /** 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;

  /**
   * String representing the object's type. Objects of the same type share the same value.
   *
   * 

Equal to {@code source_mandate_notification}. */ @SerializedName("object") String object; /** * The reason of the mandate notification. Valid reasons are {@code mandate_confirmed} or {@code * debit_initiated}. */ @SerializedName("reason") String reason; @SerializedName("sepa_debit") SepaDebit sepaDebit; /** * {@code Source} objects allow you to accept a variety of payment methods. They represent a * customer's payment instrument, and can be used with the Stripe API just like a {@code Card} * object: once chargeable, they can be charged, or can be attached to customers. * *

Stripe doesn't recommend using the deprecated Sources API. We recommend that you adopt the PaymentMethods API. This newer API * provides access to our latest features and payment method types. * *

Related guides: Sources API and Sources & Customers. */ @SerializedName("source") Source source; /** * The status of the mandate notification. Valid statuses are {@code pending} or {@code * submitted}. */ @SerializedName("status") String status; /** * The type of source this mandate notification is attached to. Should be the source type * identifier code for the payment method, such as {@code three_d_secure}. */ @SerializedName("type") String type; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AcssDebit extends StripeObject { /** The statement descriptor associate with the debit. */ @SerializedName("statement_descriptor") String statementDescriptor; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class BacsDebit extends StripeObject { /** Last 4 digits of the account number associated with the debit. */ @SerializedName("last4") String last4; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SepaDebit extends StripeObject { /** SEPA creditor ID. */ @SerializedName("creditor_identifier") String creditorIdentifier; /** Last 4 digits of the account number associated with the debit. */ @SerializedName("last4") String last4; /** Mandate reference associated with the debit. */ @SerializedName("mandate_reference") String mandateReference; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy