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