diff options
author | Hristo Venev <hristo@venev.name> | 2019-04-02 15:56:06 +0300 |
---|---|---|
committer | Hristo Venev <hristo@venev.name> | 2019-04-02 15:57:45 +0300 |
commit | b06338ec1d282a762440ad72c935717e404badca (patch) | |
tree | f6e441e97f7676e1acab6fc4ba72c3b875e97d9b /src/config.rs | |
parent | c3269142f8d6c016ce8100b86fcae2031b145a9a (diff) |
Reorg, sources have names.
Diffstat (limited to 'src/config.rs')
-rw-r--r-- | src/config.rs | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/src/config.rs b/src/config.rs index e8dcb05..6eb3761 100644 --- a/src/config.rs +++ b/src/config.rs @@ -2,8 +2,9 @@ // // See COPYING. -use crate::ip::{Ipv4Set, Ipv6Set}; -use crate::model::Key; +use crate::model::{Ipv4Set, Ipv6Set, Key}; +use std::path::PathBuf; +use std::collections::HashMap; use serde_derive; #[serde(deny_unknown_fields)] @@ -13,6 +14,8 @@ pub struct Source { pub psk: Option<Key>, pub ipv4: Ipv4Set, pub ipv6: Ipv6Set, + #[serde(default)] + pub required: bool, } #[serde(deny_unknown_fields)] @@ -20,7 +23,7 @@ pub struct Source { pub struct PeerConfig { #[serde(default = "default_min_keepalive")] pub min_keepalive: u32, - #[serde(default = "default_max_keepalive")] + #[serde(default)] pub max_keepalive: u32, } @@ -35,6 +38,9 @@ pub struct UpdateConfig { #[serde(deny_unknown_fields)] #[derive(serde_derive::Serialize, serde_derive::Deserialize, Clone, Debug)] pub struct Config { + pub cache_directory: Option<PathBuf>, + pub runtime_directory: Option<PathBuf>, + #[serde(flatten)] pub peer_config: PeerConfig, @@ -42,7 +48,7 @@ pub struct Config { pub update_config: UpdateConfig, #[serde(rename = "source")] - pub sources: Vec<Source>, + pub sources: HashMap<String, Source>, } impl PeerConfig { @@ -63,11 +69,6 @@ fn default_min_keepalive() -> u32 { } #[inline] -fn default_max_keepalive() -> u32 { - 0 -} - -#[inline] fn default_refresh_sec() -> u32 { 1200 } |