derive_environment

Crates.ioderive_environment
lib.rsderive_environment
version1.1.0
sourcesrc
created_at2023-09-19 20:47:09.576026
updated_at2023-10-05 22:33:54.693487
descriptionA Rust library for modifying structs via environment variables
homepage
repositoryhttps://github.com/eievui5/derive-environment
max_upload_size
id977216
size48,470
Evie (evie-calico)

documentation

README

A Rust library for modifying structs via environment variables.

Unlike envy, this does not create a new object. It is used to reconfigure an existing structure (after having parsed it from a config file, for example).

Ignored fields

If a certain field should not be configurable via environment variables, mark it with #[env(ignore)].

Examples

Creating a config structure:

use derive_environment::FromEnv;

#[derive(Default, FromEnv)]
pub struct Config {
    // ...
}

// Creates a base configuration struct to add on to.
// Normally this would be created using `serde` from a config file.
let mut config = Config::default();
// Names the struct "MY_CONFIG", which acts as a prefix.
config.with_env("MY_CONFIG").unwrap();

Nesting fields:

use derive_environment::FromEnv;

#[derive(FromEnv)]
struct ServerConfig {
    port: u16,
}

#[derive(FromEnv)]
pub struct Config {
    server: ServerConfig,
}

Generates:

  • MY_CONFIG_SERVER_PORT

Vector of Nested fields:

use derive_environment::FromEnv;

// `Vec`'s `FromEnv` implementation requires `Default`.
#[derive(Default, FromEnv)]
struct ServerConfig {
    port: u16,
}

#[derive(FromEnv)]
pub struct Config {
    servers: Vec<ServerConfig>,
}

Generates:

  • MY_CONFIG_SERVER_0_PORT
Commit count: 22

cargo fmt