stripe_shared/
account_requirements_alternative.rs

1#[derive(Clone, Debug)]
2#[cfg_attr(feature = "serialize", derive(serde::Serialize))]
3#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
4pub struct AccountRequirementsAlternative {
5    /// Fields that can be provided to satisfy all fields in `original_fields_due`.
6    pub alternative_fields_due: Vec<String>,
7    /// Fields that are due and can be satisfied by providing all fields in `alternative_fields_due`.
8    pub original_fields_due: Vec<String>,
9}
10#[doc(hidden)]
11pub struct AccountRequirementsAlternativeBuilder {
12    alternative_fields_due: Option<Vec<String>>,
13    original_fields_due: Option<Vec<String>>,
14}
15
16#[allow(
17    unused_variables,
18    irrefutable_let_patterns,
19    clippy::let_unit_value,
20    clippy::match_single_binding,
21    clippy::single_match
22)]
23const _: () = {
24    use miniserde::de::{Map, Visitor};
25    use miniserde::json::Value;
26    use miniserde::{make_place, Deserialize, Result};
27    use stripe_types::miniserde_helpers::FromValueOpt;
28    use stripe_types::{MapBuilder, ObjectDeser};
29
30    make_place!(Place);
31
32    impl Deserialize for AccountRequirementsAlternative {
33        fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
34            Place::new(out)
35        }
36    }
37
38    struct Builder<'a> {
39        out: &'a mut Option<AccountRequirementsAlternative>,
40        builder: AccountRequirementsAlternativeBuilder,
41    }
42
43    impl Visitor for Place<AccountRequirementsAlternative> {
44        fn map(&mut self) -> Result<Box<dyn Map + '_>> {
45            Ok(Box::new(Builder {
46                out: &mut self.out,
47                builder: AccountRequirementsAlternativeBuilder::deser_default(),
48            }))
49        }
50    }
51
52    impl MapBuilder for AccountRequirementsAlternativeBuilder {
53        type Out = AccountRequirementsAlternative;
54        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
55            Ok(match k {
56                "alternative_fields_due" => Deserialize::begin(&mut self.alternative_fields_due),
57                "original_fields_due" => Deserialize::begin(&mut self.original_fields_due),
58
59                _ => <dyn Visitor>::ignore(),
60            })
61        }
62
63        fn deser_default() -> Self {
64            Self {
65                alternative_fields_due: Deserialize::default(),
66                original_fields_due: Deserialize::default(),
67            }
68        }
69
70        fn take_out(&mut self) -> Option<Self::Out> {
71            let (Some(alternative_fields_due), Some(original_fields_due)) =
72                (self.alternative_fields_due.take(), self.original_fields_due.take())
73            else {
74                return None;
75            };
76            Some(Self::Out { alternative_fields_due, original_fields_due })
77        }
78    }
79
80    impl<'a> Map for Builder<'a> {
81        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
82            self.builder.key(k)
83        }
84
85        fn finish(&mut self) -> Result<()> {
86            *self.out = self.builder.take_out();
87            Ok(())
88        }
89    }
90
91    impl ObjectDeser for AccountRequirementsAlternative {
92        type Builder = AccountRequirementsAlternativeBuilder;
93    }
94
95    impl FromValueOpt for AccountRequirementsAlternative {
96        fn from_value(v: Value) -> Option<Self> {
97            let Value::Object(obj) = v else {
98                return None;
99            };
100            let mut b = AccountRequirementsAlternativeBuilder::deser_default();
101            for (k, v) in obj {
102                match k.as_str() {
103                    "alternative_fields_due" => {
104                        b.alternative_fields_due = FromValueOpt::from_value(v)
105                    }
106                    "original_fields_due" => b.original_fields_due = FromValueOpt::from_value(v),
107
108                    _ => {}
109                }
110            }
111            b.take_out()
112        }
113    }
114};