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

com.stripe.model.terminal.Reader Maven / Gradle / Ivy

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

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.Charge;
import com.stripe.model.ExpandableField;
import com.stripe.model.HasId;
import com.stripe.model.MetadataStore;
import com.stripe.model.PaymentIntent;
import com.stripe.model.PaymentMethod;
import com.stripe.model.Refund;
import com.stripe.model.SetupIntent;
import com.stripe.model.StripeObject;
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.terminal.ReaderCancelActionParams;
import com.stripe.param.terminal.ReaderCollectInputsParams;
import com.stripe.param.terminal.ReaderCollectPaymentMethodParams;
import com.stripe.param.terminal.ReaderConfirmPaymentIntentParams;
import com.stripe.param.terminal.ReaderCreateParams;
import com.stripe.param.terminal.ReaderListParams;
import com.stripe.param.terminal.ReaderPresentPaymentMethodParams;
import com.stripe.param.terminal.ReaderProcessPaymentIntentParams;
import com.stripe.param.terminal.ReaderProcessSetupIntentParams;
import com.stripe.param.terminal.ReaderRefundPaymentParams;
import com.stripe.param.terminal.ReaderRetrieveParams;
import com.stripe.param.terminal.ReaderSetReaderDisplayParams;
import com.stripe.param.terminal.ReaderUpdateParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * A Reader represents a physical device for accepting payment details.
 *
 * 

