use std::collections::HashMap;
use serde::{Deserialize, Serialize};
use crate::sync::shape::ShapeDefinition;
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct ShapeSubscribeMsg {
pub shape: ShapeDefinition,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct ShapeSnapshotMsg {
pub shape_id: String,
pub data: Vec<u8>,
pub snapshot_lsn: u64,
pub doc_count: usize,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct ShapeDeltaMsg {
pub shape_id: String,
pub collection: String,
pub document_id: String,
pub operation: String,
pub delta: Vec<u8>,
pub lsn: u64,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct ShapeUnsubscribeMsg {
pub shape_id: String,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct VectorClockSyncMsg {
pub clocks: HashMap<String, u64>,
pub sender_id: u64,
}