jacquard_api/com_atproto/server/
update_email.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: com.atproto.server.updateEmail
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 UpdateEmail<'a> {
21    #[serde(borrow)]
22    pub email: jacquard_common::CowStr<'a>,
23    #[serde(skip_serializing_if = "std::option::Option::is_none")]
24    pub email_auth_factor: std::option::Option<bool>,
25    /// Requires a token from com.atproto.sever.requestEmailUpdate if the account's email has been confirmed.
26    #[serde(skip_serializing_if = "std::option::Option::is_none")]
27    #[serde(borrow)]
28    pub token: std::option::Option<jacquard_common::CowStr<'a>>,
29}
30
31#[jacquard_derive::open_union]
32#[derive(
33    serde::Serialize,
34    serde::Deserialize,
35    Debug,
36    Clone,
37    PartialEq,
38    Eq,
39    thiserror::Error,
40    miette::Diagnostic,
41    jacquard_derive::IntoStatic
42)]
43#[serde(tag = "error", content = "message")]
44#[serde(bound(deserialize = "'de: 'a"))]
45pub enum UpdateEmailError<'a> {
46    #[serde(rename = "ExpiredToken")]
47    ExpiredToken(std::option::Option<String>),
48    #[serde(rename = "InvalidToken")]
49    InvalidToken(std::option::Option<String>),
50    #[serde(rename = "TokenRequired")]
51    TokenRequired(std::option::Option<String>),
52}
53
54impl std::fmt::Display for UpdateEmailError<'_> {
55    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
56        match self {
57            Self::ExpiredToken(msg) => {
58                write!(f, "ExpiredToken")?;
59                if let Some(msg) = msg {
60                    write!(f, ": {}", msg)?;
61                }
62                Ok(())
63            }
64            Self::InvalidToken(msg) => {
65                write!(f, "InvalidToken")?;
66                if let Some(msg) = msg {
67                    write!(f, ": {}", msg)?;
68                }
69                Ok(())
70            }
71            Self::TokenRequired(msg) => {
72                write!(f, "TokenRequired")?;
73                if let Some(msg) = msg {
74                    write!(f, ": {}", msg)?;
75                }
76                Ok(())
77            }
78            Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
79        }
80    }
81}
82
83/// Response type for
84///com.atproto.server.updateEmail
85pub struct UpdateEmailResponse;
86impl jacquard_common::xrpc::XrpcResp for UpdateEmailResponse {
87    const NSID: &'static str = "com.atproto.server.updateEmail";
88    const ENCODING: &'static str = "application/json";
89    type Output<'de> = ();
90    type Err<'de> = UpdateEmailError<'de>;
91}
92
93impl<'a> jacquard_common::xrpc::XrpcRequest for UpdateEmail<'a> {
94    const NSID: &'static str = "com.atproto.server.updateEmail";
95    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
96        "application/json",
97    );
98    type Response = UpdateEmailResponse;
99}
100
101/// Endpoint type for
102///com.atproto.server.updateEmail
103pub struct UpdateEmailRequest;
104impl jacquard_common::xrpc::XrpcEndpoint for UpdateEmailRequest {
105    const PATH: &'static str = "/xrpc/com.atproto.server.updateEmail";
106    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
107        "application/json",
108    );
109    type Request<'de> = UpdateEmail<'de>;
110    type Response = UpdateEmailResponse;
111}