Milim commited on
Commit
e2907ed
·
1 Parent(s): 1f90b4e

refactor config helper function

Browse files
src/config_parser/parser.rs CHANGED
@@ -24,46 +24,35 @@ pub struct Config {
24
  pub binding_ip_addr: String,
25
  pub style: Style,
26
  pub redis_connection_url: String,
27
- pub aggregator: AggreatorConfig,
28
  pub logging: bool,
29
  pub debug: bool,
30
  }
31
 
32
  /// Configuration options for the aggregator.
33
  #[derive(Clone)]
34
- pub struct AggreatorConfig {
35
  /// Whether to introduce a random delay before sending the request to the search engine.
36
  pub random_delay: bool,
37
  }
38
 
39
  impl Config {
40
  /// A function which parses the config.lua file and puts all the parsed options in the newly
41
- /// contructed Config struct and returns it.
42
  ///
43
  /// # Error
44
  ///
45
  /// Returns a lua parse error if parsing of the config.lua file fails or has a syntax error
46
- /// or io error if the config.lua file doesn't exists otherwise it returns a newly contructed
47
  /// Config struct with all the parsed config options from the parsed config file.
48
  pub fn parse() -> Result<Self, Box<dyn std::error::Error>> {
49
  Lua::new().context(|context| -> Result<Self, Box<dyn std::error::Error>> {
50
  let globals = context.globals();
51
 
52
  context
53
- .load(&fs::read_to_string(
54
- Config::handle_different_config_file_path()?,
55
- )?)
56
  .exec()?;
57
 
58
- let production_use = globals.get::<_, bool>("production_use")?;
59
- let aggregator_config = if production_use {
60
- AggreatorConfig { random_delay: true }
61
- } else {
62
- AggreatorConfig {
63
- random_delay: false,
64
- }
65
- };
66
-
67
  Ok(Config {
68
  port: globals.get::<_, u16>("port")?,
69
  binding_ip_addr: globals.get::<_, String>("binding_ip_addr")?,
@@ -72,7 +61,9 @@ impl Config {
72
  globals.get::<_, String>("colorscheme")?,
73
  ),
74
  redis_connection_url: globals.get::<_, String>("redis_connection_url")?,
75
- aggregator: aggregator_config,
 
 
76
  logging: globals.get::<_, bool>("logging")?,
77
  debug: globals.get::<_, bool>("debug")?,
78
  })
@@ -90,35 +81,37 @@ impl Config {
90
  /// one (3).
91
  /// 3. `websurfx/` (under project folder ( or codebase in other words)) if it is not present
92
  /// here then it returns an error as mentioned above.
93
- fn handle_different_config_file_path() -> Result<String, Box<dyn std::error::Error>> {
94
- if Path::new(
95
- format!(
96
- "{}/.config/{}/config.lua",
97
- std::env::var("HOME").unwrap(),
98
- COMMON_DIRECTORY_NAME
99
- )
100
- .as_str(),
101
- )
102
- .exists()
103
- {
104
- Ok(format!(
105
  "{}/.config/{}/{}",
106
  std::env::var("HOME").unwrap(),
107
  COMMON_DIRECTORY_NAME,
108
  CONFIG_FILE_NAME
109
- ))
110
- } else if Path::new(
111
- format!("/etc/xdg/{}/{}", COMMON_DIRECTORY_NAME, CONFIG_FILE_NAME).as_str(),
112
- )
113
- .exists()
114
- {
115
- Ok("/etc/xdg/websurfx/config.lua".to_string())
116
- } else if Path::new(format!("./{}/{}", COMMON_DIRECTORY_NAME, CONFIG_FILE_NAME).as_str())
117
  .exists()
118
  {
119
- Ok("./websurfx/config.lua".to_string())
120
- } else {
121
- Err("Config file not found!!".to_string().into())
122
  }
 
 
 
 
 
 
 
 
 
123
  }
124
  }
 
24
  pub binding_ip_addr: String,
25
  pub style: Style,
26
  pub redis_connection_url: String,
27
+ pub aggregator: AggregatorConfig,
28
  pub logging: bool,
29
  pub debug: bool,
30
  }
31
 
32
  /// Configuration options for the aggregator.
33
  #[derive(Clone)]
34
+ pub struct AggregatorConfig {
35
  /// Whether to introduce a random delay before sending the request to the search engine.
36
  pub random_delay: bool,
37
  }
38
 
39
  impl Config {
40
  /// A function which parses the config.lua file and puts all the parsed options in the newly
41
+ /// constructed Config struct and returns it.
42
  ///
43
  /// # Error
44
  ///
45
  /// Returns a lua parse error if parsing of the config.lua file fails or has a syntax error
46
+ /// or io error if the config.lua file doesn't exists otherwise it returns a newly constructed
47
  /// Config struct with all the parsed config options from the parsed config file.
48
  pub fn parse() -> Result<Self, Box<dyn std::error::Error>> {
49
  Lua::new().context(|context| -> Result<Self, Box<dyn std::error::Error>> {
50
  let globals = context.globals();
51
 
52
  context
53
+ .load(&fs::read_to_string(Config::get_config_path()?)?)
 
 
54
  .exec()?;
55
 
 
 
 
 
 
 
 
 
 
56
  Ok(Config {
57
  port: globals.get::<_, u16>("port")?,
58
  binding_ip_addr: globals.get::<_, String>("binding_ip_addr")?,
 
61
  globals.get::<_, String>("colorscheme")?,
62
  ),
63
  redis_connection_url: globals.get::<_, String>("redis_connection_url")?,
64
+ aggregator: AggregatorConfig {
65
+ random_delay: globals.get::<_, bool>("production_use")?,
66
+ },
67
  logging: globals.get::<_, bool>("logging")?,
68
  debug: globals.get::<_, bool>("debug")?,
69
  })
 
81
  /// one (3).
82
  /// 3. `websurfx/` (under project folder ( or codebase in other words)) if it is not present
83
  /// here then it returns an error as mentioned above.
84
+ fn get_config_path() -> Result<String, Box<dyn std::error::Error>> {
85
+ // check user config
86
+
87
+ let path = format!(
88
+ "{}/.config/{}/config.lua",
89
+ std::env::var("HOME").unwrap(),
90
+ COMMON_DIRECTORY_NAME
91
+ );
92
+ if Path::new(path.as_str()).exists() {
93
+ return Ok(format!(
 
 
94
  "{}/.config/{}/{}",
95
  std::env::var("HOME").unwrap(),
96
  COMMON_DIRECTORY_NAME,
97
  CONFIG_FILE_NAME
98
+ ));
99
+ }
100
+
101
+ // look for config in /etc/xdg
102
+ if Path::new(format!("/etc/xdg/{}/{}", COMMON_DIRECTORY_NAME, CONFIG_FILE_NAME).as_str())
 
 
 
103
  .exists()
104
  {
105
+ return Ok("/etc/xdg/websurfx/config.lua".to_string());
 
 
106
  }
107
+
108
+ // use dev config
109
+ if Path::new(format!("./{}/{}", COMMON_DIRECTORY_NAME, CONFIG_FILE_NAME).as_str()).exists()
110
+ {
111
+ return Ok("./websurfx/config.lua".to_string());
112
+ }
113
+
114
+ // if no of the configs above exist, return error
115
+ Err("Config file not found!!".to_string().into())
116
  }
117
  }
src/config_parser/parser_models.rs CHANGED
@@ -1,5 +1,5 @@
1
  //! This module provides public models for handling, storing and serializing parsed config file
2
- //! options from config.lua by grouping them togather.
3
 
4
  use serde::{Deserialize, Serialize};
5
 
 
1
  //! This module provides public models for handling, storing and serializing parsed config file
2
+ //! options from config.lua by grouping them together.
3
 
4
  use serde::{Deserialize, Serialize};
5