Skip to main content

stripe_shared/
capability.rs

1/// This is an object representing a capability for a Stripe account.
2///
3/// Related guide: [Account capabilities](https://docs.stripe.com/connect/account-capabilities)
4///
5/// For more details see <<https://stripe.com/docs/api/capabilities/object>>.
6#[derive(Clone)]
7#[cfg_attr(not(feature = "redact-generated-debug"), derive(Debug))]
8#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
9pub struct Capability {
10    /// The account for which the capability enables functionality.
11    pub account: stripe_types::Expandable<stripe_shared::Account>,
12    pub future_requirements: Option<stripe_shared::AccountCapabilityFutureRequirements>,
13    /// The identifier for the capability.
14    pub id: stripe_shared::CapabilityId,
15    /// Whether the capability has been requested.
16    pub requested: bool,
17    /// Time at which the capability was requested. Measured in seconds since the Unix epoch.
18    pub requested_at: Option<stripe_types::Timestamp>,
19    pub requirements: Option<stripe_shared::AccountCapabilityRequirements>,
20    /// The status of the capability.
21    pub status: CapabilityStatus,
22}
23#[cfg(feature = "redact-generated-debug")]
24impl std::fmt::Debug for Capability {
25    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
26        f.debug_struct("Capability").finish_non_exhaustive()
27    }
28}
29#[doc(hidden)]
30pub struct CapabilityBuilder {
31    account: Option<stripe_types::Expandable<stripe_shared::Account>>,
32    future_requirements: Option<Option<stripe_shared::AccountCapabilityFutureRequirements>>,
33    id: Option<stripe_shared::CapabilityId>,
34    requested: Option<bool>,
35    requested_at: Option<Option<stripe_types::Timestamp>>,
36    requirements: Option<Option<stripe_shared::AccountCapabilityRequirements>>,
37    status: Option<CapabilityStatus>,
38}
39
40#[allow(
41    unused_variables,
42    irrefutable_let_patterns,
43    clippy::let_unit_value,
44    clippy::match_single_binding,
45    clippy::single_match
46)]
47const _: () = {
48    use miniserde::de::{Map, Visitor};
49    use miniserde::json::Value;
50    use miniserde::{Deserialize, Result, make_place};
51    use stripe_types::miniserde_helpers::FromValueOpt;
52    use stripe_types::{MapBuilder, ObjectDeser};
53
54    make_place!(Place);
55
56    impl Deserialize for Capability {
57        fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
58            Place::new(out)
59        }
60    }
61
62    struct Builder<'a> {
63        out: &'a mut Option<Capability>,
64        builder: CapabilityBuilder,
65    }
66
67    impl Visitor for Place<Capability> {
68        fn map(&mut self) -> Result<Box<dyn Map + '_>> {
69            Ok(Box::new(Builder {
70                out: &mut self.out,
71                builder: CapabilityBuilder::deser_default(),
72            }))
73        }
74    }
75
76    impl MapBuilder for CapabilityBuilder {
77        type Out = Capability;
78        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
79            Ok(match k {
80                "account" => Deserialize::begin(&mut self.account),
81                "future_requirements" => Deserialize::begin(&mut self.future_requirements),
82                "id" => Deserialize::begin(&mut self.id),
83                "requested" => Deserialize::begin(&mut self.requested),
84                "requested_at" => Deserialize::begin(&mut self.requested_at),
85                "requirements" => Deserialize::begin(&mut self.requirements),
86                "status" => Deserialize::begin(&mut self.status),
87                _ => <dyn Visitor>::ignore(),
88            })
89        }
90
91        fn deser_default() -> Self {
92            Self {
93                account: None,
94                future_requirements: Some(None),
95                id: None,
96                requested: None,
97                requested_at: Some(None),
98                requirements: Some(None),
99                status: None,
100            }
101        }
102
103        fn take_out(&mut self) -> Option<Self::Out> {
104            let (
105                Some(account),
106                Some(future_requirements),
107                Some(id),
108                Some(requested),
109                Some(requested_at),
110                Some(requirements),
111                Some(status),
112            ) = (
113                self.account.take(),
114                self.future_requirements.take(),
115                self.id.take(),
116                self.requested,
117                self.requested_at,
118                self.requirements.take(),
119                self.status.take(),
120            )
121            else {
122                return None;
123            };
124            Some(Self::Out {
125                account,
126                future_requirements,
127                id,
128                requested,
129                requested_at,
130                requirements,
131                status,
132            })
133        }
134    }
135
136    impl Map for Builder<'_> {
137        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
138            self.builder.key(k)
139        }
140
141        fn finish(&mut self) -> Result<()> {
142            *self.out = self.builder.take_out();
143            Ok(())
144        }
145    }
146
147    impl ObjectDeser for Capability {
148        type Builder = CapabilityBuilder;
149    }
150
151    impl FromValueOpt for Capability {
152        fn from_value(v: Value) -> Option<Self> {
153            let Value::Object(obj) = v else {
154                return None;
155            };
156            let mut b = CapabilityBuilder::deser_default();
157            for (k, v) in obj {
158                match k.as_str() {
159                    "account" => b.account = FromValueOpt::from_value(v),
160                    "future_requirements" => b.future_requirements = FromValueOpt::from_value(v),
161                    "id" => b.id = FromValueOpt::from_value(v),
162                    "requested" => b.requested = FromValueOpt::from_value(v),
163                    "requested_at" => b.requested_at = FromValueOpt::from_value(v),
164                    "requirements" => b.requirements = FromValueOpt::from_value(v),
165                    "status" => b.status = FromValueOpt::from_value(v),
166                    _ => {}
167                }
168            }
169            b.take_out()
170        }
171    }
172};
173#[cfg(feature = "serialize")]
174impl serde::Serialize for Capability {
175    fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
176        use serde::ser::SerializeStruct;
177        let mut s = s.serialize_struct("Capability", 8)?;
178        s.serialize_field("account", &self.account)?;
179        s.serialize_field("future_requirements", &self.future_requirements)?;
180        s.serialize_field("id", &self.id)?;
181        s.serialize_field("requested", &self.requested)?;
182        s.serialize_field("requested_at", &self.requested_at)?;
183        s.serialize_field("requirements", &self.requirements)?;
184        s.serialize_field("status", &self.status)?;
185
186        s.serialize_field("object", "capability")?;
187        s.end()
188    }
189}
190/// The status of the capability.
191#[derive(Clone, Eq, PartialEq)]
192#[non_exhaustive]
193pub enum CapabilityStatus {
194    Active,
195    Inactive,
196    Pending,
197    Unrequested,
198    /// An unrecognized value from Stripe. Should not be used as a request parameter.
199    Unknown(String),
200}
201impl CapabilityStatus {
202    pub fn as_str(&self) -> &str {
203        use CapabilityStatus::*;
204        match self {
205            Active => "active",
206            Inactive => "inactive",
207            Pending => "pending",
208            Unrequested => "unrequested",
209            Unknown(v) => v,
210        }
211    }
212}
213
214impl std::str::FromStr for CapabilityStatus {
215    type Err = std::convert::Infallible;
216    fn from_str(s: &str) -> Result<Self, Self::Err> {
217        use CapabilityStatus::*;
218        match s {
219            "active" => Ok(Active),
220            "inactive" => Ok(Inactive),
221            "pending" => Ok(Pending),
222            "unrequested" => Ok(Unrequested),
223            v => {
224                tracing::warn!("Unknown value '{}' for enum '{}'", v, "CapabilityStatus");
225                Ok(Unknown(v.to_owned()))
226            }
227        }
228    }
229}
230impl std::fmt::Display for CapabilityStatus {
231    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
232        f.write_str(self.as_str())
233    }
234}
235
236#[cfg(not(feature = "redact-generated-debug"))]
237impl std::fmt::Debug for CapabilityStatus {
238    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
239        f.write_str(self.as_str())
240    }
241}
242#[cfg(feature = "redact-generated-debug")]
243impl std::fmt::Debug for CapabilityStatus {
244    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
245        f.debug_struct(stringify!(CapabilityStatus)).finish_non_exhaustive()
246    }
247}
248#[cfg(feature = "serialize")]
249impl serde::Serialize for CapabilityStatus {
250    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
251    where
252        S: serde::Serializer,
253    {
254        serializer.serialize_str(self.as_str())
255    }
256}
257impl miniserde::Deserialize for CapabilityStatus {
258    fn begin(out: &mut Option<Self>) -> &mut dyn miniserde::de::Visitor {
259        crate::Place::new(out)
260    }
261}
262
263impl miniserde::de::Visitor for crate::Place<CapabilityStatus> {
264    fn string(&mut self, s: &str) -> miniserde::Result<()> {
265        use std::str::FromStr;
266        self.out = Some(CapabilityStatus::from_str(s).expect("infallible"));
267        Ok(())
268    }
269}
270
271stripe_types::impl_from_val_with_from_str!(CapabilityStatus);
272#[cfg(feature = "deserialize")]
273impl<'de> serde::Deserialize<'de> for CapabilityStatus {
274    fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
275        use std::str::FromStr;
276        let s: std::borrow::Cow<'de, str> = serde::Deserialize::deserialize(deserializer)?;
277        Ok(Self::from_str(&s).expect("infallible"))
278    }
279}
280impl stripe_types::Object for Capability {
281    type Id = stripe_shared::CapabilityId;
282    fn id(&self) -> &Self::Id {
283        &self.id
284    }
285
286    fn into_id(self) -> Self::Id {
287        self.id
288    }
289}
290stripe_types::def_id!(CapabilityId);