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
|
// Copyleft (ɔ) 2021-2021 The Whirlsplash Collective
// SPDX-License-Identifier: GPL-3.0-only
#![feature(
type_ascription,
hash_set_entry,
type_name_of_val,
decl_macro,
proc_macro_hygiene
)]
#![warn(rust_2018_idioms)]
#![recursion_limit = "128"]
#[macro_use]
extern crate serde_derive;
#[macro_use]
extern crate log;
mod structures;
use config::{ConfigError, File};
use crate::structures::{
DistributorConfig,
HubConfig,
WhirlsplashApiConfig,
WhirlsplashConfig,
WhirlsplashLogConfig,
WhirlsplashPromptConfig,
};
#[derive(Serialize, Deserialize, Debug)]
pub struct Config {
pub whirlsplash: WhirlsplashConfig,
pub distributor: DistributorConfig,
pub hub: HubConfig,
}
impl Config {
pub fn refresh() { let _ = config::Config::new().refresh(); }
fn load() -> Result<Self, ConfigError> {
let mut s = config::Config::new();
s.merge(File::with_name("./Whirl.toml").required(false))?;
s.try_into()
}
pub fn get() -> Config {
return if let Err(why) = Self::load() {
error!(
"unable to load configuration file, reverting to default value: {}",
why
);
Self::default()
} else {
Self::load().unwrap()
};
}
}
impl Default for Config {
fn default() -> Self {
Config {
whirlsplash: WhirlsplashConfig {
worldsmaster_username: "WORLDSMASTER".to_string(),
ip: "0.0.0.0".to_string(),
api: WhirlsplashApiConfig {
port: 80
},
prompt: WhirlsplashPromptConfig {
enable: false,
ps1: "[WORLDSMASTER@Whirlsplash ~]$".to_string(),
},
log: WhirlsplashLogConfig {
enable: true,
level: 1,
everything: false,
test: false,
file: true,
},
},
distributor: DistributorConfig {
worldsmaster_greeting: "Welcome to Whirlsplash!".to_string(),
port: 6650,
},
hub: HubConfig {
port: 5673
},
}
}
}
|