#[derive(Clone, Eq, PartialEq)]
#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
#[cfg_attr(feature = "serialize", derive(serde::Serialize))]
#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
pub struct PaymentMethodDetailsP24 {
pub bank: Option<PaymentMethodDetailsP24Bank>,
pub reference: Option<String>,
pub verified_name: Option<String>,
}
#[cfg(feature = "redact-generated-debug")]
impl std::fmt::Debug for PaymentMethodDetailsP24 {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct("PaymentMethodDetailsP24").finish_non_exhaustive()
}
}
#[doc(hidden)]
pub struct PaymentMethodDetailsP24Builder {
bank: Option<Option<PaymentMethodDetailsP24Bank>>,
reference: Option<Option<String>>,
verified_name: 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 PaymentMethodDetailsP24 {
fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
Place::new(out)
}
}
struct Builder<'a> {
out: &'a mut Option<PaymentMethodDetailsP24>,
builder: PaymentMethodDetailsP24Builder,
}
impl Visitor for Place<PaymentMethodDetailsP24> {
fn map(&mut self) -> Result<Box<dyn Map + '_>> {
Ok(Box::new(Builder {
out: &mut self.out,
builder: PaymentMethodDetailsP24Builder::deser_default(),
}))
}
}
impl MapBuilder for PaymentMethodDetailsP24Builder {
type Out = PaymentMethodDetailsP24;
fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
Ok(match k {
"bank" => Deserialize::begin(&mut self.bank),
"reference" => Deserialize::begin(&mut self.reference),
"verified_name" => Deserialize::begin(&mut self.verified_name),
_ => <dyn Visitor>::ignore(),
})
}
fn deser_default() -> Self {
Self { bank: Some(None), reference: Some(None), verified_name: Some(None) }
}
fn take_out(&mut self) -> Option<Self::Out> {
let (Some(bank), Some(reference), Some(verified_name)) =
(self.bank.take(), self.reference.take(), self.verified_name.take())
else {
return None;
};
Some(Self::Out { bank, reference, verified_name })
}
}
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 PaymentMethodDetailsP24 {
type Builder = PaymentMethodDetailsP24Builder;
}
impl FromValueOpt for PaymentMethodDetailsP24 {
fn from_value(v: Value) -> Option<Self> {
let Value::Object(obj) = v else {
return None;
};
let mut b = PaymentMethodDetailsP24Builder::deser_default();
for (k, v) in obj {
match k.as_str() {
"bank" => b.bank = FromValueOpt::from_value(v),
"reference" => b.reference = FromValueOpt::from_value(v),
"verified_name" => b.verified_name = FromValueOpt::from_value(v),
_ => {}
}
}
b.take_out()
}
}
};
#[derive(Clone, Eq, PartialEq)]
#[non_exhaustive]
pub enum PaymentMethodDetailsP24Bank {
AliorBank,
BankMillennium,
BankNowyBfgSa,
BankPekaoSa,
BankiSpbdzielcze,
Blik,
BnpParibas,
Boz,
CitiHandlowy,
CreditAgricole,
Envelobank,
EtransferPocztowy24,
GetinBank,
Ideabank,
Ing,
Inteligo,
MbankMtransfer,
NestPrzelew,
NoblePay,
PbacZIpko,
PlusBank,
SantanderPrzelew24,
TmobileUsbugiBankowe,
ToyotaBank,
Velobank,
VolkswagenBank,
Unknown(String),
}
impl PaymentMethodDetailsP24Bank {
pub fn as_str(&self) -> &str {
use PaymentMethodDetailsP24Bank::*;
match self {
AliorBank => "alior_bank",
BankMillennium => "bank_millennium",
BankNowyBfgSa => "bank_nowy_bfg_sa",
BankPekaoSa => "bank_pekao_sa",
BankiSpbdzielcze => "banki_spbdzielcze",
Blik => "blik",
BnpParibas => "bnp_paribas",
Boz => "boz",
CitiHandlowy => "citi_handlowy",
CreditAgricole => "credit_agricole",
Envelobank => "envelobank",
EtransferPocztowy24 => "etransfer_pocztowy24",
GetinBank => "getin_bank",
Ideabank => "ideabank",
Ing => "ing",
Inteligo => "inteligo",
MbankMtransfer => "mbank_mtransfer",
NestPrzelew => "nest_przelew",
NoblePay => "noble_pay",
PbacZIpko => "pbac_z_ipko",
PlusBank => "plus_bank",
SantanderPrzelew24 => "santander_przelew24",
TmobileUsbugiBankowe => "tmobile_usbugi_bankowe",
ToyotaBank => "toyota_bank",
Velobank => "velobank",
VolkswagenBank => "volkswagen_bank",
Unknown(v) => v,
}
}
}
impl std::str::FromStr for PaymentMethodDetailsP24Bank {
type Err = std::convert::Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
use PaymentMethodDetailsP24Bank::*;
match s {
"alior_bank" => Ok(AliorBank),
"bank_millennium" => Ok(BankMillennium),
"bank_nowy_bfg_sa" => Ok(BankNowyBfgSa),
"bank_pekao_sa" => Ok(BankPekaoSa),
"banki_spbdzielcze" => Ok(BankiSpbdzielcze),
"blik" => Ok(Blik),
"bnp_paribas" => Ok(BnpParibas),
"boz" => Ok(Boz),
"citi_handlowy" => Ok(CitiHandlowy),
"credit_agricole" => Ok(CreditAgricole),
"envelobank" => Ok(Envelobank),
"etransfer_pocztowy24" => Ok(EtransferPocztowy24),
"getin_bank" => Ok(GetinBank),
"ideabank" => Ok(Ideabank),
"ing" => Ok(Ing),
"inteligo" => Ok(Inteligo),
"mbank_mtransfer" => Ok(MbankMtransfer),
"nest_przelew" => Ok(NestPrzelew),
"noble_pay" => Ok(NoblePay),
"pbac_z_ipko" => Ok(PbacZIpko),
"plus_bank" => Ok(PlusBank),
"santander_przelew24" => Ok(SantanderPrzelew24),
"tmobile_usbugi_bankowe" => Ok(TmobileUsbugiBankowe),
"toyota_bank" => Ok(ToyotaBank),
"velobank" => Ok(Velobank),
"volkswagen_bank" => Ok(VolkswagenBank),
v => {
tracing::warn!(
"Unknown value '{}' for enum '{}'",
v,
"PaymentMethodDetailsP24Bank"
);
Ok(Unknown(v.to_owned()))
}
}
}
}
impl std::fmt::Display for PaymentMethodDetailsP24Bank {
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 PaymentMethodDetailsP24Bank {
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 PaymentMethodDetailsP24Bank {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
f.debug_struct(stringify!(PaymentMethodDetailsP24Bank)).finish_non_exhaustive()
}
}
#[cfg(feature = "serialize")]
impl serde::Serialize for PaymentMethodDetailsP24Bank {
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 PaymentMethodDetailsP24Bank {
fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
crate::Place::new(out)
}
}
impl miniserde::de::Visitor for crate::Place<PaymentMethodDetailsP24Bank> {
fn string(&mut self, s: &str) -> miniserde::Result<()> {
use std::str::FromStr;
self.out = Some(PaymentMethodDetailsP24Bank::from_str(s).expect("infallible"));
Ok(())
}
}
stripe_types::impl_from_val_with_from_str!(PaymentMethodDetailsP24Bank);
#[cfg(feature = "deserialize")]
impl<'de> serde::Deserialize<'de> for PaymentMethodDetailsP24Bank {
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"))
}
}