tomkyle / configreader
Successor of germania-kg/configreader: Merge default and custom configuration files with Symfony YAML. Supports PSR-6 CacheItemPools.
Requires
- php: ^8.1
- germania-kg/cachecallable: ^2.0
- psr/cache: ^2.0|^3.0
- psr/log: ^2.0|^3.0
- symfony/yaml: ^6.1|^7.0
Requires (Dev)
- monolog/monolog: ^2.1|^3.0
- php-coveralls/php-coveralls: ^2.0
- phpspec/prophecy-phpunit: ^2.0
- phpstan/phpstan: ^1.9
- phpunit/phpunit: ^10.0
Replaces
This package is auto-updated.
Last update: 2024-10-30 02:05:32 UTC
README
PHP 8.1+ successor of GermaniaKG/ConfigReader by its original author. Reads and merges default and custom configuration files with Symfony YAML.
Installation
This package is version v3.3 and requires PHP 8.1+ For older PHP versions 7.1 to 8.0, head over to GermaniaKG/ConfigReader or germania-kg/configreader on Packagist to install package version up to version 3.2.
$ composer require tomkyle/configreader
Roadmap
- From v4 onwards, the namespace will change from
Germania\ConfigReader
totomkyle\ConfigReader
Interfaces
The ConfigReaderInterface requires an __invoke method which may be called with an arbitrary number of filename strings:
<?php namespace Germania\ConfigReader; interface ConfigReaderInterface { public function __invoke( ... $files ); }
Usage
YamlConfigReader
The YamlConfigReader implemens ConfigReaderInterface. It internally uses array_replace_recursive. If the given config files do not exist, nothing happens. The return value is an array in any case.
<?php use Germania\ConfigReader\YamlConfigReader; $reader = new YamlConfigReader( "/path/to/configs"); // Returns array $config = $reader("defaults.yaml", "optionals.yaml");
PSR-6 Cache support
The CacheConfigReader also implements ConfigReaderInterface and combines a ConfigReaderInterface instance with PSR-6 Cache functionality.
<?php use Germania\ConfigReader\YamlConfigReader; use Germania\ConfigReader\CacheConfigReader; $reader = new YamlConfigReader( "/path/to/configs"); $cache_item_pool = ... // PSR-6 CacheItemPool $cache_lifetime = 3600; $logger = ... $cache_reader = new CacheConfigReader($reader, $cache_item_pool, $cache_lifetime); $cache_reader = new CacheConfigReader($reader, $cache_item_pool, $cache_lifetime, $logger); $config = $cache_reader("defaults.yaml", "optionals.yaml");
YAML parsing options
The setYamlFlags method allows to set integer flags to be used by Symfony's YAML component. See official docs for a list of possible values: Symfony YAML component docs.
Ideas for using in config files:
- Yaml::PARSE_CONSTANT for evaluating constants created with
.env
configuration - Yaml::PARSE_DATETIME to save work with string-to-DateTime conversion
Do not use Yaml::PARSE_OBJECT_FOR_MAP as it will break the internal array_replace_recursive call. This is a good topic for future releases.
<?php use use Symfony\Component\Yaml\Yaml; $reader = new YamlConfigReader( "/path/to/configs"); $reader->setYamlFlags( Yaml::PARSE_DATETIME | Yaml::PARSE_CONSTANT );
Excluding results
Given a YAML map like this:
# ignoring.yaml # Exclude a single item: _ignore: foo # ... or even multiple items: _ignore: - foo - qux foo: bar qux: baz name: john
To exclude a certain elements, use setIgnoreKey to set the name of a YAML map item that contains the keys to exclude. The result in our example will not contain neither foo
nor _ignore
. Be careful to not overuse this feature!
$reader = new YamlConfigReader( "/path/to/configs"); $reader->setIgnoreKey( "_ignore" ); $config = $reader("ignoring.yaml"); # Will both be FALSE: isset( $config["_ignore"]) isset( $config["foo"]) # Reset again $reader->setIgnoreKey( null );
Exceptions
When YamlConfigReader stumbles upon a Symfony\Component\Yaml\Exception\ParseException, it will catch it and wrap it in a Germania\ConfigReader\ParseException. This class implements ConfigReaderExceptionInterface you can watch out for:
use Germania\ConfigReader\ConfigReaderExceptionInterface; try { $config = $reader("defaults.yaml", "optionals.yaml"); } catch (ConfigReaderExceptionInterface $e) { echo $e->getMessage(); }
Development
$ git clone https://github.com/tomkyle/ConfigReader.git
$ cd ConfigReader
$ composer install
Unit tests
Either copy phpunit.xml.dist
to phpunit.xml
and adapt to your needs, or leave as is. Run PhpUnit test or composer scripts like this:
$ composer test # or $ vendor/bin/phpunit
The test results logs are in the tests/log
directory.