#[derive(Clone)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
pub struct Card {
pub account: Option<stripe_types::Expandable<stripe_shared::Account>>,
pub address_city: Option<String>,
pub address_country: Option<String>,
pub address_line1: Option<String>,
pub address_line1_check: Option<String>,
pub address_line2: Option<String>,
pub address_state: Option<String>,
pub address_zip: Option<String>,
pub address_zip_check: Option<String>,
pub allow_redisplay: Option<CardAllowRedisplay>,
pub available_payout_methods: Option<Vec<CardAvailablePayoutMethods>>,
pub brand: String,
pub country: Option<String>,
pub currency: Option<stripe_types::Currency>,
pub customer: Option<stripe_types::Expandable<stripe_shared::Customer>>,
pub cvc_check: Option<String>,
pub default_for_currency: Option<bool>,
pub description: Option<String>,
pub dynamic_last4: Option<String>,
pub exp_month: i64,
pub exp_year: i64,
pub fingerprint: Option<String>,
pub funding: String,
pub id: stripe_shared::CardId,
pub iin: Option<String>,
pub issuer: Option<String>,
pub last4: String,
pub metadata: Option<std::collections::HashMap<String, String>>,
pub name: Option<String>,
pub networks: Option<stripe_shared::TokenCardNetworks>,
pub regulated_status: Option<CardRegulatedStatus>,
pub status: Option<String>,
pub tokenization_method: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for Card {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("Card").finish_non_exhaustive()
}
}
#[doc(hidden)]
pub struct CardBuilder {
account: Option<Option<stripe_types::Expandable<stripe_shared::Account>>>,
address_city: Option<Option<String>>,
address_country: Option<Option<String>>,
address_line1: Option<Option<String>>,
address_line1_check: Option<Option<String>>,
address_line2: Option<Option<String>>,
address_state: Option<Option<String>>,
address_zip: Option<Option<String>>,
address_zip_check: Option<Option<String>>,
allow_redisplay: Option<Option<CardAllowRedisplay>>,
available_payout_methods: Option<Option<Vec<CardAvailablePayoutMethods>>>,
brand: Option<String>,
country: Option<Option<String>>,
currency: Option<Option<stripe_types::Currency>>,
customer: Option<Option<stripe_types::Expandable<stripe_shared::Customer>>>,
cvc_check: Option<Option<String>>,
default_for_currency: Option<Option<bool>>,
description: Option<Option<String>>,
dynamic_last4: Option<Option<String>>,
exp_month: Option<i64>,
exp_year: Option<i64>,
fingerprint: Option<Option<String>>,
funding: Option<String>,
id: Option<stripe_shared::CardId>,
iin: Option<Option<String>>,
issuer: Option<Option<String>>,
last4: Option<String>,
metadata: Option<Option<std::collections::HashMap<String, String>>>,
name: Option<Option<String>>,
networks: Option<Option<stripe_shared::TokenCardNetworks>>,
regulated_status: Option<Option<CardRegulatedStatus>>,
status: Option<Option<String>>,
tokenization_method: Option<Option<String>>,
}
#[allow(
unused_variables,
irrefutable_let_patterns,
clippy::let_unit_value,
clippy::match_single_binding,
clippy::single_match
)]
const _: () = {
use miniserde::de::{Map, Visitor};
use miniserde::json::Value;
use miniserde::{Deserialize, Result, make_place};
use stripe_types::miniserde_helpers::FromValueOpt;
use stripe_types::{MapBuilder, ObjectDeser};
make_place!(Place);
impl Deserialize for Card {
fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
Place::new(out)
}
}
struct Builder<'a> {
out: &'a mut Option<Card>,
builder: CardBuilder,
}
impl Visitor for Place<Card> {
fn map(&mut self) -> Result<Box<dyn Map + '_>> {
Ok(Box::new(Builder { out: &mut self.out, builder: CardBuilder::deser_default() }))
}
}
impl MapBuilder for CardBuilder {
type Out = Card;
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
Ok(match k {
"account" => Deserialize::begin(&mut self.account),
"address_city" => Deserialize::begin(&mut self.address_city),
"address_country" => Deserialize::begin(&mut self.address_country),
"address_line1" => Deserialize::begin(&mut self.address_line1),
"address_line1_check" => Deserialize::begin(&mut self.address_line1_check),
"address_line2" => Deserialize::begin(&mut self.address_line2),
"address_state" => Deserialize::begin(&mut self.address_state),
"address_zip" => Deserialize::begin(&mut self.address_zip),
"address_zip_check" => Deserialize::begin(&mut self.address_zip_check),
"allow_redisplay" => Deserialize::begin(&mut self.allow_redisplay),
"available_payout_methods" => {
Deserialize::begin(&mut self.available_payout_methods)
}
"brand" => Deserialize::begin(&mut self.brand),
"country" => Deserialize::begin(&mut self.country),
"currency" => Deserialize::begin(&mut self.currency),
"customer" => Deserialize::begin(&mut self.customer),
"cvc_check" => Deserialize::begin(&mut self.cvc_check),
"default_for_currency" => Deserialize::begin(&mut self.default_for_currency),
"description" => Deserialize::begin(&mut self.description),
"dynamic_last4" => Deserialize::begin(&mut self.dynamic_last4),
"exp_month" => Deserialize::begin(&mut self.exp_month),
"exp_year" => Deserialize::begin(&mut self.exp_year),
"fingerprint" => Deserialize::begin(&mut self.fingerprint),
"funding" => Deserialize::begin(&mut self.funding),
"id" => Deserialize::begin(&mut self.id),
"iin" => Deserialize::begin(&mut self.iin),
"issuer" => Deserialize::begin(&mut self.issuer),
"last4" => Deserialize::begin(&mut self.last4),
"metadata" => Deserialize::begin(&mut self.metadata),
"name" => Deserialize::begin(&mut self.name),
"networks" => Deserialize::begin(&mut self.networks),
"regulated_status" => Deserialize::begin(&mut self.regulated_status),
"status" => Deserialize::begin(&mut self.status),
"tokenization_method" => Deserialize::begin(&mut self.tokenization_method),
_ => <dyn Visitor>::ignore(),
})
}
fn deser_default() -> Self {
Self {
account: Some(None),
address_city: Some(None),
address_country: Some(None),
address_line1: Some(None),
address_line1_check: Some(None),
address_line2: Some(None),
address_state: Some(None),
address_zip: Some(None),
address_zip_check: Some(None),
allow_redisplay: Some(None),
available_payout_methods: Some(None),
brand: None,
country: Some(None),
currency: Some(None),
customer: Some(None),
cvc_check: Some(None),
default_for_currency: Some(None),
description: Some(None),
dynamic_last4: Some(None),
exp_month: None,
exp_year: None,
fingerprint: Some(None),
funding: None,
id: None,
iin: Some(None),
issuer: Some(None),
last4: None,
metadata: Some(None),
name: Some(None),
networks: Some(None),
regulated_status: Some(None),
status: Some(None),
tokenization_method: Some(None),
}
}
fn take_out(&mut self) -> Option<Self::Out> {
let (
Some(account),
Some(address_city),
Some(address_country),
Some(address_line1),
Some(address_line1_check),
Some(address_line2),
Some(address_state),
Some(address_zip),
Some(address_zip_check),
Some(allow_redisplay),
Some(available_payout_methods),
Some(brand),
Some(country),
Some(currency),
Some(customer),
Some(cvc_check),
Some(default_for_currency),
Some(description),
Some(dynamic_last4),
Some(exp_month),
Some(exp_year),
Some(fingerprint),
Some(funding),
Some(id),
Some(iin),
Some(issuer),
Some(last4),
Some(metadata),
Some(name),
Some(networks),
Some(regulated_status),
Some(status),
Some(tokenization_method),
) = (
self.account.take(),
self.address_city.take(),
self.address_country.take(),
self.address_line1.take(),
self.address_line1_check.take(),
self.address_line2.take(),
self.address_state.take(),
self.address_zip.take(),
self.address_zip_check.take(),
self.allow_redisplay.take(),
self.available_payout_methods.take(),
self.brand.take(),
self.country.take(),
self.currency.take(),
self.customer.take(),
self.cvc_check.take(),
self.default_for_currency,
self.description.take(),
self.dynamic_last4.take(),
self.exp_month,
self.exp_year,
self.fingerprint.take(),
self.funding.take(),
self.id.take(),
self.iin.take(),
self.issuer.take(),
self.last4.take(),
self.metadata.take(),
self.name.take(),
self.networks.take(),
self.regulated_status.take(),
self.status.take(),
self.tokenization_method.take(),
)
else {
return None;
};
Some(Self::Out {
account,
address_city,
address_country,
address_line1,
address_line1_check,
address_line2,
address_state,
address_zip,
address_zip_check,
allow_redisplay,
available_payout_methods,
brand,
country,
currency,
customer,
cvc_check,
default_for_currency,
description,
dynamic_last4,
exp_month,
exp_year,
fingerprint,
funding,
id,
iin,
issuer,
last4,
metadata,
name,
networks,
regulated_status,
status,
tokenization_method,
})
}
}
impl Map for Builder<'_> {
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
self.builder.key(k)
}
fn finish(&mut self) -> Result<()> {
*self.out = self.builder.take_out();
Ok(())
}
}
impl ObjectDeser for Card {
type Builder = CardBuilder;
}
impl FromValueOpt for Card {
fn from_value(v: Value) -> Option<Self> {
let Value::Object(obj) = v else {
return None;
};
let mut b = CardBuilder::deser_default();
for (k, v) in obj {
match k.as_str() {
"account" => b.account = FromValueOpt::from_value(v),
"address_city" => b.address_city = FromValueOpt::from_value(v),
"address_country" => b.address_country = FromValueOpt::from_value(v),
"address_line1" => b.address_line1 = FromValueOpt::from_value(v),
"address_line1_check" => b.address_line1_check = FromValueOpt::from_value(v),
"address_line2" => b.address_line2 = FromValueOpt::from_value(v),
"address_state" => b.address_state = FromValueOpt::from_value(v),
"address_zip" => b.address_zip = FromValueOpt::from_value(v),
"address_zip_check" => b.address_zip_check = FromValueOpt::from_value(v),
"allow_redisplay" => b.allow_redisplay = FromValueOpt::from_value(v),
"available_payout_methods" => {
b.available_payout_methods = FromValueOpt::from_value(v)
}
"brand" => b.brand = FromValueOpt::from_value(v),
"country" => b.country = FromValueOpt::from_value(v),
"currency" => b.currency = FromValueOpt::from_value(v),
"customer" => b.customer = FromValueOpt::from_value(v),
"cvc_check" => b.cvc_check = FromValueOpt::from_value(v),
"default_for_currency" => b.default_for_currency = FromValueOpt::from_value(v),
"description" => b.description = FromValueOpt::from_value(v),
"dynamic_last4" => b.dynamic_last4 = FromValueOpt::from_value(v),
"exp_month" => b.exp_month = FromValueOpt::from_value(v),
"exp_year" => b.exp_year = FromValueOpt::from_value(v),
"fingerprint" => b.fingerprint = FromValueOpt::from_value(v),
"funding" => b.funding = FromValueOpt::from_value(v),
"id" => b.id = FromValueOpt::from_value(v),
"iin" => b.iin = FromValueOpt::from_value(v),
"issuer" => b.issuer = FromValueOpt::from_value(v),
"last4" => b.last4 = FromValueOpt::from_value(v),
"metadata" => b.metadata = FromValueOpt::from_value(v),
"name" => b.name = FromValueOpt::from_value(v),
"networks" => b.networks = FromValueOpt::from_value(v),
"regulated_status" => b.regulated_status = FromValueOpt::from_value(v),
"status" => b.status = FromValueOpt::from_value(v),
"tokenization_method" => b.tokenization_method = FromValueOpt::from_value(v),
_ => {}
}
}
b.take_out()
}
}
};
#[cfg(feature = "serialize")]
impl serde::Serialize for Card {
fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
use serde::ser::SerializeStruct;
let mut s = s.serialize_struct("Card", 34)?;
s.serialize_field("account", &self.account)?;
s.serialize_field("address_city", &self.address_city)?;
s.serialize_field("address_country", &self.address_country)?;
s.serialize_field("address_line1", &self.address_line1)?;
s.serialize_field("address_line1_check", &self.address_line1_check)?;
s.serialize_field("address_line2", &self.address_line2)?;
s.serialize_field("address_state", &self.address_state)?;
s.serialize_field("address_zip", &self.address_zip)?;
s.serialize_field("address_zip_check", &self.address_zip_check)?;
s.serialize_field("allow_redisplay", &self.allow_redisplay)?;
s.serialize_field("available_payout_methods", &self.available_payout_methods)?;
s.serialize_field("brand", &self.brand)?;
s.serialize_field("country", &self.country)?;
s.serialize_field("currency", &self.currency)?;
s.serialize_field("customer", &self.customer)?;
s.serialize_field("cvc_check", &self.cvc_check)?;
s.serialize_field("default_for_currency", &self.default_for_currency)?;
s.serialize_field("description", &self.description)?;
s.serialize_field("dynamic_last4", &self.dynamic_last4)?;
s.serialize_field("exp_month", &self.exp_month)?;
s.serialize_field("exp_year", &self.exp_year)?;
s.serialize_field("fingerprint", &self.fingerprint)?;
s.serialize_field("funding", &self.funding)?;
s.serialize_field("id", &self.id)?;
s.serialize_field("iin", &self.iin)?;
s.serialize_field("issuer", &self.issuer)?;
s.serialize_field("last4", &self.last4)?;
s.serialize_field("metadata", &self.metadata)?;
s.serialize_field("name", &self.name)?;
s.serialize_field("networks", &self.networks)?;
s.serialize_field("regulated_status", &self.regulated_status)?;
s.serialize_field("status", &self.status)?;
s.serialize_field("tokenization_method", &self.tokenization_method)?;
s.serialize_field("object", "card")?;
s.end()
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum CardAllowRedisplay {
Always,
Limited,
Unspecified,
Unknown(String),
}
impl CardAllowRedisplay {
pub fn as_str(&self) -> &str {
use CardAllowRedisplay::*;
match self {
Always => "always",
Limited => "limited",
Unspecified => "unspecified",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for CardAllowRedisplay {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use CardAllowRedisplay::*;
match s {
"always" => Ok(Always),
"limited" => Ok(Limited),
"unspecified" => Ok(Unspecified),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "CardAllowRedisplay");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for CardAllowRedisplay {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(not(feature = "redact-generated-debug"))]
impl std::fmt::Debug for CardAllowRedisplay {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CardAllowRedisplay {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(CardAllowRedisplay)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for CardAllowRedisplay {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(self.as_str())
}
}
impl miniserde::Deserialize for CardAllowRedisplay {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<CardAllowRedisplay> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(CardAllowRedisplay::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(CardAllowRedisplay);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for CardAllowRedisplay {
fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
use std::str::FromStr;
let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
Ok(Self::from_str(&s).expect("infallible"))
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum CardAvailablePayoutMethods {
Instant,
Standard,
Unknown(String),
}
impl CardAvailablePayoutMethods {
pub fn as_str(&self) -> &str {
use CardAvailablePayoutMethods::*;
match self {
Instant => "instant",
Standard => "standard",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for CardAvailablePayoutMethods {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use CardAvailablePayoutMethods::*;
match s {
"instant" => Ok(Instant),
"standard" => Ok(Standard),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "CardAvailablePayoutMethods");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for CardAvailablePayoutMethods {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(not(feature = "redact-generated-debug"))]
impl std::fmt::Debug for CardAvailablePayoutMethods {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CardAvailablePayoutMethods {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(CardAvailablePayoutMethods)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for CardAvailablePayoutMethods {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(self.as_str())
}
}
impl miniserde::Deserialize for CardAvailablePayoutMethods {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<CardAvailablePayoutMethods> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(CardAvailablePayoutMethods::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(CardAvailablePayoutMethods);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for CardAvailablePayoutMethods {
fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
use std::str::FromStr;
let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
Ok(Self::from_str(&s).expect("infallible"))
}
}
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum CardRegulatedStatus {
Regulated,
Unregulated,
Unknown(String),
}
impl CardRegulatedStatus {
pub fn as_str(&self) -> &str {
use CardRegulatedStatus::*;
match self {
Regulated => "regulated",
Unregulated => "unregulated",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for CardRegulatedStatus {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use CardRegulatedStatus::*;
match s {
"regulated" => Ok(Regulated),
"unregulated" => Ok(Unregulated),
v => {
tracing::warn!("Unknown value '{}' for enum '{}'", v, "CardRegulatedStatus");
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for CardRegulatedStatus {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(not(feature = "redact-generated-debug"))]
impl std::fmt::Debug for CardRegulatedStatus {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.write_str(self.as_str())
}
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for CardRegulatedStatus {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(CardRegulatedStatus)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for CardRegulatedStatus {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(self.as_str())
}
}
impl miniserde::Deserialize for CardRegulatedStatus {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<CardRegulatedStatus> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(CardRegulatedStatus::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(CardRegulatedStatus);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for CardRegulatedStatus {
fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
use std::str::FromStr;
let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
Ok(Self::from_str(&s).expect("infallible"))
}
}
impl stripe_types::Object for Card {
type Id = stripe_shared::CardId;
fn id(&self) -> &Self::Id {
&self.id
}
fn into_id(self) -> Self::Id {
self.id
}
}
stripe_types::def_id!(CardId);