1// @generated by jacquard-lexicon. DO NOT EDIT.
2//
3// Lexicon: network.slices.slice.getSyncSummary
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 CollectionSummary<'a> {
20 #[serde(borrow)]
21 pub collection: jacquard_common::CowStr<'a>,
22 pub estimated_repos: i64,
23 pub is_external: bool,
24}
25
26#[derive(
27 serde::Serialize,
28 serde::Deserialize,
29 Debug,
30 Clone,
31 PartialEq,
32 Eq,
33 bon::Builder,
34 jacquard_derive::IntoStatic
35)]
36#[builder(start_fn = new)]
37#[serde(rename_all = "camelCase")]
38pub struct GetSyncSummary<'a> {
39 #[serde(skip_serializing_if = "std::option::Option::is_none")]
40 #[serde(borrow)]
41 pub collections: std::option::Option<Vec<jacquard_common::CowStr<'a>>>,
42 #[serde(skip_serializing_if = "std::option::Option::is_none")]
43 #[serde(borrow)]
44 pub external_collections: std::option::Option<Vec<jacquard_common::CowStr<'a>>>,
45 #[serde(skip_serializing_if = "std::option::Option::is_none")]
46 #[serde(borrow)]
47 pub repos: std::option::Option<Vec<jacquard_common::CowStr<'a>>>,
48 #[serde(borrow)]
49 #[builder(into)]
50 pub slice: jacquard_common::CowStr<'a>,
51}
52
53#[jacquard_derive::lexicon]
54#[derive(
55 serde::Serialize,
56 serde::Deserialize,
57 Debug,
58 Clone,
59 PartialEq,
60 Eq,
61 jacquard_derive::IntoStatic
62)]
63#[serde(rename_all = "camelCase")]
64pub struct GetSyncSummaryOutput<'a> {
65 ///The actual limit applied (user-specified or default)
66 pub applied_limit: i64,
67 ///Number of repositories after applying limit
68 pub capped_repos: i64,
69 #[serde(borrow)]
70 pub collections_summary: Vec<jacquard_common::types::value::Data<'a>>,
71 ///Total number of repositories that would be synced
72 pub total_repos: i64,
73 ///Whether the sync would be limited by maxRepos
74 pub would_be_capped: bool,
75}
76
77///Response type for
78///network.slices.slice.getSyncSummary
79pub struct GetSyncSummaryResponse;
80impl jacquard_common::xrpc::XrpcResp for GetSyncSummaryResponse {
81 const NSID: &'static str = "network.slices.slice.getSyncSummary";
82 const ENCODING: &'static str = "application/json";
83 type Output<'de> = GetSyncSummaryOutput<'de>;
84 type Err<'de> = jacquard_common::xrpc::GenericError<'de>;
85}
86
87impl<'de> jacquard_common::xrpc::XrpcRequest<'de> for GetSyncSummary<'de> {
88 const NSID: &'static str = "network.slices.slice.getSyncSummary";
89 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
90 type Response = GetSyncSummaryResponse;
91}
92
93///Endpoint type for
94///network.slices.slice.getSyncSummary
95pub struct GetSyncSummaryRequest;
96impl jacquard_common::xrpc::XrpcEndpoint for GetSyncSummaryRequest {
97 const PATH: &'static str = "/xrpc/network.slices.slice.getSyncSummary";
98 const METHOD: jacquard_common::xrpc::XrpcMethod = jacquard_common::xrpc::XrpcMethod::Query;
99 type Request<'de> = GetSyncSummary<'de>;
100 type Response = GetSyncSummaryResponse;
101}