#layered #serde #layer #load #string #source

layeredconf

Layered configeration files, deserialized with serde

9 releases

0.2.3 Jan 22, 2022
0.2.2 Jan 22, 2022
0.2.1 Dec 8, 2021
0.1.4 Dec 7, 2021

#1565 in Encoding

22 downloads per month

MIT license

23KB
436 lines

Rust Crates.io Crates.io docs.rs

LayeredConf

Yet Another Config Package

Future

Hopefully this one will be useful to someone. Incoming features:

  • More Documentation
  • Features

Features

  • Generate config Layers loaded from multiple sources: files, strings, command line arguments...
  • Uses Clap to auto-generate command line help + usage info
  • Most of Clap's derive features are usable
  • Can define futher config files to load within config files, or command line options

Quick Example

Add layeredconf, clap, and serde to your Cargo.toml

[dependencies]
layeredconf = "0.2.0"
clap = "3.0.0-beta.5"
serde = { version = "1.0", features = ["derive"] }

Define your config

use layeredconf::{Builder, Format, LayeredConf, Source};
use serde::Deserialize;

#[derive(LayeredConf, Deserialize)]
struct Config {
    /// Will also load this config file
    #[layered(load_config)]
    #[clap(long)]
    config: Option<std::path::PathBuf>,

    /// Required to be set in at least one Layer (config file, command line, etc.)
    #[clap(long)]
    name: String,

    /// Optional field
    #[clap(long)]
    input: Option<String>,

    /// Defaulted field
    #[layered(default)]
    #[clap(long)]
    number: u32,
}

fn main() -> anyhow::Result<()> {
    let config: Config = Builder)::new()
        .new_layer(Source::OptionalFile {
            path: "/etc/my_app/config.yaml",
            format: Format::Auto,
        })
        .new_layer(Source::File {
            path: "relative/config.yaml",
            format: Format::Auto,
        })
        .new_layer(Source::Arguments)
        .solidify()?;

    // Use config in your application
}

Dependencies

~3–4.5MB
~84K SLoC