use serde::{Deserialize, Serialize};
use crate::sync::compensation::CompensationHint;
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct DeltaPushMsg {
pub collection: String,
pub document_id: String,
pub delta: Vec<u8>,
pub peer_id: u64,
pub mutation_id: u64,
#[serde(default)]
pub checksum: u32,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct DeltaAckMsg {
pub mutation_id: u64,
pub lsn: u64,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct DeltaRejectMsg {
pub mutation_id: u64,
pub reason: String,
pub compensation: Option<CompensationHint>,
}
#[derive(
Debug, Clone, Serialize, Deserialize, zerompk::ToMessagePack, zerompk::FromMessagePack,
)]
pub struct CollectionPurgedMsg {
pub tenant_id: u32,
pub name: String,
pub purge_lsn: u64,
}