Related guide: Connecting * to a reader */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Reader extends ApiResource implements HasId, MetadataStore { /** The most recent action performed by the reader. */ @SerializedName("action") Action action; /** Always true for a deleted object. */ @SerializedName("deleted") Boolean deleted; /** The current software version of the reader. */ @SerializedName("device_sw_version") String deviceSwVersion; /** * Type of reader, one of {@code bbpos_wisepad3}, {@code stripe_m2}, {@code stripe_s700}, {@code * bbpos_chipper2x}, {@code bbpos_wisepos_e}, {@code verifone_P400}, {@code simulated_wisepos_e}, * or {@code mobile_phone_reader}. */ @SerializedName("device_type") String deviceType; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** The local IP address of the reader. */ @SerializedName("ip_address") String ipAddress; /** Custom label given to the reader for easier identification. */ @SerializedName("label") String label; /** * 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 location identifier of the reader. */ @SerializedName("location") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField location; /** * 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 terminal.reader}. */ @SerializedName("object") String object; /** Serial number of the reader. */ @SerializedName("serial_number") String serialNumber; /** * The networking status of the reader. We do not recommend using this field in flows that may * block taking payments. * *

One of {@code offline}, or {@code online}. */ @SerializedName("status") String status; /** Get ID of expandable {@code location} object. */ public String getLocation() { return (this.location != null) ? this.location.getId() : null; } public void setLocation(String id) { this.location = ApiResource.setExpandableFieldId(id, this.location); } /** Get expanded {@code location}. */ public Location getLocationObject() { return (this.location != null) ? this.location.getExpanded() : null; } public void setLocationObject(Location expandableObject) { this.location = new ExpandableField(expandableObject.getId(), expandableObject); } /** Cancels the current reader action. */ public Reader cancelAction() throws StripeException { return cancelAction((Map) null, (RequestOptions) null); } /** Cancels the current reader action. */ public Reader cancelAction(RequestOptions options) throws StripeException { return cancelAction((Map) null, options); } /** Cancels the current reader action. */ public Reader cancelAction(Map params) throws StripeException { return cancelAction(params, (RequestOptions) null); } /** Cancels the current reader action. */ public Reader cancelAction(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/cancel_action", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Cancels the current reader action. */ public Reader cancelAction(ReaderCancelActionParams params) throws StripeException { return cancelAction(params, (RequestOptions) null); } /** Cancels the current reader action. */ public Reader cancelAction(ReaderCancelActionParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/cancel_action", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Initiates an input collection flow on a Reader. */ public Reader collectInputs(Map params) throws StripeException { return collectInputs(params, (RequestOptions) null); } /** Initiates an input collection flow on a Reader. */ public Reader collectInputs(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/collect_inputs", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Initiates an input collection flow on a Reader. */ public Reader collectInputs(ReaderCollectInputsParams params) throws StripeException { return collectInputs(params, (RequestOptions) null); } /** Initiates an input collection flow on a Reader. */ public Reader collectInputs(ReaderCollectInputsParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/collect_inputs", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** * Initiates a payment flow on a Reader and updates the PaymentIntent with card details before * manual confirmation. */ public Reader collectPaymentMethod(Map params) throws StripeException { return collectPaymentMethod(params, (RequestOptions) null); } /** * Initiates a payment flow on a Reader and updates the PaymentIntent with card details before * manual confirmation. */ public Reader collectPaymentMethod(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/collect_payment_method", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** * Initiates a payment flow on a Reader and updates the PaymentIntent with card details before * manual confirmation. */ public Reader collectPaymentMethod(ReaderCollectPaymentMethodParams params) throws StripeException { return collectPaymentMethod(params, (RequestOptions) null); } /** * Initiates a payment flow on a Reader and updates the PaymentIntent with card details before * manual confirmation. */ public Reader collectPaymentMethod( ReaderCollectPaymentMethodParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/collect_payment_method", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Finalizes a payment on a Reader. */ public Reader confirmPaymentIntent(Map params) throws StripeException { return confirmPaymentIntent(params, (RequestOptions) null); } /** Finalizes a payment on a Reader. */ public Reader confirmPaymentIntent(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/confirm_payment_intent", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Finalizes a payment on a Reader. */ public Reader confirmPaymentIntent(ReaderConfirmPaymentIntentParams params) throws StripeException { return confirmPaymentIntent(params, (RequestOptions) null); } /** Finalizes a payment on a Reader. */ public Reader confirmPaymentIntent( ReaderConfirmPaymentIntentParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/confirm_payment_intent", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Creates a new {@code Reader} object. */ public static Reader create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new {@code Reader} object. */ public static Reader create(Map params, RequestOptions options) throws StripeException { String path = "/v1/terminal/readers"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Reader.class); } /** Creates a new {@code Reader} object. */ public static Reader create(ReaderCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** Creates a new {@code Reader} object. */ public static Reader create(ReaderCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/terminal/readers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Reader.class); } /** Deletes a {@code Reader} object. */ public Reader delete() throws StripeException { return delete((Map) null, (RequestOptions) null); } /** Deletes a {@code Reader} object. */ public Reader delete(RequestOptions options) throws StripeException { return delete((Map) null, options); } /** Deletes a {@code Reader} object. */ public Reader delete(Map params) throws StripeException { return delete(params, (RequestOptions) null); } /** Deletes a {@code Reader} object. */ public Reader delete(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/terminal/readers/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.DELETE, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Returns a list of {@code Reader} objects. */ public static ReaderCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of {@code Reader} objects. */ public static ReaderCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/terminal/readers"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, ReaderCollection.class); } /** Returns a list of {@code Reader} objects. */ public static ReaderCollection list(ReaderListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of {@code Reader} objects. */ public static ReaderCollection list(ReaderListParams params, RequestOptions options) throws StripeException { String path = "/v1/terminal/readers"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, ReaderCollection.class); } /** Initiates a payment flow on a Reader. */ public Reader processPaymentIntent(Map params) throws StripeException { return processPaymentIntent(params, (RequestOptions) null); } /** Initiates a payment flow on a Reader. */ public Reader processPaymentIntent(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/process_payment_intent", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Initiates a payment flow on a Reader. */ public Reader processPaymentIntent(ReaderProcessPaymentIntentParams params) throws StripeException { return processPaymentIntent(params, (RequestOptions) null); } /** Initiates a payment flow on a Reader. */ public Reader processPaymentIntent( ReaderProcessPaymentIntentParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/process_payment_intent", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Initiates a setup intent flow on a Reader. */ public Reader processSetupIntent(Map params) throws StripeException { return processSetupIntent(params, (RequestOptions) null); } /** Initiates a setup intent flow on a Reader. */ public Reader processSetupIntent(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/process_setup_intent", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Initiates a setup intent flow on a Reader. */ public Reader processSetupIntent(ReaderProcessSetupIntentParams params) throws StripeException { return processSetupIntent(params, (RequestOptions) null); } /** Initiates a setup intent flow on a Reader. */ public Reader processSetupIntent(ReaderProcessSetupIntentParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/process_setup_intent", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Initiates a refund on a Reader. */ public Reader refundPayment() throws StripeException { return refundPayment((Map) null, (RequestOptions) null); } /** Initiates a refund on a Reader. */ public Reader refundPayment(RequestOptions options) throws StripeException { return refundPayment((Map) null, options); } /** Initiates a refund on a Reader. */ public Reader refundPayment(Map params) throws StripeException { return refundPayment(params, (RequestOptions) null); } /** Initiates a refund on a Reader. */ public Reader refundPayment(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/refund_payment", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Initiates a refund on a Reader. */ public Reader refundPayment(ReaderRefundPaymentParams params) throws StripeException { return refundPayment(params, (RequestOptions) null); } /** Initiates a refund on a Reader. */ public Reader refundPayment(ReaderRefundPaymentParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/refund_payment", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Retrieves a {@code Reader} object. */ public static Reader retrieve(String reader) throws StripeException { return retrieve(reader, (Map) null, (RequestOptions) null); } /** Retrieves a {@code Reader} object. */ public static Reader retrieve(String reader, RequestOptions options) throws StripeException { return retrieve(reader, (Map) null, options); } /** Retrieves a {@code Reader} object. */ public static Reader retrieve(String reader, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/terminal/readers/%s", ApiResource.urlEncodeId(reader)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Reader.class); } /** Retrieves a {@code Reader} object. */ public static Reader retrieve(String reader, ReaderRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/terminal/readers/%s", ApiResource.urlEncodeId(reader)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Reader.class); } /** Sets reader display to show cart details. */ public Reader setReaderDisplay(Map params) throws StripeException { return setReaderDisplay(params, (RequestOptions) null); } /** Sets reader display to show cart details. */ public Reader setReaderDisplay(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/set_reader_display", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** Sets reader display to show cart details. */ public Reader setReaderDisplay(ReaderSetReaderDisplayParams params) throws StripeException { return setReaderDisplay(params, (RequestOptions) null); } /** Sets reader display to show cart details. */ public Reader setReaderDisplay(ReaderSetReaderDisplayParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/terminal/readers/%s/set_reader_display", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** * Updates a {@code Reader} object by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. */ @Override public Reader update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates a {@code Reader} object by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. */ @Override public Reader update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/terminal/readers/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Reader.class); } /** * Updates a {@code Reader} object by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. */ public Reader update(ReaderUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates a {@code Reader} object by setting the values of the parameters passed. Any parameters * not provided will be left unchanged. */ public Reader update(ReaderUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/terminal/readers/%s", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Reader.class); } /** Represents an action performed by the reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Action extends StripeObject { /** Represents a reader action to collect customer inputs. */ @SerializedName("collect_inputs") CollectInputs collectInputs; /** Represents a reader action to collect a payment method. */ @SerializedName("collect_payment_method") CollectPaymentMethod collectPaymentMethod; /** Represents a reader action to confirm a payment. */ @SerializedName("confirm_payment_intent") ConfirmPaymentIntent confirmPaymentIntent; /** Failure code, only set if status is {@code failed}. */ @SerializedName("failure_code") String failureCode; /** Detailed failure message, only set if status is {@code failed}. */ @SerializedName("failure_message") String failureMessage; /** Represents a reader action to process a payment intent. */ @SerializedName("process_payment_intent") ProcessPaymentIntent processPaymentIntent; /** Represents a reader action to process a setup intent. */ @SerializedName("process_setup_intent") ProcessSetupIntent processSetupIntent; /** Represents a reader action to refund a payment. */ @SerializedName("refund_payment") RefundPayment refundPayment; /** Represents a reader action to set the reader display. */ @SerializedName("set_reader_display") SetReaderDisplay setReaderDisplay; /** * Status of the action performed by the reader. * *

One of {@code failed}, {@code in_progress}, or {@code succeeded}. */ @SerializedName("status") String status; /** * Type of action performed by the reader. * *

One of {@code collect_inputs}, {@code collect_payment_method}, {@code * confirm_payment_intent}, {@code process_payment_intent}, {@code process_setup_intent}, {@code * refund_payment}, or {@code set_reader_display}. */ @SerializedName("type") String type; /** Represents a reader action to collect customer inputs. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CollectInputs extends StripeObject { /** List of inputs to be collected. */ @SerializedName("inputs") List inputs; /** * 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. */ @SerializedName("metadata") Map metadata; /** Represents an input to be collected using the reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Input extends StripeObject { /** Default text of input being collected. */ @SerializedName("custom_text") CustomText customText; /** Information about a email being collected using a reader. */ @SerializedName("email") Email email; /** Information about a number being collected using a reader. */ @SerializedName("numeric") Numeric numeric; /** Information about a phone number being collected using a reader. */ @SerializedName("phone") Phone phone; /** Indicate that this input is required, disabling the skip button. */ @SerializedName("required") Boolean required; /** Information about a selection being collected using a reader. */ @SerializedName("selection") Selection selection; /** Information about a signature being collected using a reader. */ @SerializedName("signature") Signature signature; /** Indicate that this input was skipped by the user. */ @SerializedName("skipped") Boolean skipped; /** Information about text being collected using a reader. */ @SerializedName("text") Text text; /** List of toggles being collected. Values are present if collection is complete. */ @SerializedName("toggles") List toggles; /** * Type of input being collected. * *

One of {@code email}, {@code numeric}, {@code phone}, {@code selection}, {@code * signature}, or {@code text}. */ @SerializedName("type") String type; /** Represents custom text to be displayed when collecting the input using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CustomText extends StripeObject { /** Customize the default description for this input. */ @SerializedName("description") String description; /** Customize the default label for this input's skip button. */ @SerializedName("skip_button") String skipButton; /** Customize the default label for this input's submit button. */ @SerializedName("submit_button") String submitButton; /** Customize the default title for this input. */ @SerializedName("title") String title; } /** Information about a email being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Email extends StripeObject { /** The collected email address. */ @SerializedName("value") String value; } /** Information about a number being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Numeric extends StripeObject { /** The collected number. */ @SerializedName("value") String value; } /** Information about a phone number being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Phone extends StripeObject { /** The collected phone number. */ @SerializedName("value") String value; } /** Information about a selection being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Selection extends StripeObject { /** List of possible choices to be selected. */ @SerializedName("choices") List choices; /** The value of the selected choice. */ @SerializedName("value") String value; /** Choice to be selected on a Reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Choice extends StripeObject { /** * The button style for the choice * *

One of {@code primary}, or {@code secondary}. */ @SerializedName("style") String style; /** A value to be selected. */ @SerializedName("value") String value; } } /** Information about a signature being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Signature extends StripeObject { /** The File ID of a collected signature image. */ @SerializedName("value") String value; } /** Information about text being collected using a reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Text extends StripeObject { /** The collected text value. */ @SerializedName("value") String value; } /** Information about an input's toggle. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Toggle extends StripeObject { /** * The toggle's default value * *

One of {@code disabled}, or {@code enabled}. */ @SerializedName("default_value") String defaultValue; /** The toggle's description text. */ @SerializedName("description") String description; /** The toggle's title text. */ @SerializedName("title") String title; /** * The toggle's collected value * *

One of {@code disabled}, or {@code enabled}. */ @SerializedName("value") String value; } } } /** Represents a reader action to collect a payment method. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CollectPaymentMethod extends StripeObject { /** Represents a per-transaction override of a reader configuration. */ @SerializedName("collect_config") CollectConfig collectConfig; /** Most recent PaymentIntent processed by the reader. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; /** * PaymentMethod objects represent your customer's payment instruments. You can use them with * PaymentIntents to collect * payments or save them to Customer objects to store instrument details for future payments. * *

Related guides: Payment * Methods and More * Payment Scenarios. */ @SerializedName("payment_method") PaymentMethod paymentMethod; @SerializedName("stripe_account") String stripeAccount; /** 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); } /** Represents a per-transaction override of a reader configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CollectConfig extends StripeObject { /** Enable customer initiated cancellation when processing this payment. */ @SerializedName("enable_customer_cancellation") Boolean enableCustomerCancellation; /** Override showing a tipping selection screen on this transaction. */ @SerializedName("skip_tipping") Boolean skipTipping; /** Represents a per-transaction tipping configuration. */ @SerializedName("tipping") Tipping tipping; /** Represents a per-transaction tipping configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tipping extends StripeObject { /** * Amount used to calculate tip suggestions on tipping selection screen for this * transaction. Must be a positive integer in the smallest currency unit (e.g., 100 cents * to represent $1.00 or 100 to represent ¥100, a zero-decimal currency). */ @SerializedName("amount_eligible") Long amountEligible; } } } /** Represents a reader action to confirm a payment. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ConfirmPaymentIntent extends StripeObject { /** Most recent PaymentIntent processed by the reader. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; @SerializedName("stripe_account") String stripeAccount; /** 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); } } /** Represents a reader action to process a payment intent. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ProcessPaymentIntent extends StripeObject { /** Most recent PaymentIntent processed by the reader. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; /** Represents a per-transaction override of a reader configuration. */ @SerializedName("process_config") ProcessConfig processConfig; @SerializedName("stripe_account") String stripeAccount; /** 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); } /** Represents a per-transaction override of a reader configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ProcessConfig extends StripeObject { /** Enable customer initiated cancellation when processing this payment. */ @SerializedName("enable_customer_cancellation") Boolean enableCustomerCancellation; /** Override showing a tipping selection screen on this transaction. */ @SerializedName("skip_tipping") Boolean skipTipping; /** Represents a per-transaction tipping configuration. */ @SerializedName("tipping") Tipping tipping; /** Represents a per-transaction tipping configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tipping extends StripeObject { /** * Amount used to calculate tip suggestions on tipping selection screen for this * transaction. Must be a positive integer in the smallest currency unit (e.g., 100 cents * to represent $1.00 or 100 to represent ¥100, a zero-decimal currency). */ @SerializedName("amount_eligible") Long amountEligible; } } } /** Represents a reader action to process a setup intent. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ProcessSetupIntent extends StripeObject { /** * ID of a card PaymentMethod generated from the card_present PaymentMethod that may be * attached to a Customer for future transactions. Only present if it was possible to generate * a card PaymentMethod. */ @SerializedName("generated_card") String generatedCard; /** Represents a per-setup override of a reader configuration. */ @SerializedName("process_config") ProcessConfig processConfig; /** Most recent SetupIntent processed by the reader. */ @SerializedName("setup_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField setupIntent; /** Get ID of expandable {@code setupIntent} object. */ public String getSetupIntent() { return (this.setupIntent != null) ? this.setupIntent.getId() : null; } public void setSetupIntent(String id) { this.setupIntent = ApiResource.setExpandableFieldId(id, this.setupIntent); } /** Get expanded {@code setupIntent}. */ public SetupIntent getSetupIntentObject() { return (this.setupIntent != null) ? this.setupIntent.getExpanded() : null; } public void setSetupIntentObject(SetupIntent expandableObject) { this.setupIntent = new ExpandableField(expandableObject.getId(), expandableObject); } /** Represents a per-setup override of a reader configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ProcessConfig extends StripeObject { /** Enable customer initiated cancellation when processing this SetupIntent. */ @SerializedName("enable_customer_cancellation") Boolean enableCustomerCancellation; } } /** Represents a reader action to refund a payment. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class RefundPayment extends StripeObject { /** The amount being refunded. */ @SerializedName("amount") Long amount; /** Charge that is being refunded. */ @SerializedName("charge") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField charge; /** * 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. */ @SerializedName("metadata") Map metadata; /** Payment intent that is being refunded. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; /** * The reason for the refund. * *

One of {@code duplicate}, {@code fraudulent}, or {@code requested_by_customer}. */ @SerializedName("reason") String reason; /** Unique identifier for the refund object. */ @SerializedName("refund") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField refund; /** * Boolean indicating whether the application fee should be refunded when refunding this * charge. If a full charge refund is given, the full application fee will be refunded. * Otherwise, the application fee will be refunded in an amount proportional to the amount of * the charge refunded. An application fee can be refunded only by the application that * created the charge. */ @SerializedName("refund_application_fee") Boolean refundApplicationFee; /** Represents a per-transaction override of a reader configuration. */ @SerializedName("refund_payment_config") RefundPaymentConfig refundPaymentConfig; /** * Boolean indicating whether the transfer should be reversed when refunding this charge. The * transfer will be reversed proportionally to the amount being refunded (either the entire or * partial amount). A transfer can be reversed only by the application that created the * charge. */ @SerializedName("reverse_transfer") Boolean reverseTransfer; @SerializedName("stripe_account") String stripeAccount; /** 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); } /** Get ID of expandable {@code refund} object. */ public String getRefund() { return (this.refund != null) ? this.refund.getId() : null; } public void setRefund(String id) { this.refund = ApiResource.setExpandableFieldId(id, this.refund); } /** Get expanded {@code refund}. */ public Refund getRefundObject() { return (this.refund != null) ? this.refund.getExpanded() : null; } public void setRefundObject(Refund expandableObject) { this.refund = new ExpandableField(expandableObject.getId(), expandableObject); } /** Represents a per-transaction override of a reader configuration. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class RefundPaymentConfig extends StripeObject { /** Enable customer initiated cancellation when refunding this payment. */ @SerializedName("enable_customer_cancellation") Boolean enableCustomerCancellation; } } /** Represents a reader action to set the reader display. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class SetReaderDisplay extends StripeObject { /** Cart object to be displayed by the reader. */ @SerializedName("cart") Cart cart; /** * Type of information to be displayed by the reader. * *

Equal to {@code cart}. */ @SerializedName("type") String type; /** Represents a cart to be displayed on the reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Cart extends StripeObject { /** * Three-letter ISO currency * code, in lowercase. Must be a supported * currency. */ @SerializedName("currency") String currency; /** List of line items in the cart. */ @SerializedName("line_items") List lineItems; /** * Tax amount for the entire cart. A positive integer in the smallest currency unit. */ @SerializedName("tax") Long tax; /** * Total amount for the entire cart, including tax. A positive integer in the smallest currency unit. */ @SerializedName("total") Long total; /** Represents a line item to be displayed on the reader. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class LineItem extends StripeObject { /** * The amount of the line item. A positive integer in the smallest currency unit. */ @SerializedName("amount") Long amount; /** Description of the line item. */ @SerializedName("description") String description; /** The quantity of the line item. */ @SerializedName("quantity") Long quantity; } } } } public TestHelpers getTestHelpers() { return new TestHelpers(this); } public static class TestHelpers { private final Reader resource; private TestHelpers(Reader resource) { this.resource = resource; } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod() throws StripeException { return presentPaymentMethod((Map) null, (RequestOptions) null); } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod(RequestOptions options) throws StripeException { return presentPaymentMethod((Map) null, options); } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod(Map params) throws StripeException { return presentPaymentMethod(params, (RequestOptions) null); } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/terminal/readers/%s/present_payment_method", ApiResource.urlEncodeId(this.resource.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return resource.getResponseGetter().request(request, Reader.class); } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod(ReaderPresentPaymentMethodParams params) throws StripeException { return presentPaymentMethod(params, (RequestOptions) null); } /** * Presents a payment method on a simulated reader. Can be used to simulate accepting a payment, * saving a card or refunding a transaction. */ public Reader presentPaymentMethod( ReaderPresentPaymentMethodParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/terminal/readers/%s/present_payment_method", ApiResource.urlEncodeId(this.resource.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return resource.getResponseGetter().request(request, Reader.class); } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(action, responseGetter); trySetResponseGetter(location, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy