1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: com.atproto.identity.resolveHandle
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)]
17#[builder(start_fn = new)]
18#[serde(rename_all = "camelCase")]
19pub struct ResolveHandle<'a> {
20 #[serde(borrow)]
21 pub handle: jacquard_common::types::string::Handle<'a>,
22}
23
24impl jacquard_common::IntoStatic for ResolveHandle<'_> {
25 type Output = ResolveHandle<'static>;
26 fn into_static(self) -> Self::Output {
27 ResolveHandle {
28 handle: self.handle.into_static(),
29 }
30 }
31}
32
33#[jacquard_derive::lexicon]
34#[derive(serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq)]
35#[serde(rename_all = "camelCase")]
36pub struct ResolveHandleOutput<'a> {
37 #[serde(borrow)]
38 pub did: jacquard_common::types::string::Did<'a>,
39}
40
41impl jacquard_common::IntoStatic for ResolveHandleOutput<'_> {
42 type Output = ResolveHandleOutput<'static>;
43 fn into_static(self) -> Self::Output {
44 ResolveHandleOutput {
45 did: self.did.into_static(),
46 extra_data: self.extra_data.into_static(),
47 }
48 }
49}
50
51#[jacquard_derive::open_union]
52#[derive(
53 serde::Serialize,
54 serde::Deserialize,
55 Debug,
56 Clone,
57 PartialEq,
58 Eq,
59 thiserror::Error,
60 miette::Diagnostic
61)]
62#[serde(tag = "error", content = "message")]
63#[serde(bound(deserialize = "'de: 'a"))]
64pub enum ResolveHandleError<'a> {
65 ///The resolution process confirmed that the handle does not resolve to any DID.
66 #[serde(rename = "HandleNotFound")]
67 HandleNotFound(std::option::Option<String>),
68}
69
70impl std::fmt::Display for ResolveHandleError<'_> {
71 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
72 match self {
73 Self::HandleNotFound(msg) => {
74 write!(f, "HandleNotFound")?;
75 if let Some(msg) = msg {
76 write!(f, ": {}", msg)?;
77 }
78 Ok(())
79 }
80 Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
81 }
82 }
83}
84
85impl jacquard_common::IntoStatic for ResolveHandleError<'_> {
86 type Output = ResolveHandleError<'static>;
87 fn into_static(self) -> Self::Output {
88 match self {
89 ResolveHandleError::HandleNotFound(v) => {
90 ResolveHandleError::HandleNotFound(v.into_static())
91 }
92 ResolveHandleError::Unknown(v) => {
93 ResolveHandleError::Unknown(v.into_static())
94 }
95 }
96 }
97}
98
99impl jacquard_common::types::xrpc::XrpcRequest for ResolveHandle<'_> {
100 const NSID: &'static str = "com.atproto.identity.resolveHandle";
101 const METHOD: jacquard_common::types::xrpc::XrpcMethod = jacquard_common::types::xrpc::XrpcMethod::Query;
102 const OUTPUT_ENCODING: &'static str = "application/json";
103 type Output<'de> = ResolveHandleOutput<'de>;
104 type Err<'de> = ResolveHandleError<'de>;
105}