A better Rust ATProto crate
at main 3.9 kB view raw
1// @generated by jacquard-lexicon. DO NOT EDIT. 2// 3// Lexicon: app.bsky.feed.getPostThread 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 jacquard_derive::IntoStatic 17)] 18#[builder(start_fn = new)] 19#[serde(rename_all = "camelCase")] 20pub struct GetPostThread<'a> { 21 ///(default: 6, min: 0, max: 1000) 22 #[serde(skip_serializing_if = "std::option::Option::is_none")] 23 pub depth: std::option::Option<i64>, 24 ///(default: 80, min: 0, max: 1000) 25 #[serde(skip_serializing_if = "std::option::Option::is_none")] 26 pub parent_height: std::option::Option<i64>, 27 #[serde(borrow)] 28 pub uri: jacquard_common::types::string::AtUri<'a>, 29} 30 31#[jacquard_derive::lexicon] 32#[derive( 33 serde::Serialize, 34 serde::Deserialize, 35 Debug, 36 Clone, 37 PartialEq, 38 Eq, 39 jacquard_derive::IntoStatic 40)] 41#[serde(rename_all = "camelCase")] 42pub struct GetPostThreadOutput<'a> { 43 #[serde(borrow)] 44 pub thread: GetPostThreadOutputThread<'a>, 45 #[serde(skip_serializing_if = "std::option::Option::is_none")] 46 #[serde(borrow)] 47 pub threadgate: std::option::Option<crate::app_bsky::feed::ThreadgateView<'a>>, 48} 49 50#[jacquard_derive::open_union] 51#[derive( 52 serde::Serialize, 53 serde::Deserialize, 54 Debug, 55 Clone, 56 PartialEq, 57 Eq, 58 jacquard_derive::IntoStatic 59)] 60#[serde(tag = "$type")] 61#[serde(bound(deserialize = "'de: 'a"))] 62pub enum GetPostThreadOutputThread<'a> { 63 #[serde(rename = "app.bsky.feed.defs#threadViewPost")] 64 ThreadViewPost(Box<crate::app_bsky::feed::ThreadViewPost<'a>>), 65 #[serde(rename = "app.bsky.feed.defs#notFoundPost")] 66 NotFoundPost(Box<crate::app_bsky::feed::NotFoundPost<'a>>), 67 #[serde(rename = "app.bsky.feed.defs#blockedPost")] 68 BlockedPost(Box<crate::app_bsky::feed::BlockedPost<'a>>), 69} 70 71#[jacquard_derive::open_union] 72#[derive( 73 serde::Serialize, 74 serde::Deserialize, 75 Debug, 76 Clone, 77 PartialEq, 78 Eq, 79 thiserror::Error, 80 miette::Diagnostic, 81 jacquard_derive::IntoStatic 82)] 83#[serde(tag = "error", content = "message")] 84#[serde(bound(deserialize = "'de: 'a"))] 85pub enum GetPostThreadError<'a> { 86 #[serde(rename = "NotFound")] 87 NotFound(std::option::Option<String>), 88} 89 90impl std::fmt::Display for GetPostThreadError<'_> { 91 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { 92 match self { 93 Self::NotFound(msg) => { 94 write!(f, "NotFound")?; 95 if let Some(msg) = msg { 96 write!(f, ": {}", msg)?; 97 } 98 Ok(()) 99 } 100 Self::Unknown(err) => write!(f, "Unknown error: {:?}", err), 101 } 102 } 103} 104 105///Response type for 106///app.bsky.feed.getPostThread 107pub struct GetPostThreadResponse; 108impl jacquard_common::xrpc::XrpcResp for GetPostThreadResponse { 109 const NSID: &'static str = "app.bsky.feed.getPostThread"; 110 const ENCODING: &'static str = "application/json"; 111 type Output<'de> = GetPostThreadOutput<'de>; 112 type Err<'de> = GetPostThreadError<'de>; 113} 114 115impl<'a> jacquard_common::xrpc::XrpcRequest for GetPostThread<'a> { 116 const NSID: &'static str = "app.bsky.feed.getPostThread"; 117 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query; 118 type Response = GetPostThreadResponse; 119} 120 121///Endpoint type for 122///app.bsky.feed.getPostThread 123pub struct GetPostThreadRequest; 124impl jacquard_common::xrpc::XrpcEndpoint for GetPostThreadRequest { 125 const PATH: &'static str = "/xrpc/app.bsky.feed.getPostThread"; 126 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query; 127 type Request<'de> = GetPostThread<'de>; 128 type Response = GetPostThreadResponse; 129}