1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: app.ocho.auth.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///app.ocho.auth.updateEmail
85pub struct UpdateEmailResponse;
86impl jacquard_common::xrpc::XrpcResp for UpdateEmailResponse {
87 const NSID: &'static str = "app.ocho.auth.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 = "app.ocho.auth.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///app.ocho.auth.updateEmail
103pub struct UpdateEmailRequest;
104impl jacquard_common::xrpc::XrpcEndpoint for UpdateEmailRequest {
105 const PATH: &'static str = "/xrpc/app.ocho.auth.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}