A Rust-based CLI to merge environment-specific configurations with a base config and compare final configs across environments. Ideal for teams wanting a single source of truth for app settings, quick environment diffs, and a self-contained binary with minimal dependencies.
- Dynamic Merging: Combine base.yamlwith an environment-specific YAML (dev.yaml,staging.yaml, etc.)—no typed structs required.
- Line-by-Line Diffs: Compare two merged environments (devvsstaging, etc.) in a human-readable format.
- Flexible Config Paths: Store your YAML configs anywhere and specify the directory via --config-path.
- Environment Variables and Files: Read from environment variables using {{env:...}}or from yaml file using{{file:...}}
- Validate against schema: Validate against a predefined JSON schema using -vor--validatethat auto-converts yaml to json. The schema file is to be placed under the same config-path and namedschema.json.
- Single Binary: Compiles to a single executable (no extra runtime needed).
- Requirements
- Installation
- Configuration Structure
- Usage
- Roadmap / Future Features
- Contributing
- License
- Rust 1.60+ (if building from source)
- Cargo (if installing via cargo install)
- Linux, macOS, or Windows (64-bit recommended)
(If you distribute prebuilt binaries, end users won’t need Rust/Cargo.)
- Clone the repository:
git clone https://github.com/alighaddar10/confy.git cd confy
- Build the release binary:
cargo build --release 
- Run the tool (on Unix-like systems):
./target/release/confy --help 
If you publish this tool to crates.io:
cargo install confyThen run:
smart-config --helpBy default, the CLI looks in a directory called config/ for your YAML files:
confy/
├─ config/
│  ├─ base.yaml
│  ├─ dev.yaml
│  ├─ staging.yaml
│  └─ prod.yaml
├─ ...
- base.yaml: Common settings shared across all environments.
- .yaml: Override or extend base.yamlfor each environment (dev,staging,prod, etc.).
- You can specify a custom path using --config-path /some/other/path.
Example base.yaml:
logging:
  level: info
  format: text
service:
  port: 8080
  name: MyAppExample dev.yaml:
logging:
  level: debug
database:
  host: localhost
  user: dev_user
  password: dev_secretRun confy --help (or ./confy if you built locally) to see all commands and options:
confy 0.2.2
A CLI to manage environment configs
USAGE:
    confy <COMMAND>
COMMANDS:
    build    Merge base + environment override
    diff     Compare final config of two environments
    help     Prints this message or the help of the given subcommand(s)
- 
build - Merges base.yaml+<env>.yamlinto a single merged YAML.
- Can output to stdout or write to a file.
- Supports a custom config directory path.
 
- Merges 
- 
diff - Generates a line-by-line diff of two fully merged configs.
- Great for seeing what changed between devandstaging, etc.
 
- 
Build for devenvironment, print to stdout:confy build --env dev This will look for config/base.yaml+config/dev.yamland print the merged YAML to stdout.
- 
Build for stagingand output to file:confy build --env staging --output staging.final.yaml 
- 
Diff devvsstaging:confy diff --env1 dev --env2 staging Displays color-coded differences between the final dev and staging configs. 
- 
Specify a custom config path: confy build --env prod --config-path ./my_configs Looks for ./my_configs/base.yamland./my_configs/prod.yaml.
- Structured Diffs: Compare YAML trees to highlight changed keys/values rather than raw text lines.
- Plugin Architecture: Allow custom merge strategies or transformations.
- Fork the repo and clone your fork locally.
- Create a branch for your feature or fix: git checkout -b feature/my-improvement.
- Commit and push:
git commit -m "Add new feature" git push origin feature/my-improvement
- Open a Pull Request in the original repo, describing your changes.
Please also check out the issues for open tasks or bugs. We welcome contributions of all kinds, from code to documentation improvements!
This project is licensed under the MIT License. You’re free to use, modify, and distribute it as allowed under the license terms.
Happy Configuring!
If you have questions or suggestions, feel free to file an issue or open a PR. We’d love to hear your feedback and contributions!