scuffle-settings

Crates.ioscuffle-settings
lib.rsscuffle-settings
version0.1.4
created_at2024-11-28 16:48:27.187188+00
updated_at2025-05-17 13:36:19.740286+00
descriptionTools for managing configuration from environment variables or config files.
homepage
repositoryhttps://github.com/scufflecloud/scuffle
max_upload_size
id1464774
size66,042
Developers (github:scufflecloud:developers)

documentation

https://docs.rs/scuffle-settings

README

scuffle-settings

[!WARNING]
This crate is under active development and may not be stable.

License: MIT OR Apache-2.0 docs.rs crates.io GitHub Actions: ci Codecov


A crate designed to provide a simple interface to load and manage settings.

This crate is a wrapper around the config crate and clap crate to provide a simple interface to load and manage settings.

See the changelog for a full release history.

Feature flags

  • cli — Enables cli parsing using clap
  • ron — Enables the ron format
  • toml — Enables the toml format
  • yaml — Enables the yaml format
  • json — Enables the json format
  • json5 — Enables the json5 formast
  • ini — Enables the ini format
  • all-formats — Enables all formats
  • templates — Enables templating support via jinja
  • bootstrap — Enables scuffle-bootstrap support
  • full — Enables everything
  • docs — Enables changelog and documentation of feature flags

Examples

With scuffle_bootstrap

// Define a config struct like this
// You can use all of the serde attributes to customize the deserialization
#[derive(serde_derive::Deserialize)]
struct MyConfig {
    some_setting: String,
    #[serde(default)]
    some_other_setting: i32,
}

// Implement scuffle_boostrap::ConfigParser for the config struct like this
scuffle_settings::bootstrap!(MyConfig);

/// Our global state
struct Global;

impl scuffle_bootstrap::global::Global for Global {
    type Config = MyConfig;

    async fn init(config: MyConfig) -> anyhow::Result<Arc<Self>> {
        // Here you now have access to the config
        Ok(Arc::new(Self))
    }
}

Without scuffle_bootstrap

// Define a config struct like this
// You can use all of the serde attributes to customize the deserialization
#[derive(serde_derive::Deserialize)]
struct MyConfig {
    some_setting: String,
    #[serde(default)]
    some_other_setting: i32,
}

// Parsing options
let options = scuffle_settings::Options {
    env_prefix: Some("MY_APP"),
    ..Default::default()
};
// Parse the settings
let settings: MyConfig = scuffle_settings::parse_settings(options)?;

See Options for more information on how to customize parsing.

Templates

If the templates feature is enabled, the parser will attempt to render the configuration file as a jinja template before processing it.

All environment variables set during execution will be available under the env variable inside the file.

Example TOML file:

some_setting = "${{ env.MY_APP_SECRET }}"

Use ${{ and }} for variables, {% and %} for blocks and {# and #} for comments.

Command Line Interface

The following options are available for the CLI:

  • --config or -c

    Path to a configuration file. This option can be used multiple times to load multiple files.

  • --override or -o

    Provide an override for a configuration value, in the format KEY=VALUE.

License

This project is licensed under the MIT or Apache-2.0 license. You can choose between one of them if you use this work.

SPDX-License-Identifier: MIT OR Apache-2.0

Commit count: 1522

cargo fmt