2019-12-22 13:13:29 +03:00
|
|
|
|
# itconfig
|
|
|
|
|
|
2019-12-23 09:49:57 +03:00
|
|
|
|
Easy build a configs from environment variables and use it in globally.
|
2019-12-22 13:13:29 +03:00
|
|
|
|
|
|
|
|
|
We recommend you start with the [documentation].
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Example usage
|
|
|
|
|
|
|
|
|
|
```rust
|
|
|
|
|
#[macro_use] extern crate itconfig;
|
2019-12-26 08:26:27 +03:00
|
|
|
|
use std::env;
|
|
|
|
|
//use dotenv::dotenv;
|
2019-12-22 13:13:29 +03:00
|
|
|
|
|
|
|
|
|
config! {
|
2020-01-10 23:42:41 +03:00
|
|
|
|
DEBUG: bool => false,
|
|
|
|
|
|
|
|
|
|
#[env_name = "APP_HOST"]
|
2020-01-07 22:36:50 +03:00
|
|
|
|
HOST: String => "127.0.0.1",
|
2019-12-25 11:03:33 +03:00
|
|
|
|
|
2020-01-07 16:17:48 +03:00
|
|
|
|
DATABASE_URL < (
|
|
|
|
|
"postgres://",
|
|
|
|
|
POSTGRES_USERNAME => "user",
|
|
|
|
|
":",
|
|
|
|
|
POSTGRES_PASSWORD => "pass",
|
|
|
|
|
"@",
|
|
|
|
|
POSTGRES_HOST => "localhost:5432",
|
|
|
|
|
"/",
|
|
|
|
|
POSTGRES_DB => "test",
|
|
|
|
|
),
|
2020-01-10 23:42:41 +03:00
|
|
|
|
|
|
|
|
|
APP {
|
|
|
|
|
ARTICLE {
|
|
|
|
|
PER_PAGE: u32 => 15,
|
|
|
|
|
}
|
2019-12-27 23:57:13 +03:00
|
|
|
|
|
2020-01-10 23:42:41 +03:00
|
|
|
|
#[cfg(feature = "companies")]
|
|
|
|
|
COMPANY {
|
|
|
|
|
#[env_name = "INSTITUTIONS_PER_PAGE"]
|
|
|
|
|
PER_PAGE: u32 => 15,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FEATURE {
|
|
|
|
|
NEW_MENU: bool => false,
|
|
|
|
|
|
|
|
|
|
COMPANY {
|
|
|
|
|
PROFILE: bool => false,
|
|
|
|
|
}
|
2019-12-25 11:03:33 +03:00
|
|
|
|
}
|
2019-12-22 13:13:29 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn main () {
|
2019-12-24 19:37:55 +03:00
|
|
|
|
// dotenv().ok();
|
2020-01-10 23:42:41 +03:00
|
|
|
|
env::set_var("FEATURE_NEW_MENU", "t");
|
2019-12-26 08:26:27 +03:00
|
|
|
|
|
2019-12-22 13:13:29 +03:00
|
|
|
|
cfg::init();
|
2020-01-07 16:17:48 +03:00
|
|
|
|
assert_eq!(cfg::HOST(), String::from("127.0.0.1"));
|
|
|
|
|
assert_eq!(cfg::DATABASE_URL(), String::from("postgres://user:pass@localhost:5432/test"));
|
2020-01-10 23:42:41 +03:00
|
|
|
|
assert_eq!(cfg::APP:ARTICLE:PER_PAGE(), 15);
|
|
|
|
|
assert_eq!(cfg::FEATURE::NEW_MENU(), true);
|
2019-12-22 13:13:29 +03:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
2020-01-19 17:33:46 +03:00
|
|
|
|
Macro is an optional feature, enabled by default. You can install itconfig without default
|
|
|
|
|
features and use this lib as shown below
|
|
|
|
|
|
|
|
|
|
```rust
|
|
|
|
|
use itconfig::*;
|
|
|
|
|
use std::env;
|
|
|
|
|
// use dotenv::dotenv;
|
|
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
|
env::set_var("DATABASE_URL", "postgres://127.0.0.1:5432/test");
|
|
|
|
|
|
|
|
|
|
let database_url = get_env::<String>("DATABASE_URL").unwrap();
|
|
|
|
|
let new_profile: bool = get_env_or_default("FEATURE_NEW_PROFILE", false);
|
|
|
|
|
let articles_per_page: u32 = get_env_or_set_default("ARTICLES_PER_PAGE", 10);
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
2019-12-24 19:37:55 +03:00
|
|
|
|
## Roadmap
|
|
|
|
|
|
2019-12-25 11:04:13 +03:00
|
|
|
|
* [x] Add namespace for variables
|
2019-12-26 08:26:27 +03:00
|
|
|
|
* [x] Custom env name
|
2019-12-27 23:57:13 +03:00
|
|
|
|
* [x] Support feature config and other meta directives
|
2020-01-06 23:12:06 +03:00
|
|
|
|
* [x] Add default value to env if env is not found
|
2020-01-07 16:17:48 +03:00
|
|
|
|
* [x] Concat env variables to one variable
|
2020-01-10 23:42:41 +03:00
|
|
|
|
* [x] Add nested namespaces
|
|
|
|
|
* [x] Support meta for namespaces
|
2020-01-21 11:12:12 +03:00
|
|
|
|
* [x] Support array type
|
2020-01-10 08:23:06 +03:00
|
|
|
|
* [ ] Support hashmap type
|
|
|
|
|
* [ ] Support custom env type
|
2020-01-10 23:42:41 +03:00
|
|
|
|
* [ ] Common configuration for namespace variables
|
2019-12-24 19:37:55 +03:00
|
|
|
|
|
|
|
|
|
|
2020-01-21 11:12:12 +03:00
|
|
|
|
## Available features
|
|
|
|
|
|
|
|
|
|
* default = ["macro", "primitives"]
|
|
|
|
|
* macro = []
|
|
|
|
|
* array = ["serde_json"]
|
|
|
|
|
* primitives = ["numbers", "bool"]
|
|
|
|
|
* numbers = ["int", "uint", "float"]
|
|
|
|
|
* int = ["i8", "i16", "i32", "i64", "i128", "isize"]
|
|
|
|
|
* uint = ["u8", "u16", "u32", "u64", "u128", "usize"]
|
|
|
|
|
* float = ["f32", "f64"]
|
|
|
|
|
* i8 = []
|
|
|
|
|
* i16 = []
|
|
|
|
|
* i32 = []
|
|
|
|
|
* i64 = []
|
|
|
|
|
* i128 = []
|
|
|
|
|
* isize = []
|
|
|
|
|
* u8 = []
|
|
|
|
|
* u16 = []
|
|
|
|
|
* u32 = []
|
|
|
|
|
* u64 = []
|
|
|
|
|
* u128 = []
|
|
|
|
|
* usize = []
|
|
|
|
|
* f32 = []
|
|
|
|
|
* f64 = []
|
|
|
|
|
* bool = []
|
|
|
|
|
|
2020-01-19 20:42:26 +03:00
|
|
|
|
|
2019-12-24 19:37:55 +03:00
|
|
|
|
## License
|
|
|
|
|
|
|
|
|
|
[MIT] © [Ice Temple](https://github.com/icetemple)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Contributors
|
|
|
|
|
|
|
|
|
|
[pleshevskiy](https://github.com/pleshevskiy) (Dmitriy Pleshevskiy) – creator, maintainer.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-12-22 13:13:29 +03:00
|
|
|
|
[documentation]: https://docs.rs/itconfig
|