stripe_shared/
cash_balance.rs1#[derive(Clone, Debug)]
7#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
8pub struct CashBalance {
9 pub available: Option<std::collections::HashMap<String, i64>>,
13 pub customer: String,
15 pub livemode: bool,
17 pub settings: stripe_shared::CustomerBalanceCustomerBalanceSettings,
18}
19#[doc(hidden)]
20pub struct CashBalanceBuilder {
21 available: Option<Option<std::collections::HashMap<String, i64>>>,
22 customer: Option<String>,
23 livemode: Option<bool>,
24 settings: Option<stripe_shared::CustomerBalanceCustomerBalanceSettings>,
25}
26
27#[allow(
28 unused_variables,
29 irrefutable_let_patterns,
30 clippy::let_unit_value,
31 clippy::match_single_binding,
32 clippy::single_match
33)]
34const _: () = {
35 use miniserde::de::{Map, Visitor};
36 use miniserde::json::Value;
37 use miniserde::{Deserialize, Result, make_place};
38 use stripe_types::miniserde_helpers::FromValueOpt;
39 use stripe_types::{MapBuilder, ObjectDeser};
40
41 make_place!(Place);
42
43 impl Deserialize for CashBalance {
44 fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
45 Place::new(out)
46 }
47 }
48
49 struct Builder<'a> {
50 out: &'a mut Option<CashBalance>,
51 builder: CashBalanceBuilder,
52 }
53
54 impl Visitor for Place<CashBalance> {
55 fn map(&mut self) -> Result<Box<dyn Map + '_>> {
56 Ok(Box::new(Builder {
57 out: &mut self.out,
58 builder: CashBalanceBuilder::deser_default(),
59 }))
60 }
61 }
62
63 impl MapBuilder for CashBalanceBuilder {
64 type Out = CashBalance;
65 fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
66 Ok(match k {
67 "available" => Deserialize::begin(&mut self.available),
68 "customer" => Deserialize::begin(&mut self.customer),
69 "livemode" => Deserialize::begin(&mut self.livemode),
70 "settings" => Deserialize::begin(&mut self.settings),
71 _ => <dyn Visitor>::ignore(),
72 })
73 }
74
75 fn deser_default() -> Self {
76 Self {
77 available: Deserialize::default(),
78 customer: Deserialize::default(),
79 livemode: Deserialize::default(),
80 settings: Deserialize::default(),
81 }
82 }
83
84 fn take_out(&mut self) -> Option<Self::Out> {
85 let (Some(available), Some(customer), Some(livemode), Some(settings)) =
86 (self.available.take(), self.customer.take(), self.livemode, self.settings)
87 else {
88 return None;
89 };
90 Some(Self::Out { available, customer, livemode, settings })
91 }
92 }
93
94 impl Map for Builder<'_> {
95 fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
96 self.builder.key(k)
97 }
98
99 fn finish(&mut self) -> Result<()> {
100 *self.out = self.builder.take_out();
101 Ok(())
102 }
103 }
104
105 impl ObjectDeser for CashBalance {
106 type Builder = CashBalanceBuilder;
107 }
108
109 impl FromValueOpt for CashBalance {
110 fn from_value(v: Value) -> Option<Self> {
111 let Value::Object(obj) = v else {
112 return None;
113 };
114 let mut b = CashBalanceBuilder::deser_default();
115 for (k, v) in obj {
116 match k.as_str() {
117 "available" => b.available = FromValueOpt::from_value(v),
118 "customer" => b.customer = FromValueOpt::from_value(v),
119 "livemode" => b.livemode = FromValueOpt::from_value(v),
120 "settings" => b.settings = FromValueOpt::from_value(v),
121 _ => {}
122 }
123 }
124 b.take_out()
125 }
126 }
127};
128#[cfg(feature = "serialize")]
129impl serde::Serialize for CashBalance {
130 fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
131 use serde::ser::SerializeStruct;
132 let mut s = s.serialize_struct("CashBalance", 5)?;
133 s.serialize_field("available", &self.available)?;
134 s.serialize_field("customer", &self.customer)?;
135 s.serialize_field("livemode", &self.livemode)?;
136 s.serialize_field("settings", &self.settings)?;
137
138 s.serialize_field("object", "cash_balance")?;
139 s.end()
140 }
141}