1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
use std::{
fmt::Display,
net::{Ipv4Addr, SocketAddr},
path::PathBuf,
};
use uuid::Uuid;
use crate::config::{NodeId, OperatorId};
pub const DORA_COORDINATOR_PORT_DEFAULT: u16 = 0xD02A;
pub const MANUAL_STOP: &str = "dora/stop";
pub fn control_socket_addr() -> SocketAddr {
SocketAddr::new(Ipv4Addr::new(127, 0, 0, 1).into(), 6012)
}
#[derive(Debug, serde::Deserialize, serde::Serialize)]
pub enum ControlRequest {
Start {
dataflow_path: PathBuf,
name: Option<String>,
},
Reload {
dataflow_id: Uuid,
node_id: NodeId,
operator_id: Option<OperatorId>,
},
Check {
dataflow_uuid: Uuid,
},
Stop {
dataflow_uuid: Uuid,
},
StopByName {
name: String,
},
Destroy,
List,
DaemonConnected,
}
#[derive(Debug, serde::Deserialize, serde::Serialize)]
pub enum ControlRequestReply {
Error(String),
CoordinatorStopped,
DataflowStarted { uuid: Uuid },
DataflowReloaded { uuid: Uuid },
DataflowStopped { uuid: Uuid },
DataflowList { dataflows: Vec<DataflowId> },
DestroyOk,
DaemonConnected(bool),
}
#[derive(Debug, Clone, serde::Serialize, serde::Deserialize)]
pub struct DataflowId {
pub uuid: Uuid,
pub name: Option<String>,
}
impl Display for DataflowId {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
if let Some(name) = &self.name {
write!(f, "[{name}] {}", self.uuid)
} else {
write!(f, "[<unnamed>] {}", self.uuid)
}
}
}