jacquard_api/com_atproto/server/
refresh_session.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: com.atproto.server.refreshSession
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)]
18#[serde(rename_all = "camelCase")]
19pub struct RefreshSessionOutput<'a> {
20    #[serde(borrow)]
21    pub access_jwt: jacquard_common::CowStr<'a>,
22    #[serde(skip_serializing_if = "std::option::Option::is_none")]
23    pub active: std::option::Option<bool>,
24    #[serde(borrow)]
25    pub did: jacquard_common::types::string::Did<'a>,
26    #[serde(skip_serializing_if = "std::option::Option::is_none")]
27    #[serde(borrow)]
28    pub did_doc: std::option::Option<jacquard_common::types::value::Data<'a>>,
29    #[serde(borrow)]
30    pub handle: jacquard_common::types::string::Handle<'a>,
31    #[serde(borrow)]
32    pub refresh_jwt: jacquard_common::CowStr<'a>,
33    ///Hosting status of the account. If not specified, then assume 'active'.
34    #[serde(skip_serializing_if = "std::option::Option::is_none")]
35    #[serde(borrow)]
36    pub status: std::option::Option<jacquard_common::CowStr<'a>>,
37}
38
39#[jacquard_derive::open_union]
40#[derive(
41    serde::Serialize,
42    serde::Deserialize,
43    Debug,
44    Clone,
45    PartialEq,
46    Eq,
47    thiserror::Error,
48    miette::Diagnostic,
49    jacquard_derive::IntoStatic
50)]
51#[serde(tag = "error", content = "message")]
52#[serde(bound(deserialize = "'de: 'a"))]
53pub enum RefreshSessionError<'a> {
54    #[serde(rename = "AccountTakedown")]
55    AccountTakedown(std::option::Option<String>),
56}
57
58impl std::fmt::Display for RefreshSessionError<'_> {
59    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
60        match self {
61            Self::AccountTakedown(msg) => {
62                write!(f, "AccountTakedown")?;
63                if let Some(msg) = msg {
64                    write!(f, ": {}", msg)?;
65                }
66                Ok(())
67            }
68            Self::Unknown(err) => write!(f, "Unknown error: {:?}", err),
69        }
70    }
71}
72
73/// XRPC request marker type
74#[derive(
75    Debug,
76    Clone,
77    Copy,
78    PartialEq,
79    Eq,
80    serde::Serialize,
81    serde::Deserialize,
82    jacquard_derive::IntoStatic
83)]
84pub struct RefreshSession;
85///Response type for
86///com.atproto.server.refreshSession
87pub struct RefreshSessionResponse;
88impl jacquard_common::xrpc::XrpcResp for RefreshSessionResponse {
89    const NSID: &'static str = "com.atproto.server.refreshSession";
90    const ENCODING: &'static str = "application/json";
91    type Output<'de> = RefreshSessionOutput<'de>;
92    type Err<'de> = RefreshSessionError<'de>;
93}
94
95impl<'de> jacquard_common::xrpc::XrpcRequest<'de> for RefreshSession {
96    const NSID: &'static str = "com.atproto.server.refreshSession";
97    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
98        "application/json",
99    );
100    type Response = RefreshSessionResponse;
101}
102
103///Endpoint type for
104///com.atproto.server.refreshSession
105pub struct RefreshSessionRequest;
106impl jacquard_common::xrpc::XrpcEndpoint for RefreshSessionRequest {
107    const PATH: &'static str = "/xrpc/com.atproto.server.refreshSession";
108    const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Procedure(
109        "application/json",
110    );
111    type Request<'de> = RefreshSession;
112    type Response = RefreshSessionResponse;
113}