configured

Utility to load configuration from well defined layers into any type which can be deserialized by Serde

8 releases (5 breaking)

0.7.1 Nov 5, 2023
0.7.0 Nov 5, 2023
0.6.2 Oct 19, 2023
0.5.0 Oct 12, 2022
0.2.0 Jun 8, 2022
Download history 153/week @ 2024-06-13 134/week @ 2024-06-20 125/week @ 2024-06-27 130/week @ 2024-07-04 154/week @ 2024-07-11 140/week @ 2024-07-18 235/week @ 2024-07-25 129/week @ 2024-08-01 177/week @ 2024-08-08 123/week @ 2024-08-15 105/week @ 2024-08-22 90/week @ 2024-08-29 125/week @ 2024-09-05 72/week @ 2024-09-12 160/week @ 2024-09-19 91/week @ 2024-09-26

458 downloads per month

Custom license

11KB
99 lines

Configured

Crates.io license build

Opinionated utility to load a configuration from well defined layers into any type which can be deserialized by Serde using kebab-case.

First, values from the mandatory default configuration file at <CONFIG_DIR>/default.yaml are loaded.

Then, if the environment variable CONFIG_OVERLAYS is defined, its comma separated overlays (e.g. "prod" or "feat, dev") at <CONFIG_DIR>/<overlay>.yaml are loaded from left to right as overlays, i.e. adding or overwriting already existing values.

Finally environment variables prefixed with <CONFIG_ENV_PREFIX>__ and segments separated by __ (double underscores are used as segment separators to allow for single underscores in segment names) are used as final overlay.

Example

#[derive(Debug, Deserialize)]
#[serde(rename_all = "kebab-case")]
struct Config {
    foo: Foo,
    qux: Qux,
}

#[derive(Debug, Deserialize)]
#[serde(rename_all = "kebab-case")]
struct Foo {
    bar: String,
    baz: String,
}

#[derive(Debug, Deserialize)]
#[serde(rename_all = "kebab-case")]
struct Qux {
    quux: String,
    corge_grault: String,
}

#[test]
fn test_load() -> Result<(), Error> {
    env::set_var(CONFIG_DIR, "test-config");
    env::set_var(CONFIG_OVERLAYS, "feat, dev");
    env::set_var("APP__QUX__CORGE_GRAULT", "corge-grault-env");

    let config = Config::load()?;

    assert_eq!(config.foo.bar.as_str(), "bar");
    assert_eq!(config.foo.baz.as_str(), "baz-dev");
    assert_eq!(config.qux.quux.as_str(), "quux-feat");
    assert_eq!(config.qux.corge_grault.as_str(), "corge-grault-env");

    Ok(())
}

Attribution

This utility is built on top of the fantastic Config library.

License

This code is open source software licensed under the Apache 2.0 License.

Dependencies

~2–3MB
~62K SLoC