jacquard_api/place_stream/server/
list_webhooks.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: place.stream.server.listWebhooks
4//
5// This file was automatically generated from Lexicon schemas.
6// Any manual changes will be overwritten on the next regeneration.
7
8#[derive(
9    serde::Serialize,
10    serde::Deserialize,
11    Debug,
12    Clone,
13    PartialEq,
14    Eq,
15    bon::Builder,
16    jacquard_derive::IntoStatic
17)]
18#[builder(start_fn = new)]
19#[serde(rename_all = "camelCase")]
20pub struct ListWebhooks<'a> {
21    #[serde(skip_serializing_if = "std::option::Option::is_none")]
22    pub active: std::option::Option<bool>,
23    #[serde(skip_serializing_if = "std::option::Option::is_none")]
24    #[serde(borrow)]
25    #[builder(into)]
26    pub cursor: std::option::Option<jacquard_common::CowStr<'a>>,
27    #[serde(skip_serializing_if = "std::option::Option::is_none")]
28    #[serde(borrow)]
29    #[builder(into)]
30    pub event: std::option::Option<jacquard_common::CowStr<'a>>,
31    ///(default: 50, min: 1, max: 100)
32    #[serde(skip_serializing_if = "std::option::Option::is_none")]
33    pub limit: std::option::Option<i64>,
34}
35
36#[jacquard_derive::lexicon]
37#[derive(
38    serde::Serialize,
39    serde::Deserialize,
40    Debug,
41    Clone,
42    PartialEq,
43    Eq,
44    jacquard_derive::IntoStatic
45)]
46#[serde(rename_all = "camelCase")]
47pub struct ListWebhooksOutput<'a> {
48    ///A cursor for pagination, if there are more results.
49    #[serde(skip_serializing_if = "std::option::Option::is_none")]
50    #[serde(borrow)]
51    pub cursor: std::option::Option<jacquard_common::CowStr<'a>>,
52    #[serde(borrow)]
53    pub webhooks: Vec<crate::place_stream::server::Webhook<'a>>,
54}
55
56#[jacquard_derive::open_union]
57#[derive(
58    serde::Serialize,
59    serde::Deserialize,
60    Debug,
61    Clone,
62    PartialEq,
63    Eq,
64    thiserror::Error,
65    miette::Diagnostic,
66    jacquard_derive::IntoStatic
67)]
68#[serde(tag = "error", content = "message")]
69#[serde(bound(deserialize = "'de: 'a"))]
70pub enum ListWebhooksError<'a> {
71    ///The provided cursor is invalid or expired.
72    #[serde(rename = "InvalidCursor")]
73    InvalidCursor(std::option::Option<String>),
74}
75
76impl std::fmt::Display for ListWebhooksError<'_> {
77    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
78        match self {
79            Self::InvalidCursor(msg) => {
80                write!(f, "InvalidCursor")?;
81                if let Some(msg) = msg {
82                    write!(f, ": {}", msg)?;
83                }
84                Ok(())
85            }
86            Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
87        }
88    }
89}
90
91///Response type for
92///place.stream.server.listWebhooks
93pub struct ListWebhooksResponse;
94impl jacquard_common::xrpc::XrpcResp for ListWebhooksResponse {
95    const NSID: &'static str = "place.stream.server.listWebhooks";
96    const ENCODING: &'static str = "application/json";
97    type Output<'de> = ListWebhooksOutput<'de>;
98    type Err<'de> = ListWebhooksError<'de>;
99}
100
101impl<'de> jacquard_common::xrpc::XrpcRequest<'de> for ListWebhooks<'de> {
102    const NSID: &'static str = "place.stream.server.listWebhooks";
103    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
104    type Response = ListWebhooksResponse;
105}
106
107///Endpoint type for
108///place.stream.server.listWebhooks
109pub struct ListWebhooksRequest;
110impl jacquard_common::xrpc::XrpcEndpoint for ListWebhooksRequest {
111    const PATH: &'static str = "/xrpc/place.stream.server.listWebhooks";
112    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
113    type Request<'de> = ListWebhooks<'de>;
114    type Response = ListWebhooksResponse;
115}