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

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

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

@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class StripeError extends StripeObject {
  /** For card errors, the ID of the failed charge. */
  @SerializedName("charge")
  String charge;

  /**
   * For some errors that could be handled programmatically, a short string indicating the error code reported.
   *
   * 

One of {@code account_closed}, {@code account_country_invalid_address}, {@code * account_error_country_change_requires_additional_steps}, {@code account_information_mismatch}, * {@code account_invalid}, {@code account_number_invalid}, {@code acss_debit_session_incomplete}, * {@code alipay_upgrade_required}, {@code amount_too_large}, {@code amount_too_small}, {@code * api_key_expired}, {@code application_fees_not_allowed}, {@code authentication_required}, {@code * balance_insufficient}, {@code balance_invalid_parameter}, {@code * bank_account_bad_routing_numbers}, {@code bank_account_declined}, {@code bank_account_exists}, * {@code bank_account_restricted}, {@code bank_account_unusable}, {@code * bank_account_unverified}, {@code bank_account_verification_failed}, {@code * billing_invalid_mandate}, {@code bitcoin_upgrade_required}, {@code * capture_charge_authorization_expired}, {@code capture_unauthorized_payment}, {@code * card_decline_rate_limit_exceeded}, {@code card_declined}, {@code * cardholder_phone_number_required}, {@code charge_already_captured}, {@code * charge_already_refunded}, {@code charge_disputed}, {@code charge_exceeds_source_limit}, {@code * charge_exceeds_transaction_limit}, {@code charge_expired_for_capture}, {@code * charge_invalid_parameter}, {@code charge_not_refundable}, {@code clearing_code_unsupported}, * {@code country_code_invalid}, {@code country_unsupported}, {@code coupon_expired}, {@code * customer_max_payment_methods}, {@code customer_max_subscriptions}, {@code * customer_tax_location_invalid}, {@code debit_not_authorized}, {@code email_invalid}, {@code * expired_card}, {@code financial_connections_account_inactive}, {@code * financial_connections_institution_unavailable}, {@code * financial_connections_no_successful_transaction_refresh}, {@code forwarding_api_inactive}, * {@code forwarding_api_invalid_parameter}, {@code forwarding_api_upstream_connection_error}, * {@code forwarding_api_upstream_connection_timeout}, {@code gift_card_balance_insufficient}, * {@code gift_card_code_exists}, {@code gift_card_inactive}, {@code idempotency_key_in_use}, * {@code incorrect_address}, {@code incorrect_cvc}, {@code incorrect_number}, {@code * incorrect_zip}, {@code instant_payouts_config_disabled}, {@code * instant_payouts_currency_disabled}, {@code instant_payouts_limit_exceeded}, {@code * instant_payouts_unsupported}, {@code insufficient_funds}, {@code intent_invalid_state}, {@code * intent_verification_method_missing}, {@code invalid_card_type}, {@code invalid_characters}, * {@code invalid_charge_amount}, {@code invalid_cvc}, {@code invalid_expiry_month}, {@code * invalid_expiry_year}, {@code invalid_mandate_reference_prefix_format}, {@code invalid_number}, * {@code invalid_source_usage}, {@code invalid_tax_location}, {@code * invoice_no_customer_line_items}, {@code invoice_no_payment_method_types}, {@code * invoice_no_subscription_line_items}, {@code invoice_not_editable}, {@code * invoice_on_behalf_of_not_editable}, {@code invoice_payment_intent_requires_action}, {@code * invoice_upcoming_none}, {@code livemode_mismatch}, {@code lock_timeout}, {@code missing}, * {@code no_account}, {@code not_allowed_on_standard_account}, {@code out_of_inventory}, {@code * ownership_declaration_not_allowed}, {@code parameter_invalid_empty}, {@code * parameter_invalid_integer}, {@code parameter_invalid_string_blank}, {@code * parameter_invalid_string_empty}, {@code parameter_missing}, {@code parameter_unknown}, {@code * parameters_exclusive}, {@code payment_intent_action_required}, {@code * payment_intent_authentication_failure}, {@code payment_intent_incompatible_payment_method}, * {@code payment_intent_invalid_parameter}, {@code * payment_intent_konbini_rejected_confirmation_number}, {@code payment_intent_mandate_invalid}, * {@code payment_intent_payment_attempt_expired}, {@code payment_intent_payment_attempt_failed}, * {@code payment_intent_unexpected_state}, {@code payment_method_bank_account_already_verified}, * {@code payment_method_bank_account_blocked}, {@code * payment_method_billing_details_address_missing}, {@code payment_method_configuration_failures}, * {@code payment_method_currency_mismatch}, {@code payment_method_customer_decline}, {@code * payment_method_invalid_parameter}, {@code payment_method_invalid_parameter_testmode}, {@code * payment_method_microdeposit_failed}, {@code * payment_method_microdeposit_verification_amounts_invalid}, {@code * payment_method_microdeposit_verification_amounts_mismatch}, {@code * payment_method_microdeposit_verification_attempts_exceeded}, {@code * payment_method_microdeposit_verification_descriptor_code_mismatch}, {@code * payment_method_microdeposit_verification_timeout}, {@code payment_method_not_available}, {@code * payment_method_provider_decline}, {@code payment_method_provider_timeout}, {@code * payment_method_unactivated}, {@code payment_method_unexpected_state}, {@code * payment_method_unsupported_type}, {@code payout_reconciliation_not_ready}, {@code * payouts_limit_exceeded}, {@code payouts_not_allowed}, {@code platform_account_required}, {@code * platform_api_key_expired}, {@code postal_code_invalid}, {@code processing_error}, {@code * product_inactive}, {@code progressive_onboarding_limit_exceeded}, {@code rate_limit}, {@code * refer_to_customer}, {@code refund_disputed_payment}, {@code resource_already_exists}, {@code * resource_missing}, {@code return_intent_already_processed}, {@code routing_number_invalid}, * {@code secret_key_required}, {@code sensitive_data_access_expired}, {@code * sepa_unsupported_account}, {@code setup_attempt_failed}, {@code * setup_intent_authentication_failure}, {@code setup_intent_invalid_parameter}, {@code * setup_intent_mandate_invalid}, {@code setup_intent_setup_attempt_expired}, {@code * setup_intent_unexpected_state}, {@code shipping_address_invalid}, {@code * shipping_calculation_failed}, {@code sku_inactive}, {@code state_unsupported}, {@code * status_transition_invalid}, {@code stripe_tax_inactive}, {@code tax_id_invalid}, {@code * taxes_calculation_failed}, {@code terminal_location_country_unsupported}, {@code * terminal_reader_busy}, {@code terminal_reader_collected_data_invalid}, {@code * terminal_reader_hardware_fault}, {@code terminal_reader_invalid_location_for_activation}, * {@code terminal_reader_invalid_location_for_payment}, {@code terminal_reader_offline}, {@code * terminal_reader_timeout}, {@code testmode_charges_only}, {@code tls_version_unsupported}, * {@code token_already_used}, {@code token_card_network_invalid}, {@code token_in_use}, {@code * transfer_source_balance_parameters_mismatch}, {@code transfers_not_allowed}, or {@code * url_invalid}. */ @SerializedName("code") String code; /** * For card errors resulting from a card issuer decline, a short string indicating the card issuer's reason for the * decline if they provide one. */ @SerializedName("decline_code") String declineCode; /** * A URL to more information about the error * code reported. */ @SerializedName("doc_url") String docUrl; /** * A human-readable message providing more details about the error. For card errors, these * messages can be shown to your users. */ @SerializedName("message") String message; /** * If the error is parameter-specific, the parameter related to the error. For example, you can * use this to display a message near the correct form field. */ @SerializedName("param") String param; /** * A PaymentIntent guides you through the process of collecting a payment from your customer. We * recommend that you create exactly one PaymentIntent for each order or customer session in your * system. You can reference the PaymentIntent later to see the history of payment attempts for a * particular session. * *

A PaymentIntent transitions through multiple statuses * throughout its lifetime as it interfaces with Stripe.js to perform authentication flows and * ultimately creates at most one successful charge. * *

Related guide: Payment Intents * API */ @SerializedName("payment_intent") PaymentIntent 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; /** * If the error is specific to the type of payment method, the payment method type that had a * problem. This field is only populated for invoice-related errors. */ @SerializedName("payment_method_type") String paymentMethodType; /** A URL to the request log entry in your dashboard. */ @SerializedName("request_log_url") String requestLogUrl; /** * A SetupIntent guides you through the process of setting up and saving a customer's payment * credentials for future payments. For example, you can use a SetupIntent to set up and save your * customer's card without immediately collecting a payment. Later, you can use PaymentIntents to drive the payment * flow. * *

Create a SetupIntent when you're ready to collect your customer's payment credentials. Don't * maintain long-lived, unconfirmed SetupIntents because they might not be valid. The SetupIntent * transitions through multiple statuses as it guides you * through the setup process. * *

Successful SetupIntents result in payment credentials that are optimized for future * payments. For example, cardholders in certain regions might need * to be run through Strong * Customer Authentication during payment method collection to streamline later off-session payments. If you use the * SetupIntent with a Customer, it automatically * attaches the resulting payment method to that Customer after successful setup. We recommend * using SetupIntents or setup_future_usage * on PaymentIntents to save payment methods to prevent saving invalid or unoptimized payment * methods. * *

By using SetupIntents, you can reduce friction for your customers, even as regulations * change over time. * *

Related guide: Setup Intents * API */ @SerializedName("setup_intent") SetupIntent setupIntent; @SerializedName("source") PaymentSource source; /** * The type of error returned. One of {@code api_error}, {@code card_error}, {@code * idempotency_error}, or {@code invalid_request_error} */ @SerializedName("type") String type; /** The user message associated with the error. */ @SerializedName("user_message") String userMessage; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy