Skip to main content

jacquard_api/place_stream/multistream/
delete_target.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: place.stream.multistream.deleteTarget
4//
5// This file was automatically generated from Lexicon schemas.
6// Any manual changes will be overwritten on the next regeneration.
7
8#[allow(unused_imports)]
9use alloc::collections::BTreeMap;
10
11#[allow(unused_imports)]
12use core::marker::PhantomData;
13use jacquard_common::types::string::{RecordKey, Rkey};
14use jacquard_derive::{IntoStatic, lexicon};
15use serde::{Serialize, Deserialize};
16
17#[lexicon]
18#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic)]
19#[serde(rename_all = "camelCase")]
20pub struct DeleteTarget<'a> {
21    ///The Record Key of the target to delete.
22    #[serde(borrow)]
23    pub rkey: RecordKey<Rkey<'a>>,
24}
25
26
27#[lexicon]
28#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic, Default)]
29#[serde(rename_all = "camelCase")]
30pub struct DeleteTargetOutput<'a> {}
31
32#[jacquard_derive::open_union]
33#[derive(
34    Serialize,
35    Deserialize,
36    Debug,
37    Clone,
38    PartialEq,
39    Eq,
40    thiserror::Error,
41    miette::Diagnostic,
42    IntoStatic
43)]
44
45#[serde(tag = "error", content = "message")]
46#[serde(bound(deserialize = "'de: 'a"))]
47pub enum DeleteTargetError<'a> {}
48impl core::fmt::Display for DeleteTargetError<'_> {
49    fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
50        match self {
51            Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
52        }
53    }
54}
55
56/// Response type for place.stream.multistream.deleteTarget
57pub struct DeleteTargetResponse;
58impl jacquard_common::xrpc::XrpcResp for DeleteTargetResponse {
59    const NSID: &'static str = "place.stream.multistream.deleteTarget";
60    const ENCODING: &'static str = "application/json";
61    type Output<'de> = DeleteTargetOutput<'de>;
62    type Err<'de> = DeleteTargetError<'de>;
63}
64
65impl<'a> jacquard_common::xrpc::XrpcRequest for DeleteTarget<'a> {
66    const NSID: &'static str = "place.stream.multistream.deleteTarget";
67    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
68        "application/json",
69    );
70    type Response = DeleteTargetResponse;
71}
72
73/// Endpoint type for place.stream.multistream.deleteTarget
74pub struct DeleteTargetRequest;
75impl jacquard_common::xrpc::XrpcEndpoint for DeleteTargetRequest {
76    const PATH: &'static str = "/xrpc/place.stream.multistream.deleteTarget";
77    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
78        "application/json",
79    );
80    type Request<'de> = DeleteTarget<'de>;
81    type Response = DeleteTargetResponse;
82}
83
84pub mod delete_target_state {
85
86    pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
87    #[allow(unused)]
88    use ::core::marker::PhantomData;
89    mod sealed {
90        pub trait Sealed {}
91    }
92    /// State trait tracking which required fields have been set
93    pub trait State: sealed::Sealed {
94        type Rkey;
95    }
96    /// Empty state - all required fields are unset
97    pub struct Empty(());
98    impl sealed::Sealed for Empty {}
99    impl State for Empty {
100        type Rkey = Unset;
101    }
102    ///State transition - sets the `rkey` field to Set
103    pub struct SetRkey<S: State = Empty>(PhantomData<fn() -> S>);
104    impl<S: State> sealed::Sealed for SetRkey<S> {}
105    impl<S: State> State for SetRkey<S> {
106        type Rkey = Set<members::rkey>;
107    }
108    /// Marker types for field names
109    #[allow(non_camel_case_types)]
110    pub mod members {
111        ///Marker type for the `rkey` field
112        pub struct rkey(());
113    }
114}
115
116/// Builder for constructing an instance of this type
117pub struct DeleteTargetBuilder<'a, S: delete_target_state::State> {
118    _state: PhantomData<fn() -> S>,
119    _fields: (Option<RecordKey<Rkey<'a>>>,),
120    _lifetime: PhantomData<&'a ()>,
121}
122
123impl<'a> DeleteTarget<'a> {
124    /// Create a new builder for this type
125    pub fn new() -> DeleteTargetBuilder<'a, delete_target_state::Empty> {
126        DeleteTargetBuilder::new()
127    }
128}
129
130impl<'a> DeleteTargetBuilder<'a, delete_target_state::Empty> {
131    /// Create a new builder with all fields unset
132    pub fn new() -> Self {
133        DeleteTargetBuilder {
134            _state: PhantomData,
135            _fields: (None,),
136            _lifetime: PhantomData,
137        }
138    }
139}
140
141impl<'a, S> DeleteTargetBuilder<'a, S>
142where
143    S: delete_target_state::State,
144    S::Rkey: delete_target_state::IsUnset,
145{
146    /// Set the `rkey` field (required)
147    pub fn rkey(
148        mut self,
149        value: impl Into<RecordKey<Rkey<'a>>>,
150    ) -> DeleteTargetBuilder<'a, delete_target_state::SetRkey<S>> {
151        self._fields.0 = Option::Some(value.into());
152        DeleteTargetBuilder {
153            _state: PhantomData,
154            _fields: self._fields,
155            _lifetime: PhantomData,
156        }
157    }
158}
159
160impl<'a, S> DeleteTargetBuilder<'a, S>
161where
162    S: delete_target_state::State,
163    S::Rkey: delete_target_state::IsSet,
164{
165    /// Build the final struct
166    pub fn build(self) -> DeleteTarget<'a> {
167        DeleteTarget {
168            rkey: self._fields.0.unwrap(),
169            extra_data: Default::default(),
170        }
171    }
172    /// Build the final struct with custom extra_data
173    pub fn build_with_data(
174        self,
175        extra_data: BTreeMap<
176            jacquard_common::deps::smol_str::SmolStr,
177            jacquard_common::types::value::Data<'a>,
178        >,
179    ) -> DeleteTarget<'a> {
180        DeleteTarget {
181            rkey: self._fields.0.unwrap(),
182            extra_data: Some(extra_data),
183        }
184    }
185}