stripe_misc/webhook_endpoint/
types.rs

1/// You can configure [webhook endpoints](https://docs.stripe.com/webhooks/) via the API to be
2/// notified about events that happen in your Stripe account or connected
3/// accounts.
4///
5/// Most users configure webhooks from [the dashboard](https://dashboard.stripe.com/webhooks), which provides a user interface for registering and testing your webhook endpoints.
6///
7/// Related guide: [Setting up webhooks](https://docs.stripe.com/webhooks/configure)
8///
9/// For more details see <<https://stripe.com/docs/api/webhook_endpoints/object>>.
10#[derive(Clone, Debug)]
11#[cfg_attr(feature = "deserialize", derive(serde::Deserialize))]
12pub struct WebhookEndpoint {
13    /// The API version events are rendered as for this webhook endpoint.
14    pub api_version: Option<String>,
15    /// The ID of the associated Connect application.
16    pub application: Option<String>,
17    /// Time at which the object was created. Measured in seconds since the Unix epoch.
18    pub created: stripe_types::Timestamp,
19    /// An optional description of what the webhook is used for.
20    pub description: Option<String>,
21    /// The list of events to enable for this endpoint.
22    /// `['*']` indicates that all events are enabled, except those that require explicit selection.
23    pub enabled_events: Vec<String>,
24    /// Unique identifier for the object.
25    pub id: stripe_misc::WebhookEndpointId,
26    /// Has the value `true` if the object exists in live mode or the value `false` if the object exists in test mode.
27    pub livemode: bool,
28    /// Set of [key-value pairs](https://stripe.com/docs/api/metadata) that you can attach to an object.
29    /// This can be useful for storing additional information about the object in a structured format.
30    pub metadata: std::collections::HashMap<String, String>,
31    /// The endpoint's secret, used to generate [webhook signatures](https://docs.stripe.com/webhooks/signatures).
32    /// Only returned at creation.
33    pub secret: Option<String>,
34    /// The status of the webhook. It can be `enabled` or `disabled`.
35    pub status: String,
36    /// The URL of the webhook endpoint.
37    pub url: String,
38}
39#[doc(hidden)]
40pub struct WebhookEndpointBuilder {
41    api_version: Option<Option<String>>,
42    application: Option<Option<String>>,
43    created: Option<stripe_types::Timestamp>,
44    description: Option<Option<String>>,
45    enabled_events: Option<Vec<String>>,
46    id: Option<stripe_misc::WebhookEndpointId>,
47    livemode: Option<bool>,
48    metadata: Option<std::collections::HashMap<String, String>>,
49    secret: Option<Option<String>>,
50    status: Option<String>,
51    url: Option<String>,
52}
53
54#[allow(
55    unused_variables,
56    irrefutable_let_patterns,
57    clippy::let_unit_value,
58    clippy::match_single_binding,
59    clippy::single_match
60)]
61const _: () = {
62    use miniserde::de::{Map, Visitor};
63    use miniserde::json::Value;
64    use miniserde::{Deserialize, Result, make_place};
65    use stripe_types::miniserde_helpers::FromValueOpt;
66    use stripe_types::{MapBuilder, ObjectDeser};
67
68    make_place!(Place);
69
70    impl Deserialize for WebhookEndpoint {
71        fn begin(out: &mut Option<Self>) -> &mut dyn Visitor {
72            Place::new(out)
73        }
74    }
75
76    struct Builder<'a> {
77        out: &'a mut Option<WebhookEndpoint>,
78        builder: WebhookEndpointBuilder,
79    }
80
81    impl Visitor for Place<WebhookEndpoint> {
82        fn map(&mut self) -> Result<Box<dyn Map + '_>> {
83            Ok(Box::new(Builder {
84                out: &mut self.out,
85                builder: WebhookEndpointBuilder::deser_default(),
86            }))
87        }
88    }
89
90    impl MapBuilder for WebhookEndpointBuilder {
91        type Out = WebhookEndpoint;
92        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
93            Ok(match k {
94                "api_version" => Deserialize::begin(&mut self.api_version),
95                "application" => Deserialize::begin(&mut self.application),
96                "created" => Deserialize::begin(&mut self.created),
97                "description" => Deserialize::begin(&mut self.description),
98                "enabled_events" => Deserialize::begin(&mut self.enabled_events),
99                "id" => Deserialize::begin(&mut self.id),
100                "livemode" => Deserialize::begin(&mut self.livemode),
101                "metadata" => Deserialize::begin(&mut self.metadata),
102                "secret" => Deserialize::begin(&mut self.secret),
103                "status" => Deserialize::begin(&mut self.status),
104                "url" => Deserialize::begin(&mut self.url),
105
106                _ => <dyn Visitor>::ignore(),
107            })
108        }
109
110        fn deser_default() -> Self {
111            Self {
112                api_version: Deserialize::default(),
113                application: Deserialize::default(),
114                created: Deserialize::default(),
115                description: Deserialize::default(),
116                enabled_events: Deserialize::default(),
117                id: Deserialize::default(),
118                livemode: Deserialize::default(),
119                metadata: Deserialize::default(),
120                secret: Deserialize::default(),
121                status: Deserialize::default(),
122                url: Deserialize::default(),
123            }
124        }
125
126        fn take_out(&mut self) -> Option<Self::Out> {
127            let (
128                Some(api_version),
129                Some(application),
130                Some(created),
131                Some(description),
132                Some(enabled_events),
133                Some(id),
134                Some(livemode),
135                Some(metadata),
136                Some(secret),
137                Some(status),
138                Some(url),
139            ) = (
140                self.api_version.take(),
141                self.application.take(),
142                self.created,
143                self.description.take(),
144                self.enabled_events.take(),
145                self.id.take(),
146                self.livemode,
147                self.metadata.take(),
148                self.secret.take(),
149                self.status.take(),
150                self.url.take(),
151            )
152            else {
153                return None;
154            };
155            Some(Self::Out {
156                api_version,
157                application,
158                created,
159                description,
160                enabled_events,
161                id,
162                livemode,
163                metadata,
164                secret,
165                status,
166                url,
167            })
168        }
169    }
170
171    impl Map for Builder<'_> {
172        fn key(&mut self, k: &str) -> Result<&mut dyn Visitor> {
173            self.builder.key(k)
174        }
175
176        fn finish(&mut self) -> Result<()> {
177            *self.out = self.builder.take_out();
178            Ok(())
179        }
180    }
181
182    impl ObjectDeser for WebhookEndpoint {
183        type Builder = WebhookEndpointBuilder;
184    }
185
186    impl FromValueOpt for WebhookEndpoint {
187        fn from_value(v: Value) -> Option<Self> {
188            let Value::Object(obj) = v else {
189                return None;
190            };
191            let mut b = WebhookEndpointBuilder::deser_default();
192            for (k, v) in obj {
193                match k.as_str() {
194                    "api_version" => b.api_version = FromValueOpt::from_value(v),
195                    "application" => b.application = FromValueOpt::from_value(v),
196                    "created" => b.created = FromValueOpt::from_value(v),
197                    "description" => b.description = FromValueOpt::from_value(v),
198                    "enabled_events" => b.enabled_events = FromValueOpt::from_value(v),
199                    "id" => b.id = FromValueOpt::from_value(v),
200                    "livemode" => b.livemode = FromValueOpt::from_value(v),
201                    "metadata" => b.metadata = FromValueOpt::from_value(v),
202                    "secret" => b.secret = FromValueOpt::from_value(v),
203                    "status" => b.status = FromValueOpt::from_value(v),
204                    "url" => b.url = FromValueOpt::from_value(v),
205
206                    _ => {}
207                }
208            }
209            b.take_out()
210        }
211    }
212};
213#[cfg(feature = "serialize")]
214impl serde::Serialize for WebhookEndpoint {
215    fn serialize<S: serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
216        use serde::ser::SerializeStruct;
217        let mut s = s.serialize_struct("WebhookEndpoint", 12)?;
218        s.serialize_field("api_version", &self.api_version)?;
219        s.serialize_field("application", &self.application)?;
220        s.serialize_field("created", &self.created)?;
221        s.serialize_field("description", &self.description)?;
222        s.serialize_field("enabled_events", &self.enabled_events)?;
223        s.serialize_field("id", &self.id)?;
224        s.serialize_field("livemode", &self.livemode)?;
225        s.serialize_field("metadata", &self.metadata)?;
226        s.serialize_field("secret", &self.secret)?;
227        s.serialize_field("status", &self.status)?;
228        s.serialize_field("url", &self.url)?;
229
230        s.serialize_field("object", "webhook_endpoint")?;
231        s.end()
232    }
233}
234impl stripe_types::Object for WebhookEndpoint {
235    type Id = stripe_misc::WebhookEndpointId;
236    fn id(&self) -> &Self::Id {
237        &self.id
238    }
239
240    fn into_id(self) -> Self::Id {
241        self.id
242    }
243}
244stripe_types::def_id!(WebhookEndpointId);