This package is abandoned as of 2020-01-14. Users are encouraged to migrate to Laminas and to use phly/phly-configfactory as a replacement for this package.
This library provides a re-usable factory for pulling configuration from nested keys.
Run the following to install this library:
$ composer require phly/phly-expressive-configfactory
Assign the factory Phly\Expressive\ConfigFactory
to services named with the
following structure:
config-<dot.separated.config.keys>
As an example, if you have the following structure:
return [
'cache' => [
'adapters' => [
'blog' => [
'connection' => 'tcp://localhost:6349',
'username' => 'www-data',
'prefix' => 'blog',
],
],
],
];
and you wanted the "blog" adapter configuration, you would assign the dependency as follows:
return [
'dependencies' => [
'factories' => [
'config-cache.adapters.blog' => \Phly\Expressive\ConfigFactory,
],
],
];
By default, if no configuration at the expected key is found, the factory returns an empty array. If you want it to instead raise an exception, you can assign the factory as follows:
return [
'dependencies' => [
'factories' => [
'config-cache.adapters.blog' => new \Phly\Expressive\ConfigFactory(false),
],
],
];
This operation is safe, as
ConfigFactory
implements__set_state()
, allowing it to be serialized safely withvar_export()
.
The exception will indicate the key hierarchy it was attempting to retrieve.
In your factories, you will refer to the metaname when retrieving the service. Following our example above:
use Psr\Container\ContainerInterface;
class BlogCacheFactory
{
public function __invoke(ContainerInterface $container)
{
return new Cache($container->get('config-cache.adapters.blog'));
}
}
Since 1.1.0
If you are using zend-servicemanager,
you can use the class Phly\Expressive\ConfigAbstractFactory
as an abstract
factory. This allows you to omit adding a factory entry for every configuration
segment you want to retrieve. Instead, you can add the following:
return [
'dependencies' => [
'abstract_factories' => [
\Phly\Expressive\ConfigAbstractFactory::class,
// OR
new \Phly\Expressive\ConfigAbstractFactory(false),
],
],
];
When present, it will handle any services with the prefix config-
, and operate
in the same way as the ConfigFactory
.
You should only specify keys that will return an array. Most containers only
allow returning an array or object from factories, and will raise an exception
otherwise. For those requiring an object, Expressive generally casts to an
ArrayObject
instance, making this safe.