jacquard_api/network_slices/slice/
get_sync_summary.rs

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}