1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: tools.ozone.communication.createTemplate
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 jacquard_derive::IntoStatic,
17 Default
18)]
19#[serde(rename_all = "camelCase")]
20pub struct CreateTemplate<'a> {
21 /// Content of the template, markdown supported, can contain variable placeholders.
22 #[serde(borrow)]
23 pub content_markdown: jacquard_common::CowStr<'a>,
24 /// DID of the user who is creating the template.
25 #[serde(skip_serializing_if = "std::option::Option::is_none")]
26 #[serde(borrow)]
27 pub created_by: std::option::Option<jacquard_common::types::string::Did<'a>>,
28 /// Message language.
29 #[serde(skip_serializing_if = "std::option::Option::is_none")]
30 pub lang: std::option::Option<jacquard_common::types::string::Language>,
31 /// Name of the template.
32 #[serde(borrow)]
33 pub name: jacquard_common::CowStr<'a>,
34 /// Subject of the message, used in emails.
35 #[serde(borrow)]
36 pub subject: jacquard_common::CowStr<'a>,
37}
38
39#[jacquard_derive::lexicon]
40#[derive(
41 serde::Serialize,
42 serde::Deserialize,
43 Debug,
44 Clone,
45 PartialEq,
46 Eq,
47 jacquard_derive::IntoStatic
48)]
49#[serde(rename_all = "camelCase")]
50pub struct CreateTemplateOutput<'a> {
51 #[serde(flatten)]
52 #[serde(borrow)]
53 pub value: crate::tools_ozone::communication::TemplateView<'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 CreateTemplateError<'a> {
71 #[serde(rename = "DuplicateTemplateName")]
72 DuplicateTemplateName(std::option::Option<String>),
73}
74
75impl std::fmt::Display for CreateTemplateError<'_> {
76 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
77 match self {
78 Self::DuplicateTemplateName(msg) => {
79 write!(f, "DuplicateTemplateName")?;
80 if let Some(msg) = msg {
81 write!(f, ": {}", msg)?;
82 }
83 Ok(())
84 }
85 Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
86 }
87 }
88}
89
90///Response type for
91///tools.ozone.communication.createTemplate
92pub struct CreateTemplateResponse;
93impl jacquard_common::xrpc::XrpcResp for CreateTemplateResponse {
94 const NSID: &'static str = "tools.ozone.communication.createTemplate";
95 const ENCODING: &'static str = "application/json";
96 type Output<'de> = CreateTemplateOutput<'de>;
97 type Err<'de> = CreateTemplateError<'de>;
98}
99
100impl<'a> jacquard_common::xrpc::XrpcRequest for CreateTemplate<'a> {
101 const NSID: &'static str = "tools.ozone.communication.createTemplate";
102 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
103 "application/json",
104 );
105 type Response = CreateTemplateResponse;
106}
107
108///Endpoint type for
109///tools.ozone.communication.createTemplate
110pub struct CreateTemplateRequest;
111impl jacquard_common::xrpc::XrpcEndpoint for CreateTemplateRequest {
112 const PATH: &'static str = "/xrpc/tools.ozone.communication.createTemplate";
113 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
114 "application/json",
115 );
116 type Request<'de> = CreateTemplate<'de>;
117 type Response = CreateTemplateResponse;
118}