A better Rust ATProto crate
1// @generated by jacquard-lexicon. DO NOT EDIT. 2// 3// Lexicon: com.atproto.sync.getHostStatus 4// 5// This file was automatically generated from Lexicon schemas. 6// Any manual changes will be overwritten on the next regeneration. 7 8#[derive( 9 serde::Serialize, 10 serde::Deserialize, 11 Debug, 12 Clone, 13 PartialEq, 14 Eq, 15 bon::Builder 16)] 17#[builder(start_fn = new)] 18#[serde(rename_all = "camelCase")] 19pub struct GetHostStatus<'a> { 20 #[serde(borrow)] 21 #[builder(into)] 22 pub hostname: jacquard_common::CowStr<'a>, 23} 24 25impl jacquard_common::IntoStatic for GetHostStatus<'_> { 26 type Output = GetHostStatus<'static>; 27 fn into_static(self) -> Self::Output { 28 GetHostStatus { 29 hostname: self.hostname.into_static(), 30 } 31 } 32} 33 34#[jacquard_derive::lexicon] 35#[derive(serde::Serialize, serde::Deserialize, Debug, Clone, PartialEq, Eq)] 36#[serde(rename_all = "camelCase")] 37pub struct GetHostStatusOutput<'a> { 38 ///Number of accounts on the server which are associated with the upstream host. Note that the upstream may actually have more accounts. 39 #[serde(skip_serializing_if = "std::option::Option::is_none")] 40 pub account_count: std::option::Option<i64>, 41 #[serde(borrow)] 42 pub hostname: jacquard_common::CowStr<'a>, 43 ///Recent repo stream event sequence number. May be delayed from actual stream processing (eg, persisted cursor not in-memory cursor). 44 #[serde(skip_serializing_if = "std::option::Option::is_none")] 45 pub seq: std::option::Option<i64>, 46 #[serde(skip_serializing_if = "std::option::Option::is_none")] 47 #[serde(borrow)] 48 pub status: std::option::Option<crate::com_atproto::sync::HostStatus<'a>>, 49} 50 51impl jacquard_common::IntoStatic for GetHostStatusOutput<'_> { 52 type Output = GetHostStatusOutput<'static>; 53 fn into_static(self) -> Self::Output { 54 GetHostStatusOutput { 55 account_count: self.account_count.into_static(), 56 hostname: self.hostname.into_static(), 57 seq: self.seq.into_static(), 58 status: self.status.into_static(), 59 extra_data: self.extra_data.into_static(), 60 } 61 } 62} 63 64#[jacquard_derive::open_union] 65#[derive( 66 serde::Serialize, 67 serde::Deserialize, 68 Debug, 69 Clone, 70 PartialEq, 71 Eq, 72 thiserror::Error, 73 miette::Diagnostic 74)] 75#[serde(tag = "error", content = "message")] 76#[serde(bound(deserialize = "'de: 'a"))] 77pub enum GetHostStatusError<'a> { 78 #[serde(rename = "HostNotFound")] 79 HostNotFound(std::option::Option<String>), 80} 81 82impl std::fmt::Display for GetHostStatusError<'_> { 83 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { 84 match self { 85 Self::HostNotFound(msg) => { 86 write!(f, "HostNotFound")?; 87 if let Some(msg) = msg { 88 write!(f, ": {}", msg)?; 89 } 90 Ok(()) 91 } 92 Self::Unknown(err) => write!(f, "Unknown error: {:?}", err), 93 } 94 } 95} 96 97impl jacquard_common::IntoStatic for GetHostStatusError<'_> { 98 type Output = GetHostStatusError<'static>; 99 fn into_static(self) -> Self::Output { 100 match self { 101 GetHostStatusError::HostNotFound(v) => { 102 GetHostStatusError::HostNotFound(v.into_static()) 103 } 104 GetHostStatusError::Unknown(v) => { 105 GetHostStatusError::Unknown(v.into_static()) 106 } 107 } 108 } 109} 110 111impl jacquard_common::types::xrpc::XrpcRequest for GetHostStatus<'_> { 112 const NSID: &'static str = "com.atproto.sync.getHostStatus"; 113 const METHOD: jacquard_common::types::xrpc::XrpcMethod = jacquard_common::types::xrpc::XrpcMethod::Query; 114 const OUTPUT_ENCODING: &'static str = "application/json"; 115 type Output<'de> = GetHostStatusOutput<'de>; 116 type Err<'de> = GetHostStatusError<'de>; 117}