stripe_shared/
payment_method_options_customer_balance_bank_transfer.rs

1#[derive(Clone, Debug)]
2#[cfg_attr(feature = "serialize", derive(serde::Serialize))]
3#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
4pub struct PaymentMethodOptionsCustomerBalanceBankTransfer {
5    pub eu_bank_transfer: Option<stripe_shared::PaymentMethodOptionsCustomerBalanceEuBankAccount>,
6    /// List of address types that should be returned in the financial_addresses response.
7    /// If not specified, all valid types will be returned.
8    ///
9    /// Permitted values include: `sort_code`, `zengin`, `iban`, or `spei`.
10    pub requested_address_types:
11        Option<Vec<PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes>>,
12    /// The bank transfer type that this PaymentIntent is allowed to use for funding Permitted values include: `eu_bank_transfer`, `gb_bank_transfer`, `jp_bank_transfer`, `mx_bank_transfer`, or `us_bank_transfer`.
13    #[cfg_attr(any(feature = "deserialize", feature = "serialize"), serde(rename = "type"))]
14    pub type_: Option<PaymentMethodOptionsCustomerBalanceBankTransferType>,
15}
16#[doc(hidden)]
17pub struct PaymentMethodOptionsCustomerBalanceBankTransferBuilder {
18    eu_bank_transfer:
19        Option<Option<stripe_shared::PaymentMethodOptionsCustomerBalanceEuBankAccount>>,
20    requested_address_types:
21        Option<Option<Vec<PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes>>>,
22    type_: Option<Option<PaymentMethodOptionsCustomerBalanceBankTransferType>>,
23}
24
25#[allow(
26    unused_variables,
27    irrefutable_let_patterns,
28    clippy::let_unit_value,
29    clippy::match_single_binding,
30    clippy::single_match
31)]
32const _: () = {
33    use miniserde::de::{Map, Visitor};
34    use miniserde::json::Value;
35    use miniserde::{Deserialize, Result, make_place};
36    use stripe_types::miniserde_helpers::FromValueOpt;
37    use stripe_types::{MapBuilder, ObjectDeser};
38
39    make_place!(Place);
40
41    impl Deserialize for PaymentMethodOptionsCustomerBalanceBankTransfer {
42        fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
43            Place::new(out)
44        }
45    }
46
47    struct Builder<'a> {
48        out: &'a mut Option<PaymentMethodOptionsCustomerBalanceBankTransfer>,
49        builder: PaymentMethodOptionsCustomerBalanceBankTransferBuilder,
50    }
51
52    impl Visitor for Place<PaymentMethodOptionsCustomerBalanceBankTransfer> {
53        fn map(&mut self) -> Result<Box<dyn Map + '_>> {
54            Ok(Box::new(Builder {
55                out: &mut self.out,
56                builder: PaymentMethodOptionsCustomerBalanceBankTransferBuilder::deser_default(),
57            }))
58        }
59    }
60
61    impl MapBuilder for PaymentMethodOptionsCustomerBalanceBankTransferBuilder {
62        type Out = PaymentMethodOptionsCustomerBalanceBankTransfer;
63        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
64            Ok(match k {
65                "eu_bank_transfer" => Deserialize::begin(&mut self.eu_bank_transfer),
66                "requested_address_types" => Deserialize::begin(&mut self.requested_address_types),
67                "type" => Deserialize::begin(&mut self.type_),
68                _ => <dyn Visitor>::ignore(),
69            })
70        }
71
72        fn deser_default() -> Self {
73            Self {
74                eu_bank_transfer: Deserialize::default(),
75                requested_address_types: Deserialize::default(),
76                type_: Deserialize::default(),
77            }
78        }
79
80        fn take_out(&mut self) -> Option<Self::Out> {
81            let (Some(eu_bank_transfer), Some(requested_address_types), Some(type_)) =
82                (self.eu_bank_transfer, self.requested_address_types.take(), self.type_)
83            else {
84                return None;
85            };
86            Some(Self::Out { eu_bank_transfer, requested_address_types, type_ })
87        }
88    }
89
90    impl Map for Builder<'_> {
91        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
92            self.builder.key(k)
93        }
94
95        fn finish(&mut self) -> Result<()> {
96            *self.out = self.builder.take_out();
97            Ok(())
98        }
99    }
100
101    impl ObjectDeser for PaymentMethodOptionsCustomerBalanceBankTransfer {
102        type Builder = PaymentMethodOptionsCustomerBalanceBankTransferBuilder;
103    }
104
105    impl FromValueOpt for PaymentMethodOptionsCustomerBalanceBankTransfer {
106        fn from_value(v: Value) -> Option<Self> {
107            let Value::Object(obj) = v else {
108                return None;
109            };
110            let mut b = PaymentMethodOptionsCustomerBalanceBankTransferBuilder::deser_default();
111            for (k, v) in obj {
112                match k.as_str() {
113                    "eu_bank_transfer" => b.eu_bank_transfer = FromValueOpt::from_value(v),
114                    "requested_address_types" => {
115                        b.requested_address_types = FromValueOpt::from_value(v)
116                    }
117                    "type" => b.type_ = FromValueOpt::from_value(v),
118                    _ => {}
119                }
120            }
121            b.take_out()
122        }
123    }
124};
125/// List of address types that should be returned in the financial_addresses response.
126/// If not specified, all valid types will be returned.
127///
128/// Permitted values include: `sort_code`, `zengin`, `iban`, or `spei`.
129#[derive(Copy, Clone, Eq, PartialEq)]
130pub enum PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
131    Aba,
132    Iban,
133    Sepa,
134    SortCode,
135    Spei,
136    Swift,
137    Zengin,
138}
139impl PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
140    pub fn as_str(self) -> &'static str {
141        use PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes::*;
142        match self {
143            Aba => "aba",
144            Iban => "iban",
145            Sepa => "sepa",
146            SortCode => "sort_code",
147            Spei => "spei",
148            Swift => "swift",
149            Zengin => "zengin",
150        }
151    }
152}
153
154impl std::str::FromStr for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
155    type Err = stripe_types::StripeParseError;
156    fn from_str(s: &str) -> Result<Self, Self::Err> {
157        use PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes::*;
158        match s {
159            "aba" => Ok(Aba),
160            "iban" => Ok(Iban),
161            "sepa" => Ok(Sepa),
162            "sort_code" => Ok(SortCode),
163            "spei" => Ok(Spei),
164            "swift" => Ok(Swift),
165            "zengin" => Ok(Zengin),
166            _ => Err(stripe_types::StripeParseError),
167        }
168    }
169}
170impl std::fmt::Display for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
171    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
172        f.write_str(self.as_str())
173    }
174}
175
176impl std::fmt::Debug for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
177    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
178        f.write_str(self.as_str())
179    }
180}
181#[cfg(feature = "serialize")]
182impl serde::Serialize for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes {
183    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
184    where
185        S: serde::Serializer,
186    {
187        serializer.serialize_str(self.as_str())
188    }
189}
190impl miniserde::Deserialize
191    for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes
192{
193    fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
194        crate::Place::new(out)
195    }
196}
197
198impl miniserde::de::Visitor
199    for crate::Place<PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes>
200{
201    fn string(&mut self, s: &str) -> miniserde::Result<()> {
202        use std::str::FromStr;
203        self.out = Some(
204            PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes::from_str(s)
205                .map_err(|_| miniserde::Error)?,
206        );
207        Ok(())
208    }
209}
210
211stripe_types::impl_from_val_with_from_str!(
212    PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes
213);
214#[cfg(feature = "deserialize")]
215impl<'de> serde::Deserialize<'de>
216    for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes
217{
218    fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
219        use std::str::FromStr;
220        let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
221        Self::from_str(&s).map_err(|_| serde::de::Error::custom("Unknown value for PaymentMethodOptionsCustomerBalanceBankTransferRequestedAddressTypes"))
222    }
223}
224/// The bank transfer type that this PaymentIntent is allowed to use for funding Permitted values include: `eu_bank_transfer`, `gb_bank_transfer`, `jp_bank_transfer`, `mx_bank_transfer`, or `us_bank_transfer`.
225#[derive(Copy, Clone, Eq, PartialEq)]
226pub enum PaymentMethodOptionsCustomerBalanceBankTransferType {
227    EuBankTransfer,
228    GbBankTransfer,
229    JpBankTransfer,
230    MxBankTransfer,
231    UsBankTransfer,
232}
233impl PaymentMethodOptionsCustomerBalanceBankTransferType {
234    pub fn as_str(self) -> &'static str {
235        use PaymentMethodOptionsCustomerBalanceBankTransferType::*;
236        match self {
237            EuBankTransfer => "eu_bank_transfer",
238            GbBankTransfer => "gb_bank_transfer",
239            JpBankTransfer => "jp_bank_transfer",
240            MxBankTransfer => "mx_bank_transfer",
241            UsBankTransfer => "us_bank_transfer",
242        }
243    }
244}
245
246impl std::str::FromStr for PaymentMethodOptionsCustomerBalanceBankTransferType {
247    type Err = stripe_types::StripeParseError;
248    fn from_str(s: &str) -> Result<Self, Self::Err> {
249        use PaymentMethodOptionsCustomerBalanceBankTransferType::*;
250        match s {
251            "eu_bank_transfer" => Ok(EuBankTransfer),
252            "gb_bank_transfer" => Ok(GbBankTransfer),
253            "jp_bank_transfer" => Ok(JpBankTransfer),
254            "mx_bank_transfer" => Ok(MxBankTransfer),
255            "us_bank_transfer" => Ok(UsBankTransfer),
256            _ => Err(stripe_types::StripeParseError),
257        }
258    }
259}
260impl std::fmt::Display for PaymentMethodOptionsCustomerBalanceBankTransferType {
261    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
262        f.write_str(self.as_str())
263    }
264}
265
266impl std::fmt::Debug for PaymentMethodOptionsCustomerBalanceBankTransferType {
267    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
268        f.write_str(self.as_str())
269    }
270}
271#[cfg(feature = "serialize")]
272impl serde::Serialize for PaymentMethodOptionsCustomerBalanceBankTransferType {
273    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
274    where
275        S: serde::Serializer,
276    {
277        serializer.serialize_str(self.as_str())
278    }
279}
280impl miniserde::Deserialize for PaymentMethodOptionsCustomerBalanceBankTransferType {
281    fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
282        crate::Place::new(out)
283    }
284}
285
286impl miniserde::de::Visitor for crate::Place<PaymentMethodOptionsCustomerBalanceBankTransferType> {
287    fn string(&mut self, s: &str) -> miniserde::Result<()> {
288        use std::str::FromStr;
289        self.out = Some(
290            PaymentMethodOptionsCustomerBalanceBankTransferType::from_str(s)
291                .map_err(|_| miniserde::Error)?,
292        );
293        Ok(())
294    }
295}
296
297stripe_types::impl_from_val_with_from_str!(PaymentMethodOptionsCustomerBalanceBankTransferType);
298#[cfg(feature = "deserialize")]
299impl<'de> serde::Deserialize<'de> for PaymentMethodOptionsCustomerBalanceBankTransferType {
300    fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
301        use std::str::FromStr;
302        let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
303        Self::from_str(&s).map_err(|_| {
304            serde::de::Error::custom(
305                "Unknown value for PaymentMethodOptionsCustomerBalanceBankTransferType",
306            )
307        })
308    }
309}