1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: com.atproto.server.describeServer
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 Default
18)]
19#[serde(rename_all = "camelCase")]
20pub struct Contact<'a> {
21 #[serde(skip_serializing_if = "std::option::Option::is_none")]
22 #[serde(borrow)]
23 pub email: std::option::Option<jacquard_common::CowStr<'a>>,
24}
25
26#[jacquard_derive::lexicon]
27#[derive(
28 serde::Serialize,
29 serde::Deserialize,
30 Debug,
31 Clone,
32 PartialEq,
33 Eq,
34 jacquard_derive::IntoStatic,
35 Default
36)]
37#[serde(rename_all = "camelCase")]
38pub struct Links<'a> {
39 #[serde(skip_serializing_if = "std::option::Option::is_none")]
40 #[serde(borrow)]
41 pub privacy_policy: std::option::Option<jacquard_common::types::string::Uri<'a>>,
42 #[serde(skip_serializing_if = "std::option::Option::is_none")]
43 #[serde(borrow)]
44 pub terms_of_service: std::option::Option<jacquard_common::types::string::Uri<'a>>,
45}
46
47#[jacquard_derive::lexicon]
48#[derive(
49 serde::Serialize,
50 serde::Deserialize,
51 Debug,
52 Clone,
53 PartialEq,
54 Eq,
55 jacquard_derive::IntoStatic
56)]
57#[serde(rename_all = "camelCase")]
58pub struct DescribeServerOutput<'a> {
59 /// List of domain suffixes that can be used in account handles.
60 #[serde(borrow)]
61 pub available_user_domains: Vec<jacquard_common::CowStr<'a>>,
62 /// Contact information
63 #[serde(skip_serializing_if = "std::option::Option::is_none")]
64 #[serde(borrow)]
65 pub contact: std::option::Option<jacquard_common::types::value::Data<'a>>,
66 #[serde(borrow)]
67 pub did: jacquard_common::types::string::Did<'a>,
68 /// If true, an invite code must be supplied to create an account on this instance.
69 #[serde(skip_serializing_if = "std::option::Option::is_none")]
70 pub invite_code_required: std::option::Option<bool>,
71 /// URLs of service policy documents.
72 #[serde(skip_serializing_if = "std::option::Option::is_none")]
73 #[serde(borrow)]
74 pub links: std::option::Option<jacquard_common::types::value::Data<'a>>,
75 /// If true, a phone verification token must be supplied to create an account on this instance.
76 #[serde(skip_serializing_if = "std::option::Option::is_none")]
77 pub phone_verification_required: std::option::Option<bool>,
78}
79
80/// XRPC request marker type
81#[derive(
82 Debug,
83 Clone,
84 Copy,
85 PartialEq,
86 Eq,
87 serde::Serialize,
88 serde::Deserialize,
89 jacquard_derive::IntoStatic
90)]
91pub struct DescribeServer;
92///Response type for
93///com.atproto.server.describeServer
94pub struct DescribeServerResponse;
95impl jacquard_common::xrpc::XrpcResp for DescribeServerResponse {
96 const NSID: &'static str = "com.atproto.server.describeServer";
97 const ENCODING: &'static str = "application/json";
98 type Output<'de> = DescribeServerOutput<'de>;
99 type Err<'de> = jacquard_common::xrpc::GenericError<'de>;
100}
101
102impl jacquard_common::xrpc::XrpcRequest for DescribeServer {
103 const NSID: &'static str = "com.atproto.server.describeServer";
104 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
105 type Response = DescribeServerResponse;
106}
107
108///Endpoint type for
109///com.atproto.server.describeServer
110pub struct DescribeServerRequest;
111impl jacquard_common::xrpc::XrpcEndpoint for DescribeServerRequest {
112 const PATH: &'static str = "/xrpc/com.atproto.server.describeServer";
113 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
114 type Request<'de> = DescribeServer;
115 type Response = DescribeServerResponse;
116}