This crate provides a method of injecting variables from multiple external sources into a
template string. Sources can be anything as long as they implement the
Loader
trait which handles the
loading of the variables in a standard way.
These are the currently implemented sources and their associated template keys
| Source | Key | Description |
|-|-|-|
| AWS EC2 Instance Tags | awsec2tag
| Load the value of AWS EC2 Instance Tags by their key |
| AWS EC2 Metadata Service | awsec2metadata
| Load a value from the AWS EC2 Metadata Service by it's path |
| Environment Variables | env
| Load the value of an environment variable |
```rust let mut seed = Seed::new("Hi %env:NAME%!"); let output = seed.germinate().await?;
assert_eq!("Hi John!", output); ```
You can also include your own sources using the
Seed::add_custom_loader
method. The only requirement is that the custom loader must implement the
Loader
trait
```rust let mut seed = Seed::new("Hi %name:name%");
// Add a custom loader for the name key. This is the loader that will be used whenever // germinate finds %name:...% in the template string seed.addcustomloader("name".to_string(), Box::new(NameLoader {}));
let output = seed.germinate().await?;
assert_eq!("Hi John", output); ```
Germinate provides a CLI for templating files, available from the Github releases. To run the CLI, cimply download the binary for your system and check the usage with germinate --help
The CLI can be used to parse an template file and output it either to stdout
or optionally, an output file
```
germinate myfile.txt.tmpl
germinate myfile.txt.tmpl -o myfile.txt ```