jacquard_api/place_stream/server/
create_webhook.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: place.stream.server.createWebhook
4//
5// This file was automatically generated from Lexicon schemas.
6// Any manual changes will be overwritten on the next regeneration.
7
8#[jacquard_derive::lexicon]
9#[derive(
10    serde::Serialize,
11    serde::Deserialize,
12    Debug,
13    Clone,
14    PartialEq,
15    Eq,
16    bon::Builder,
17    jacquard_derive::IntoStatic
18)]
19#[serde(rename_all = "camelCase")]
20#[builder(start_fn = new)]
21pub struct CreateWebhook<'a> {
22    ///Whether this webhook should be active upon creation.
23    #[serde(skip_serializing_if = "std::option::Option::is_none")]
24    pub active: std::option::Option<bool>,
25    ///A description of what this webhook is used for.
26    #[serde(skip_serializing_if = "std::option::Option::is_none")]
27    #[serde(borrow)]
28    #[builder(into)]
29    pub description: std::option::Option<jacquard_common::CowStr<'a>>,
30    ///The types of events this webhook should receive.
31    #[serde(borrow)]
32    pub events: Vec<jacquard_common::CowStr<'a>>,
33    ///A user-friendly name for this webhook.
34    #[serde(skip_serializing_if = "std::option::Option::is_none")]
35    #[serde(borrow)]
36    #[builder(into)]
37    pub name: std::option::Option<jacquard_common::CowStr<'a>>,
38    ///Text to prepend to webhook messages.
39    #[serde(skip_serializing_if = "std::option::Option::is_none")]
40    #[serde(borrow)]
41    #[builder(into)]
42    pub prefix: std::option::Option<jacquard_common::CowStr<'a>>,
43    ///Text replacement rules for webhook messages.
44    #[serde(skip_serializing_if = "std::option::Option::is_none")]
45    #[serde(borrow)]
46    pub rewrite: std::option::Option<Vec<crate::place_stream::server::RewriteRule<'a>>>,
47    ///Text to append to webhook messages.
48    #[serde(skip_serializing_if = "std::option::Option::is_none")]
49    #[serde(borrow)]
50    #[builder(into)]
51    pub suffix: std::option::Option<jacquard_common::CowStr<'a>>,
52    ///The webhook URL where events will be sent.
53    #[serde(borrow)]
54    pub url: jacquard_common::types::string::Uri<'a>,
55    #[serde(flatten)]
56    #[serde(borrow)]
57    #[builder(default)]
58    pub extra_data: ::std::collections::BTreeMap<
59        ::jacquard_common::smol_str::SmolStr,
60        ::jacquard_common::types::value::Data<'a>,
61    >,
62}
63
64#[jacquard_derive::lexicon]
65#[derive(
66    serde::Serialize,
67    serde::Deserialize,
68    Debug,
69    Clone,
70    PartialEq,
71    Eq,
72    jacquard_derive::IntoStatic
73)]
74#[serde(rename_all = "camelCase")]
75pub struct CreateWebhookOutput<'a> {
76    #[serde(borrow)]
77    pub webhook: crate::place_stream::server::Webhook<'a>,
78}
79
80#[jacquard_derive::open_union]
81#[derive(
82    serde::Serialize,
83    serde::Deserialize,
84    Debug,
85    Clone,
86    PartialEq,
87    Eq,
88    thiserror::Error,
89    miette::Diagnostic
90)]
91#[serde(tag = "error", content = "message")]
92#[serde(bound(deserialize = "'de: 'a"))]
93pub enum CreateWebhookError<'a> {
94    ///The provided webhook URL is invalid or unreachable.
95    #[serde(rename = "InvalidUrl")]
96    InvalidUrl(std::option::Option<String>),
97    ///A webhook with this URL already exists for this user.
98    #[serde(rename = "DuplicateWebhook")]
99    DuplicateWebhook(std::option::Option<String>),
100    ///The user has reached their maximum number of webhooks.
101    #[serde(rename = "TooManyWebhooks")]
102    TooManyWebhooks(std::option::Option<String>),
103}
104
105impl std::fmt::Display for CreateWebhookError<'_> {
106    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
107        match self {
108            Self::InvalidUrl(msg) => {
109                write!(f, "InvalidUrl")?;
110                if let Some(msg) = msg {
111                    write!(f, ": {}", msg)?;
112                }
113                Ok(())
114            }
115            Self::DuplicateWebhook(msg) => {
116                write!(f, "DuplicateWebhook")?;
117                if let Some(msg) = msg {
118                    write!(f, ": {}", msg)?;
119                }
120                Ok(())
121            }
122            Self::TooManyWebhooks(msg) => {
123                write!(f, "TooManyWebhooks")?;
124                if let Some(msg) = msg {
125                    write!(f, ": {}", msg)?;
126                }
127                Ok(())
128            }
129            Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
130        }
131    }
132}
133
134impl jacquard_common::IntoStatic for CreateWebhookError<'_> {
135    type Output = CreateWebhookError<'static>;
136    fn into_static(self) -> Self::Output {
137        match self {
138            CreateWebhookError::InvalidUrl(v) => {
139                CreateWebhookError::InvalidUrl(v.into_static())
140            }
141            CreateWebhookError::DuplicateWebhook(v) => {
142                CreateWebhookError::DuplicateWebhook(v.into_static())
143            }
144            CreateWebhookError::TooManyWebhooks(v) => {
145                CreateWebhookError::TooManyWebhooks(v.into_static())
146            }
147            CreateWebhookError::Unknown(v) => {
148                CreateWebhookError::Unknown(v.into_static())
149            }
150        }
151    }
152}
153
154///Response type for
155///place.stream.server.createWebhook
156pub struct CreateWebhookResponse;
157impl jacquard_common::xrpc::XrpcResp for CreateWebhookResponse {
158    const NSID: &'static str = "place.stream.server.createWebhook";
159    const ENCODING: &'static str = "application/json";
160    type Output<'de> = CreateWebhookOutput<'de>;
161    type Err<'de> = CreateWebhookError<'de>;
162}
163
164impl<'de> jacquard_common::xrpc::XrpcRequest<'de> for CreateWebhook<'de> {
165    const NSID: &'static str = "place.stream.server.createWebhook";
166    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
167        "application/json",
168    );
169    type Response = CreateWebhookResponse;
170}
171
172///Endpoint type for
173///place.stream.server.createWebhook
174pub struct CreateWebhookRequest;
175impl jacquard_common::xrpc::XrpcEndpoint for CreateWebhookRequest {
176    const PATH: &'static str = "/xrpc/place.stream.server.createWebhook";
177    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
178        "application/json",
179    );
180    type Request<'de> = CreateWebhook<'de>;
181    type Response = CreateWebhookResponse;
182}