forked from Deuxfleurs/garage
46 lines
885 B
Rust
46 lines
885 B
Rust
use std::time::Duration;
|
|
use std::net::SocketAddr;
|
|
use serde::{Serialize, Deserialize};
|
|
|
|
use crate::data::*;
|
|
|
|
pub const DEFAULT_TIMEOUT: Duration = Duration::from_secs(30);
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
pub enum Message {
|
|
Ok,
|
|
Error(String),
|
|
|
|
Ping(PingMessage),
|
|
PullStatus,
|
|
PullConfig,
|
|
AdvertiseNodesUp(Vec<AdvertisedNode>),
|
|
AdvertiseConfig(NetworkConfig),
|
|
|
|
PutBlock(PutBlockMessage),
|
|
|
|
TableRPC(String, #[serde(with = "serde_bytes")] Vec<u8>),
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
pub struct PingMessage {
|
|
pub id: UUID,
|
|
pub rpc_port: u16,
|
|
|
|
pub status_hash: Hash,
|
|
pub config_version: u64,
|
|
}
|
|
|
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
pub struct AdvertisedNode {
|
|
pub id: UUID,
|
|
pub addr: SocketAddr,
|
|
}
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
pub struct PutBlockMessage {
|
|
pub meta: BlockMeta,
|
|
|
|
#[serde(with="serde_bytes")]
|
|
pub data: Vec<u8>,
|
|
}
|