jacquard_api/network_slices/
slice.rs

1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: network.slices.slice.defs
4//
5// This file was automatically generated from Lexicon schemas.
6// Any manual changes will be overwritten on the next regeneration.
7
8pub mod clear_slice_records;
9pub mod create_o_auth_client;
10pub mod delete_o_auth_client;
11pub mod get_actors;
12pub mod get_jetstream_logs;
13pub mod get_jetstream_status;
14pub mod get_job_logs;
15pub mod get_job_status;
16pub mod get_o_auth_clients;
17pub mod get_slice_records;
18pub mod get_sparklines;
19pub mod get_sync_summary;
20pub mod start_sync;
21pub mod stats;
22pub mod sync_user_collections;
23pub mod update_o_auth_client;
24
25#[jacquard_derive::lexicon]
26#[derive(
27    serde::Serialize,
28    serde::Deserialize,
29    Debug,
30    Clone,
31    PartialEq,
32    Eq,
33    jacquard_derive::IntoStatic
34)]
35#[serde(rename_all = "camelCase")]
36pub struct Slice<'a> {
37    ///When the slice was created
38    pub created_at: jacquard_common::types::string::Datetime,
39    ///Primary domain namespace for this slice (e.g. social.grain)
40    #[serde(borrow)]
41    pub domain: jacquard_common::CowStr<'a>,
42    ///Name of the slice
43    #[serde(borrow)]
44    pub name: jacquard_common::CowStr<'a>,
45}
46
47/// Typed wrapper for GetRecord response with this collection's record type.
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 SliceGetRecordOutput<'a> {
59    #[serde(skip_serializing_if = "std::option::Option::is_none")]
60    #[serde(borrow)]
61    pub cid: std::option::Option<jacquard_common::types::string::Cid<'a>>,
62    #[serde(borrow)]
63    pub uri: jacquard_common::types::string::AtUri<'a>,
64    #[serde(borrow)]
65    pub value: Slice<'a>,
66}
67
68/// Marker type for deserializing records from this collection.
69pub struct SliceRecord;
70impl jacquard_common::xrpc::XrpcResp for SliceRecord {
71    const NSID: &'static str = "network.slices.slice";
72    const ENCODING: &'static str = "application/json";
73    type Output<'de> = SliceGetRecordOutput<'de>;
74    type Err<'de> = jacquard_common::types::collection::RecordError<'de>;
75}
76
77impl jacquard_common::types::collection::Collection for Slice<'_> {
78    const NSID: &'static str = "network.slices.slice";
79    type Record = SliceRecord;
80}
81
82impl From<SliceGetRecordOutput<'_>> for Slice<'_> {
83    fn from(output: SliceGetRecordOutput<'_>) -> Self {
84        use jacquard_common::IntoStatic;
85        output.value.into_static()
86    }
87}
88
89#[jacquard_derive::lexicon]
90#[derive(
91    serde::Serialize,
92    serde::Deserialize,
93    Debug,
94    Clone,
95    PartialEq,
96    Eq,
97    jacquard_derive::IntoStatic
98)]
99#[serde(rename_all = "camelCase")]
100pub struct SliceView<'a> {
101    #[serde(borrow)]
102    pub cid: jacquard_common::types::string::Cid<'a>,
103    pub created_at: jacquard_common::types::string::Datetime,
104    ///Profile of the slice creator
105    #[serde(borrow)]
106    pub creator: crate::network_slices::actor::ProfileViewBasic<'a>,
107    ///Primary domain namespace for this slice (e.g. social.grain)
108    #[serde(borrow)]
109    pub domain: jacquard_common::CowStr<'a>,
110    ///Total number of unique indexed actors in this slice
111    #[serde(skip_serializing_if = "std::option::Option::is_none")]
112    pub indexed_actor_count: std::option::Option<i64>,
113    ///Number of collections with indexed records
114    #[serde(skip_serializing_if = "std::option::Option::is_none")]
115    pub indexed_collection_count: std::option::Option<i64>,
116    ///Total number of indexed records in this slice
117    #[serde(skip_serializing_if = "std::option::Option::is_none")]
118    pub indexed_record_count: std::option::Option<i64>,
119    ///Display name of the slice
120    #[serde(borrow)]
121    pub name: jacquard_common::CowStr<'a>,
122    ///Recent activity sparkline data points for the last 24 hours
123    #[serde(skip_serializing_if = "std::option::Option::is_none")]
124    #[serde(borrow)]
125    pub sparkline: std::option::Option<
126        Vec<crate::network_slices::slice::SparklinePoint<'a>>,
127    >,
128    #[serde(borrow)]
129    pub uri: jacquard_common::types::string::AtUri<'a>,
130    ///Total number of waitlist invites for this slice
131    #[serde(skip_serializing_if = "std::option::Option::is_none")]
132    pub waitlist_invite_count: std::option::Option<i64>,
133    ///Total number of waitlist requests for this slice
134    #[serde(skip_serializing_if = "std::option::Option::is_none")]
135    pub waitlist_request_count: std::option::Option<i64>,
136}
137
138#[jacquard_derive::lexicon]
139#[derive(
140    serde::Serialize,
141    serde::Deserialize,
142    Debug,
143    Clone,
144    PartialEq,
145    Eq,
146    jacquard_derive::IntoStatic
147)]
148#[serde(rename_all = "camelCase")]
149pub struct SparklinePoint<'a> {
150    pub count: i64,
151    pub timestamp: jacquard_common::types::string::Datetime,
152}