Crates.io | salak |
lib.rs | salak |
version | 0.14.1 |
source | src |
created_at | 2021-02-15 07:19:42.381087 |
updated_at | 2021-08-21 09:15:40.378251 |
description | A rust configuration loader |
homepage | https://github.com/leptonyu/salak.rs |
repository | https://github.com/leptonyu/salak.rs |
max_upload_size | |
id | 355361 |
size | 159,594 |
Salak is a multi layered configuration loader and zero-boilerplate configuration parser, with many predefined sources.
Please refer to salak doc.
Please notice that salak-0.9.*
is totally rewrited, so the APIs may changes much, and some functions may be removed. They will be added in later version.
use salak::*;
#[derive(Debug, FromEnvironment)]
#[salak(prefix = "config")]
struct Config {
#[salak(default = false)]
verbose: bool,
optional: Option<String>,
#[salak(name = "val")]
value: i64,
}
let env = Salak::builder()
.set("config.val", "2021")
.build()
.unwrap();
let config = env.get::<Config>().unwrap();
assert_eq!(2021, config.value);
assert_eq!(None, config.optional);
assert_eq!(false, config.verbose);
salak_factory can initialize resource based on salak
, such as redis, postgresql, etc.
use std::sync::Arc;
use salak::*;
use salak_factory::redis_default::RedisPool;
generate_service!(RedisService {
redis: RedisPool,
#[salak(namespace = "hello", access = "pub")]
back: Option<RedisPool>
});
fn main() -> Result<(), PropertyError> {
env_logger::builder()
.filter_level(log::LevelFilter::Info)
.try_init()?;
let env = Salak::builder()
.register_default_resource::<RedisPool>()?
.configure_args(app_info!())
.build()?;
let _service = env.get_service::<RedisService>()?;
let _conn = _service.as_redis().get()?;
Ok(())
}