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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
use crate::config::*;
use crate::core::Ops;
use crate::errors::NetworkError;
use crate::prochandler::HandleOps;
use crate::runner::Regress;
use log::debug;
use serde::{Deserialize, Serialize};
use std::default::Default;
use zmq::{self, Context, Message};

#[derive(Serialize, Deserialize, Default)]
pub struct DispatchMsg {
	pub proctype: HandleOps,
	pub func: Option<Ops>,
	pub application: Option<String>,
	pub refresh: bool,
	pub regress_counter: Option<Regress>,
}

#[derive(Debug, Serialize, Deserialize)]
pub struct ResponseMsg {
	pub code: String,
	pub message: String,
}

impl Default for ResponseMsg {
	fn default() -> ResponseMsg {
		ResponseMsg {
			code: String::from("E000"),
			message: String::from(
				"A generic, unspecified error occured. See backtrace for more details.",
			),
		}
	}
}

pub fn send(d_msg: DispatchMsg) -> Result<ResponseMsg, NetworkError> {
	let context = Context::new();
	let requester = context.socket(zmq::REQ)?;

	requester.connect(get_config()?.client_url.as_str())?;

	let mut msg = Message::new();

	debug!("Sending Request...");
	requester.send(&serde_json::to_string(&d_msg)?, 0)?;

	requester.recv(&mut msg, 0)?;

	let retmsg: ResponseMsg = serde_json::from_str(msg.as_str().unwrap_or_default())?;

	debug!("Received response: {:?}", retmsg);

	Ok(retmsg)
}

pub fn heartbeat() -> Result<ResponseMsg, NetworkError> {
	// TODO: Define an early exit if daemon isn't running yet.
	let context = Context::new();
	let requester = context.socket(zmq::REQ)?;

	requester.connect(get_config()?.client_url.as_str())?;

	// QUESTION: These params are a hack. Is there a better way to detect this?
	requester.set_linger(1)?;
	requester.set_rcvtimeo(2000)?;

	let mut msg = Message::new();

	debug!("Sending Heartbeat...");

	let snd_msg = DispatchMsg {
		proctype: HandleOps::Heartbeat,
		..Default::default()
	};

	requester.send(&serde_json::to_string(&snd_msg)?, 0)?;

	requester.recv(&mut msg, 0)?;

	let retmsg: ResponseMsg = serde_json::from_str(msg.as_str().unwrap_or_default())?;

	// TODO: Check against expected heartbeat output.

	debug!("Received response: {:?}", retmsg);

	Ok(retmsg)
}