curatorium/easy-config

CLI to generate environment-specific configuration files

Installs: 30

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:project

pkg:composer/curatorium/easy-config

dev-main 2025-09-16 21:45 UTC

This package is not auto-updated.

Last update: 2026-01-10 19:29:03 UTC


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.