A better Rust ATProto crate
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}