proto_blue_api/generated/tools/ozone/communication/
createTemplate.rs1#![allow(clippy::pedantic, clippy::nursery, clippy::all)]
4
5use serde::{Deserialize, Serialize};
6
7#[derive(Debug, Clone, Serialize, Deserialize)]
10#[serde(rename_all = "camelCase")]
11pub struct Input {
12 pub content_markdown: String,
13 #[serde(skip_serializing_if = "Option::is_none")]
14 pub created_by: Option<proto_blue_syntax::Did>,
15 #[serde(skip_serializing_if = "Option::is_none")]
16 pub lang: Option<String>,
17 pub name: String,
18 pub subject: String,
19}
20
21pub type Output = crate::tools::ozone::communication::defs::TemplateView;
22
23#[derive(Debug, thiserror::Error)]
25pub enum CallError {
26 #[error("DuplicateTemplateName")]
27 DuplicateTemplateName,
28 #[error("{0}")]
29 Xrpc(proto_blue_xrpc::XrpcError),
30 #[error(transparent)]
31 Transport(#[from] proto_blue_xrpc::Error),
32 #[error(transparent)]
33 Json(#[from] serde_json::Error),
34}
35
36fn map_xrpc_error(err: proto_blue_xrpc::XrpcError) -> CallError {
37 match err.error.as_deref() {
38 Some("DuplicateTemplateName") => CallError::DuplicateTemplateName,
39 _ => CallError::Xrpc(err),
40 }
41}
42
43pub async fn call(
45 client: &proto_blue_xrpc::XrpcClient,
46 input: &Input,
47 opts: Option<&proto_blue_xrpc::CallOptions>,
48) -> Result<Output, CallError> {
49 let qp_ref: Option<&proto_blue_xrpc::QueryParams> = None;
50 let body = proto_blue_xrpc::XrpcBody::Json(serde_json::to_value(input)?);
51 let response = match client
52 .procedure(
53 "tools.ozone.communication.createTemplate",
54 qp_ref,
55 Some(body),
56 opts,
57 )
58 .await
59 {
60 Ok(r) => r,
61 Err(proto_blue_xrpc::Error::Xrpc(x)) => return Err(map_xrpc_error(x)),
62 Err(e) => return Err(CallError::Transport(e)),
63 };
64 Ok(serde_json::from_value(response.data)?)
65}
66
67#[cfg(feature = "server")]
69pub fn register<F, Fut>(
70 server: proto_blue_xrpc::XrpcServer,
71 handler: F,
72) -> proto_blue_xrpc::XrpcServer
73where
74 F: Fn(proto_blue_xrpc::HandlerContext, Option<Input>) -> Fut + Send + Sync + 'static,
75 Fut: std::future::Future<Output = Result<Output, proto_blue_xrpc::XrpcServerError>>
76 + Send
77 + 'static,
78{
79 let handler = std::sync::Arc::new(handler);
80 server.procedure("tools.ozone.communication.createTemplate", move |ctx| {
81 let handler = handler.clone();
82 async move {
83 let input = match ctx.json_body()? {
84 Some(v) => Some(serde_json::from_value::<Input>(v).map_err(|e| {
85 proto_blue_xrpc::XrpcServerError::new(
86 proto_blue_xrpc::ResponseType::InvalidRequest,
87 format!("input deserialize: {e}"),
88 )
89 })?),
90 None => None,
91 };
92 let out = handler(ctx, input).await?;
93 let value = serde_json::to_value(&out).map_err(|e| {
94 proto_blue_xrpc::XrpcServerError::new(
95 proto_blue_xrpc::ResponseType::InternalServerError,
96 format!("output serialize: {e}"),
97 )
98 })?;
99 Ok::<_, proto_blue_xrpc::XrpcServerError>(value)
100 }
101 })
102}