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
use super::{Connect, ReadWrite};
use crate::error::{ClientErrorKind, Error, Result};
use std::os::unix::fs::FileTypeExt;
use std::os::unix::net::UnixStream;
use std::path::PathBuf;
use std::time::Duration;
pub const DEFAULT_SOCKET_PATH: &str = "/run/parsec/parsec.sock";
#[derive(Debug, Clone)]
pub struct Handler {
path: PathBuf,
timeout: Option<Duration>,
}
impl Connect for Handler {
fn connect(&self) -> Result<Box<dyn ReadWrite>> {
let stream = UnixStream::connect(self.path.clone()).map_err(ClientErrorKind::Ipc)?;
stream
.set_read_timeout(self.timeout)
.map_err(ClientErrorKind::Ipc)?;
stream
.set_write_timeout(self.timeout)
.map_err(ClientErrorKind::Ipc)?;
Ok(Box::from(stream))
}
fn set_timeout(&mut self, timeout: Option<Duration>) {
self.timeout = timeout;
}
}
impl Handler {
pub fn new(path: PathBuf, timeout: Option<Duration>) -> Result<Self> {
if path.exists()
&& std::fs::metadata(&path)
.map_err(|_| Error::Client(ClientErrorKind::InvalidSocketAddress))?
.file_type()
.is_socket()
{
Ok(Handler { path, timeout })
} else {
Err(Error::Client(ClientErrorKind::InvalidSocketAddress))
}
}
}
impl Default for Handler {
fn default() -> Self {
Handler {
path: DEFAULT_SOCKET_PATH.into(),
timeout: Some(super::DEFAULT_TIMEOUT),
}
}
}