A better Rust ATProto crate
at lifetimes 4.5 kB view raw
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)] 52#[serde(tag = "error", content = "message")] 53#[serde(bound(deserialize = "'de: 'a"))] 54pub enum UpdateEmailError<'a> { 55 #[serde(rename = "ExpiredToken")] 56 ExpiredToken(std::option::Option<String>), 57 #[serde(rename = "InvalidToken")] 58 InvalidToken(std::option::Option<String>), 59 #[serde(rename = "TokenRequired")] 60 TokenRequired(std::option::Option<String>), 61} 62 63impl std::fmt::Display for UpdateEmailError<'_> { 64 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { 65 match self { 66 Self::ExpiredToken(msg) => { 67 write!(f, "ExpiredToken")?; 68 if let Some(msg) = msg { 69 write!(f, ": {}", msg)?; 70 } 71 Ok(()) 72 } 73 Self::InvalidToken(msg) => { 74 write!(f, "InvalidToken")?; 75 if let Some(msg) = msg { 76 write!(f, ": {}", msg)?; 77 } 78 Ok(()) 79 } 80 Self::TokenRequired(msg) => { 81 write!(f, "TokenRequired")?; 82 if let Some(msg) = msg { 83 write!(f, ": {}", msg)?; 84 } 85 Ok(()) 86 } 87 Self::Unknown(err) => write!(f, "Unknown error: {:?}", err), 88 } 89 } 90} 91 92impl jacquard_common::IntoStatic for UpdateEmailError<'_> { 93 type Output = UpdateEmailError<'static>; 94 fn into_static(self) -> Self::Output { 95 match self { 96 UpdateEmailError::ExpiredToken(v) => { 97 UpdateEmailError::ExpiredToken(v.into_static()) 98 } 99 UpdateEmailError::InvalidToken(v) => { 100 UpdateEmailError::InvalidToken(v.into_static()) 101 } 102 UpdateEmailError::TokenRequired(v) => { 103 UpdateEmailError::TokenRequired(v.into_static()) 104 } 105 UpdateEmailError::Unknown(v) => UpdateEmailError::Unknown(v.into_static()), 106 } 107 } 108} 109 110///Response type for 111///com.atproto.server.updateEmail 112pub struct UpdateEmailResponse; 113impl jacquard_common::xrpc::XrpcResp for UpdateEmailResponse { 114 const NSID: &'static str = "com.atproto.server.updateEmail"; 115 const ENCODING: &'static str = "application/json"; 116 type Output<'de> = (); 117 type Err<'de> = UpdateEmailError<'de>; 118} 119 120impl<'de> jacquard_common::xrpc::XrpcRequest<'de> for UpdateEmail<'de> { 121 const NSID: &'static str = "com.atproto.server.updateEmail"; 122 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure( 123 "application/json", 124 ); 125 type Response = UpdateEmailResponse; 126} 127 128///Endpoint type for 129///com.atproto.server.updateEmail 130pub struct UpdateEmailRequest; 131impl jacquard_common::xrpc::XrpcEndpoint for UpdateEmailRequest { 132 const PATH: &'static str = "/xrpc/com.atproto.server.updateEmail"; 133 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure( 134 "application/json", 135 ); 136 type Request<'de> = UpdateEmail<'de>; 137 type Response = UpdateEmailResponse; 138}