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

com.stripe.param.InvoicePayParams Maven / Gradle / Ivy

// Generated by delombok at Thu Oct 22 19:52:27 PDT 2020
// File generated from our OpenAPI spec
package com.stripe.param;

import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class InvoicePayParams extends ApiRequestParams {
  /**
   * Specifies which fields in the response should be expanded.
   */
  @SerializedName("expand")
  List expand;
  /**
   * Map of extra parameters for custom features not available in this client library. The content
   * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
   * key/value pair is serialized as if the key is a root-level field (serialized) name in this
   * param object. Effectively, this map is flattened to its parent instance.
   */
  @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
  Map extraParams;
  /**
   * In cases where the source used to pay the invoice has insufficient funds, passing {@code
   * forgive=true} controls whether a charge should be attempted for the full amount available on
   * the source, up to the amount to fully pay the invoice. This effectively forgives the difference
   * between the amount available on the source and the amount due.
   *
   * 

Passing {@code forgive=false} will fail the charge if the source hasn't been pre-funded with * the right amount. An example for this case is with ACH Credit Transfers and wires: if the * amount wired is less than the amount due by a small amount, you might want to forgive the * difference. Defaults to {@code false}. */ @SerializedName("forgive") Boolean forgive; /** * Indicates if a customer is on or off-session while an invoice payment is attempted. Defaults to * {@code true} (off-session). */ @SerializedName("off_session") Boolean offSession; /** * Boolean representing whether an invoice is paid outside of Stripe. This will result in no * charge being made. Defaults to {@code false}. */ @SerializedName("paid_out_of_band") Boolean paidOutOfBand; /** * A PaymentMethod to be charged. The PaymentMethod must be the ID of a PaymentMethod belonging to * the customer associated with the invoice being paid. */ @SerializedName("payment_method") String paymentMethod; /** * A payment source to be charged. The source must be the ID of a source belonging to the customer * associated with the invoice being paid. */ @SerializedName("source") String source; private InvoicePayParams(List expand, Map extraParams, Boolean forgive, Boolean offSession, Boolean paidOutOfBand, String paymentMethod, String source) { this.expand = expand; this.extraParams = extraParams; this.forgive = forgive; this.offSession = offSession; this.paidOutOfBand = paidOutOfBand; this.paymentMethod = paymentMethod; this.source = source; } public static Builder builder() { return new Builder(); } public static class Builder { private List expand; private Map extraParams; private Boolean forgive; private Boolean offSession; private Boolean paidOutOfBand; private String paymentMethod; private String source; /** Finalize and obtain parameter instance from this builder. */ public InvoicePayParams build() { return new InvoicePayParams(this.expand, this.extraParams, this.forgive, this.offSession, this.paidOutOfBand, this.paymentMethod, this.source); } /** * Add an element to `expand` list. A list is initialized for the first `add/addAll` call, and * subsequent calls adds additional elements to the original list. See {@link * InvoicePayParams#expand} for the field documentation. */ public Builder addExpand(String element) { if (this.expand == null) { this.expand = new ArrayList<>(); } this.expand.add(element); return this; } /** * Add all elements to `expand` list. A list is initialized for the first `add/addAll` call, and * subsequent calls adds additional elements to the original list. See {@link * InvoicePayParams#expand} for the field documentation. */ public Builder addAllExpand(List elements) { if (this.expand == null) { this.expand = new ArrayList<>(); } this.expand.addAll(elements); return this; } /** * Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll` * call, and subsequent calls add additional key/value pairs to the original map. See {@link * InvoicePayParams#extraParams} for the field documentation. */ public Builder putExtraParam(String key, Object value) { if (this.extraParams == null) { this.extraParams = new HashMap<>(); } this.extraParams.put(key, value); return this; } /** * Add all map key/value pairs to `extraParams` map. A map is initialized for the first * `put/putAll` call, and subsequent calls add additional key/value pairs to the original map. * See {@link InvoicePayParams#extraParams} for the field documentation. */ public Builder putAllExtraParam(Map map) { if (this.extraParams == null) { this.extraParams = new HashMap<>(); } this.extraParams.putAll(map); return this; } /** * In cases where the source used to pay the invoice has insufficient funds, passing {@code * forgive=true} controls whether a charge should be attempted for the full amount available on * the source, up to the amount to fully pay the invoice. This effectively forgives the * difference between the amount available on the source and the amount due. * *

Passing {@code forgive=false} will fail the charge if the source hasn't been pre-funded * with the right amount. An example for this case is with ACH Credit Transfers and wires: if * the amount wired is less than the amount due by a small amount, you might want to forgive the * difference. Defaults to {@code false}. */ public Builder setForgive(Boolean forgive) { this.forgive = forgive; return this; } /** * Indicates if a customer is on or off-session while an invoice payment is attempted. Defaults * to {@code true} (off-session). */ public Builder setOffSession(Boolean offSession) { this.offSession = offSession; return this; } /** * Boolean representing whether an invoice is paid outside of Stripe. This will result in no * charge being made. Defaults to {@code false}. */ public Builder setPaidOutOfBand(Boolean paidOutOfBand) { this.paidOutOfBand = paidOutOfBand; return this; } /** * A PaymentMethod to be charged. The PaymentMethod must be the ID of a PaymentMethod belonging * to the customer associated with the invoice being paid. */ public Builder setPaymentMethod(String paymentMethod) { this.paymentMethod = paymentMethod; return this; } /** * A payment source to be charged. The source must be the ID of a source belonging to the * customer associated with the invoice being paid. */ public Builder setSource(String source) { this.source = source; return this; } } /** * Specifies which fields in the response should be expanded. */ @java.lang.SuppressWarnings("all") @lombok.Generated public List getExpand() { return this.expand; } /** * Map of extra parameters for custom features not available in this client library. The content * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each * key/value pair is serialized as if the key is a root-level field (serialized) name in this * param object. Effectively, this map is flattened to its parent instance. */ @java.lang.SuppressWarnings("all") @lombok.Generated public Map getExtraParams() { return this.extraParams; } /** * In cases where the source used to pay the invoice has insufficient funds, passing {@code * forgive=true} controls whether a charge should be attempted for the full amount available on * the source, up to the amount to fully pay the invoice. This effectively forgives the difference * between the amount available on the source and the amount due. * *

Passing {@code forgive=false} will fail the charge if the source hasn't been pre-funded with * the right amount. An example for this case is with ACH Credit Transfers and wires: if the * amount wired is less than the amount due by a small amount, you might want to forgive the * difference. Defaults to {@code false}. */ @java.lang.SuppressWarnings("all") @lombok.Generated public Boolean getForgive() { return this.forgive; } /** * Indicates if a customer is on or off-session while an invoice payment is attempted. Defaults to * {@code true} (off-session). */ @java.lang.SuppressWarnings("all") @lombok.Generated public Boolean getOffSession() { return this.offSession; } /** * Boolean representing whether an invoice is paid outside of Stripe. This will result in no * charge being made. Defaults to {@code false}. */ @java.lang.SuppressWarnings("all") @lombok.Generated public Boolean getPaidOutOfBand() { return this.paidOutOfBand; } /** * A PaymentMethod to be charged. The PaymentMethod must be the ID of a PaymentMethod belonging to * the customer associated with the invoice being paid. */ @java.lang.SuppressWarnings("all") @lombok.Generated public String getPaymentMethod() { return this.paymentMethod; } /** * A payment source to be charged. The source must be the ID of a source belonging to the customer * associated with the invoice being paid. */ @java.lang.SuppressWarnings("all") @lombok.Generated public String getSource() { return this.source; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy