Download the PHP package webimpress/zend-pimple-config without Composer
On this page you can find all versions of the php package webimpress/zend-pimple-config. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download webimpress/zend-pimple-config
More information about webimpress/zend-pimple-config
Files in webimpress/zend-pimple-config
Package zend-pimple-config
Short Description PSR-11 Pimple container configurator for ZF and Expressive applications
License BSD-3-Clause
Informations about the package zend-pimple-config
zend-pimple-config
Repository abandoned 2019-12-31
This repository has moved to laminas/laminas-pimple-config.
This library provides utilities to configure a PSR-11 compatible Pimple container using zend-servicemanager configuration, for purposes of usage within Expressive.
Installation
Run the following to install this library:
Configuration
To get a configured PSR-11 Pimple container, do the following:
The dependencies
sub associative array can contain the following keys:
services
: an associative array that maps a key to a specific service instance.invokables
: an associative array that map a key to a constructor-less service; i.e., for services that do not require arguments to the constructor. The key and service name usually are the same; if they are not, the key is treated as an alias.factories
: an associative array that maps a service name to a factory class name, or any callable. Factory classes must be instantiable without arguments, and callable once instantiated (i.e., implement the__invoke()
method).aliases
: an associative array that maps an alias to a service name (or another alias).delegators
: an associative array that maps service names to lists of delegator factory keys, see the Expressive delegators documentation for more details.extensions
: an associative array that maps service names to lists of extension factory names, see the the section below.shared
: associative array that map a service name to a boolean, in order to indicate the service manager if it should cache or not a service created through the get method, independant of the shared_by_default setting.shared_by_default
: boolean that indicates whether services created through theget
method should be cached. This istrue
by default.
Please note, that the whole configuration is available in the
$container
onconfig
key:
extensions
The
extensions
configuration is only available with the Pimple container. If you are using Aura.Di or zend-servicemanager, you can usedelegators
instead. It is recommended to usedelegators
if you'd like to keep the highest compatibility and might consider changing the container library you use in the future.
An extension factory has the following signature:
The parameters passed to the extension factory are the following:
$service
is the real service instance.$container
is the container that is used while creating the extension for the requested service.$name
is the name of the service being requested.
Here is an example extension factory:
You can also return a different instance from the extension factory:
Please note that when configuring extensions, you must provide a list of extension factories for the service, and not a single extension factory name:
Service extensions are called in the same order as defined in the list.
Using with Expressive
Replace contents of config/container.php
with the following: