#configuration #configuration-management #flexible #source #loading #process #realme

macro realme_macros

A flexible and extensible configuration management library for Rust, designed to simplify the process of loading and managing configuration settings from various sources

2 unstable releases

0.2.2 Dec 25, 2024
0.1.0 Nov 11, 2024

#1834 in Procedural macros

Download history 96/week @ 2024-11-06 27/week @ 2024-11-13 6/week @ 2024-11-20 1/week @ 2024-12-04 3/week @ 2024-12-11 139/week @ 2024-12-25 18/week @ 2025-01-01 70/week @ 2025-01-08

227 downloads per month
Used in realme

MIT/Apache

11KB
144 lines

Realme Macros

Build License: GPLv3 Latest Version codecov

Macros for Realme.

Realme is a flexible and extensible configuration management library for Rust. It simplifies the process of loading and managing configuration settings from various sources. The name "Realme" is a play on "Realm" and "me," emphasizing its role in managing your application's configuration realm.

Features

  • Support for multiple configuration formats for file(etc. TOML, JSON ...) or string or env or even command line flags, and you can easily add support for more formats
  • Loosely typed — Serialization and deserialization of configuration data, configuration values may be read in any supported type, as long as there exists a reasonable conversion
  • Custom parser support and flexible adaptor system for different data sources, for example, you can check the cmd parser, which allows you to read configuration from command line flags with clap
  • Live watching and re-reading of config files

Installation

Add this to your Cargo.toml:

[dependencies]
realme = {version = "0.1.4", features = ["toml"]}

You can also enable other features, for example, to use hot reloading feature, you need to enable json andwatch feature:

realme = {version = "0.1.4", features = ["toml", "json", "watch"]}

Usage

Here's a simple example of how to use Realme:

    use realme::{Adaptor, Realme, StringSource, TomlParser};
    use serde::{Serialize, Deserialize};

    #[derive(Debug, Serialize, Deserialize)]
    struct Person {
        name: String,
        age: u32,
        birthday: chrono::DateTime<chrono::Utc>,
    }

    const CONFIGURATION1: &str = r#"
        name = "John"
        age = 30
        birthday = 1993-01-01T00:00:00Z
    "#;

fn main() {
    let realme = Realme::builder()
        .load(Adaptor::new(StringSource::<TomlParser>::new(
            CONFIGURATION1,
        )))
        .build()
        .expect("Building configuration object");

    let person: Person = realme.try_deserialize().unwrap();

    println!("{:?}", person);
    println!("{:?}", realme);
    
    assert_eq!(person.name, TryInto::<String>::try_into(realme.get("name").unwrap()).unwrap());
    assert_eq!(person.age, realme.get_as::<u32, _>("age").unwrap());
    assert_eq!(person.birthday, realme.get_as::<chrono::DateTime<chrono::Utc>, _>("birthday").unwrap());
}

For more detailed examples, check the examples directory.

For a real-world example, you can check the Rinkle project.

Compartion

I am impressed by the following libraries:

And compared to them, Realme has the following features:

  • Realme value conversion is all based on serde, so you can convert to any type that implements serde::Serialize and serde::Deserialize trait
  • Realme has a flexible adaptor system, you can easily add your own adaptor by implementing the Parser and Source trait
  • Realme supports file source hot reloading, you can reload the configuration file at runtime

But Realme has the following drawbacks:

  • Newer project, less documentations, less tests
  • It might have some breaking changes

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~220–660KB
~16K SLoC