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
89
90
91
92
93
|
use serde_derive;
use std::time::SystemTime;
use crate::ip::{Endpoint, Ipv4Net, Ipv6Net};
#[serde(deny_unknown_fields)]
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct Peer {
pub public_key: String,
#[serde(default = "Vec::new")]
pub ipv4: Vec<Ipv4Net>,
#[serde(default = "Vec::new")]
pub ipv6: Vec<Ipv6Net>,
}
#[serde(deny_unknown_fields)]
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct Server {
#[serde(flatten)]
pub peer: Peer,
pub endpoint: Endpoint,
#[serde(default = "default_peer_keepalive")]
pub keepalive: u32,
}
#[serde(deny_unknown_fields)]
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct RoadWarrior {
#[serde(flatten)]
pub peer: Peer,
pub base: String,
}
fn default_peer_keepalive() -> u32 {
0
}
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct SourceConfig {
#[serde(default = "Vec::new")]
pub servers: Vec<Server>,
#[serde(default = "Vec::new")]
pub road_warriors: Vec<RoadWarrior>,
}
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct SourceNextConfig {
#[serde(with = "serde_utc")]
pub update_at: SystemTime,
#[serde(flatten)]
pub config: SourceConfig,
}
#[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, PartialEq, Eq, Debug)]
pub struct Source {
#[serde(flatten)]
pub config: SourceConfig,
pub next: Option<SourceNextConfig>,
}
mod serde_utc {
use crate::bin;
use chrono::{DateTime, SecondsFormat, TimeZone, Utc};
use serde::*;
use std::time::SystemTime;
pub fn serialize<S: Serializer>(t: &SystemTime, ser: S) -> Result<S::Ok, S::Error> {
let t = DateTime::<Utc>::from(*t);
if ser.is_human_readable() {
ser.serialize_str(&t.to_rfc3339_opts(SecondsFormat::Nanos, true))
} else {
let mut buf = [0u8; 12];
let (buf_secs, buf_nanos) = mut_array_refs![&mut buf, 8, 4];
*buf_secs = bin::i64_to_be(t.timestamp());
*buf_nanos = bin::u32_to_be(t.timestamp_subsec_nanos());
ser.serialize_bytes(&buf)
}
}
pub fn deserialize<'de, D: Deserializer<'de>>(de: D) -> Result<SystemTime, D::Error> {
if de.is_human_readable() {
let s: String = String::deserialize(de)?;
let t = DateTime::parse_from_rfc3339(&s).map_err(de::Error::custom)?;
Ok(t.into())
} else {
let mut buf = <[u8; 12]>::deserialize(de)?;
let (buf_secs, buf_nanos) = array_refs![&mut buf, 8, 4];
let secs = bin::i64_from_be(*buf_secs);
let nanos = bin::u32_from_be(*buf_nanos);
Ok(Utc.timestamp(secs, nanos).into())
}
}
}
|