curatorium/easy-config
Composer 安装命令:
composer create-project curatorium/easy-config
包简介
CLI to generate environment-specific configuration files
README 文档
README
A command to generate environment-specific configuration files
Takes YAML files as input, resolves config values for the requested environment, and applies those values to a template. It allows you to inherit common settings and selectively override only what’s necessary. It reduces the need to maintain duplicate settings files for different environments.
A configuration entry with params:
acme:Website: # <entry-name>:<type>: host: acme.devel # <param-name>: <value> host@prod: acme.com # <param-name>@<env-base>: <value> host@prod-1: acme.com # <param-name>@<env>: <value> host@prod-2: acme.net # <param-name>@<env>: <value>
Will be resolved for the prod-2 environment as (cat acme.yml | ez-cfg prod-2 --resolve):
acme:Website: host: acme.net
Step-by-step here's what it does:
- Ingests YAML/eYAML or JSON/eJSON configuration files
- Resolves the configuration entries for your specific environment, merging them with the base-environment defaults, and environment-unspecific defaults
- Resolves defaults for your configuration entry, merging them with the entry's type defaults, and global defaults
- Applies each configuration entry to a template engine to generate the final configuration files
Installation
composer global require curatorium/easy-config
Requirements
- PHP >= 8.2
- PHP extension for YAML
- for eJSON you need to install ejson globally
- for eYAML you need to install yq and the
eyamlcommand (provided by this package) globally
Usage
Pure command line:
easy-config --template=templates/ --extension=tpl prod-2 -- *.json *.ejson *.yaml *.eyaml
...or via configuration file .easy-config:
in-files: ['*.json', '*.ejson', '*.yaml', '*.eyaml'] out-files: '${env}/${tags.type}/${tags.name}.conf' templates: templates/
Syntax
# Configuration entry: a named map containing several parameters. # # the name of the config entry (**required**) # | # | type specifier (**required**) # ▼ ▼ <name>:<type>@<env>: # ▲ # environment specifier (**optional**); when omitted, the entry/param, will apply to all environments; # ▼ <param>@<env>: <value> # ▲ # parameter name (**required**) # Entry tags (key/value, implicitly includes: type, module, feature, name, fullname, ext) # ▼ :<tag>: <value> # Type defaults: a named map containing default parameters shared by all entries of that type. # # type specifier (**required**) # ▼ :<type>@<env>: <param>@<env>: <value> # Global defaults: a named map containing default parameters shared by all entries. # # type name Default is reserved for global defaults # ▼ :Default@<env>: <param>@<env>: <value>
Note:
<env> can be composed of a prefix (called base environment, ex.: 'test', 'prod') followed by a - and a suffix.
Base environments can add another layer of defaults that the full environment can inherit.
统计信息
- 总下载量: 26
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-01-09