承接 curatorium/easy-config 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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 eyaml command (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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-09