A better Rust ATProto crate
at main 3.5 kB view raw
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}