
envious allows you to deserialize your serde enabled structs from
environment variables.
See it in action:
use ;
let config: Config = default.build_from_env.expect;
With the following environment variables:
it will parse it from the environment and give you a Rust struct you can use in your application.
Note: The environment variables are case sensitive by default! This can be modified using the [
Config::case_sensitive] method.
envious also supports the ability to only take in prefixed environment variables via the [Config::with_prefix] method. This will strip it before processing them further.
Getting Started
To use envious simply add it to your Cargo.toml with:
and deserialize from your environment with [Config::default] and then [Config::build_from_env]!
⚠️ Current Shortcomings
- Tuple Enum Variants can currently not be longer than one element!
- Ordering of arrays is highly sensitive to environment order
- No ordering is currently done, and the ordering depends on how the operating system propagates variables
- Deserializing where a
nullin other formats is required is currently not possible- See #12 for more details
How deserialization works
The mapping between environment variables and the serde model is as follows:
Nested fields are seperated by a provided separator.
This can be modified by using the [Config::with_separator] and defaults to __ (double underscore). For example, if you have the following struct:
use ;
You can deserialize Config with the following variables:
Arrays are serialized using nested fields with the individual keys being discarded
Arrays are represented as anonymous structs, with the 'fields' being the individual elements.
A more complex example could look like this:
use ;
Now, to deserialize a House we can set the following variables:
As you can see, the individual 'keys' of the array do not matter! The same key refers to the same object though.
Unit enums variants (without fields), are serialized from strings
As you can see in the example above, the Material enum gets simply deserialized from the name of the variant. Be careful about upper/lower case if you have enabled case sensitivity via [Config::case_sensitive]. With this enabled, Serde requires that the case is exactly the same!
Complex enum variants are serialzed just like structs
Per default serde uses external tagging for more complicated enum variants.
Tuple enums are currently only supported with a single value.
To see what this means, lets take this enum as an example:
use ;
To deserialize Config here, we can use the following variables:
Any of these sets of variables would give you the expected outcome.
Should you change the tagging of your struct, be sure to adapt the given variables.
License
envious is licensed under MIT or Apache 2.0, as you wish.
Contributing
To contribute to envious you can:
- Open up issues with ideas, remarks, bug reports, etc...
- Fork and implement new features and send them in as pull requests
- Leave it a Star and spread the word! ;)