jacquard-api 0.12.0-beta.2

Generated AT Protocol API bindings for Jacquard
Documentation
// @generated by jacquard-lexicon. DO NOT EDIT.
//
// Lexicon: network.slices.slice.startSync
//
// This file was automatically generated from Lexicon schemas.
// Any manual changes will be overwritten on the next regeneration.

#[allow(unused_imports)]
use alloc::collections::BTreeMap;

#[allow(unused_imports)]
use core::marker::PhantomData;
use jacquard_common::deps::smol_str::SmolStr;
use jacquard_common::types::string::{Did, Nsid};
use jacquard_common::types::value::Data;
use jacquard_common::{BosStr, CowStr, DefaultStr, FromStaticStr};
use jacquard_derive::IntoStatic;
use serde::{Deserialize, Serialize};

#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic, Default)]
#[serde(
    rename_all = "camelCase",
    bound(deserialize = "S: Deserialize<'de> + BosStr")
)]
pub struct StartSync<S: BosStr = DefaultStr> {
    ///List of collection NSIDs to sync (primary collections matching slice domain)
    #[serde(skip_serializing_if = "Option::is_none")]
    pub collections: Option<Vec<Nsid<S>>>,
    ///List of external collection NSIDs to sync (collections outside slice domain)
    #[serde(skip_serializing_if = "Option::is_none")]
    pub external_collections: Option<Vec<Nsid<S>>>,
    ///Maximum number of records to sync per repository
    #[serde(skip_serializing_if = "Option::is_none")]
    pub limit_per_repo: Option<i64>,
    ///List of specific repository DIDs to sync from
    #[serde(skip_serializing_if = "Option::is_none")]
    pub repos: Option<Vec<Did<S>>>,
    ///Skip lexicon validation during sync  Defaults to `false`.
    #[serde(skip_serializing_if = "Option::is_none")]
    #[serde(default = "_default_start_sync_skip_validation")]
    pub skip_validation: Option<bool>,
    ///AT-URI of the slice to sync data into
    pub slice: S,
    #[serde(flatten, default, skip_serializing_if = "Option::is_none")]
    pub extra_data: Option<BTreeMap<SmolStr, Data<S>>>,
}

#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq, IntoStatic, Default)]
#[serde(
    rename_all = "camelCase",
    bound(deserialize = "S: Deserialize<'de> + BosStr")
)]
pub struct StartSyncOutput<S: BosStr = DefaultStr> {
    ///UUID of the enqueued sync job
    pub job_id: S,
    ///Success message confirming job enqueue
    pub message: S,
    #[serde(flatten, default, skip_serializing_if = "Option::is_none")]
    pub extra_data: Option<BTreeMap<SmolStr, Data<S>>>,
}

/// Response type for network.slices.slice.startSync
pub struct StartSyncResponse;
impl jacquard_common::xrpc::XrpcResp for StartSyncResponse {
    const NSID: &'static str = "network.slices.slice.startSync";
    const ENCODING: &'static str = "application/json";
    type Output<S: BosStr> = StartSyncOutput<S>;
    type Err = jacquard_common::xrpc::GenericError;
}

impl<S: BosStr> jacquard_common::xrpc::XrpcRequest for StartSync<S> {
    const NSID: &'static str = "network.slices.slice.startSync";
    const METHOD: jacquard_common::xrpc::XrpcMethod =
        jacquard_common::xrpc::XrpcMethod::Procedure("application/json");
    type Response = StartSyncResponse;
}

/// Endpoint type for network.slices.slice.startSync
pub struct StartSyncRequest;
impl jacquard_common::xrpc::XrpcEndpoint for StartSyncRequest {
    const PATH: &'static str = "/xrpc/network.slices.slice.startSync";
    const METHOD: jacquard_common::xrpc::XrpcMethod =
        jacquard_common::xrpc::XrpcMethod::Procedure("application/json");
    type Request<S: BosStr> = StartSync<S>;
    type Response = StartSyncResponse;
}

fn _default_start_sync_skip_validation() -> Option<bool> {
    Some(false)
}