mvbcoding / config-service-provider
A config ServiceProvider for Silex with support for php, json, yaml and toml.
Requires
- php: >=5.3.3,<8.0
- pimple/pimple: ^3.0
Requires (Dev)
- jamesmoss/toml: ^1.0
- phpunit/phpunit: ^5.4
- symfony/yaml: ^2.8|^3.0
Suggests
- jamesmoss/toml: For ToML configuration files
- symfony/yaml: For YAML configuration files
This package is auto-updated.
Last update: 2024-12-28 11:31:22 UTC
README
A config ServiceProvider for Silex with support for php, json, yaml and toml.
Version 1.0.0 is an import of igorw/ConfigServiceProvider Since this repository seems dead, I took the liberty to create my own version. All credits for this version go to igorw. Thanks!
I also incorperated some fixes from outstanding PR's:
Usage
Passing a config file
Pass the config file's path to the service provider's constructor. This is the recommended way of doing it, allowing you to define multiple environments.
$env = getenv('APP_ENV') ?: 'prod';
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/$env.json"));
Now you can specify a prod
and a dev
environment.
config/prod.json
{
"debug": false
}
config/dev.json
{
"debug": true
}
To switch between them, just set the APP_ENV
environment variable. In apache
that would be:
SetEnv APP_ENV dev
Or in nginx with fcgi:
fastcgi_param APP_ENV dev
Configuration values are set on the $app
object. For example, to retrieve the debug
configuration value, you can simply access the debug
key of $app
.
$app->get('/', function() use ($app) {
echo $app['debug'];
});
In order to prevent your configuration from overriding the keys that might be set on the application, you can pass in a prefix
to the constructor. This prefix will then be available as a key under which all your other configuration can be accessed:
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/$env.json", array(), null, 'example'));
You can now access the debug
value defined in your configuration like this:
$app->get('/', function() use ($app) {
echo $app['example']['debug'];
});
Replacements
Also, you can pass an array of replacement patterns as second argument.
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/services.json", array(
'data_path' => __DIR__.'/data',
)));
Now you can use the pattern in your configuration file.
/config/services.json
{
"xsl.path": "%data_path%/xsl"
}
You can also specify replacements inside the config file by using a key with
%foo%
notation:
{
"%root_path%": "../..",
"xsl.path": "%root_path%/xsl"
}
Using Yaml
To use Yaml instead of JSON, just pass a file that ends on .yml
:
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/services.yml"));
Note, you will have to require the ^2.8|^3.0
of the symfony/yaml
package.
Using TOML
To use TOML instead of any of the other supported formats,
just pass a file that ends on .toml
:
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/services.toml"));
Note, you will have to require the ^1.1
of the jamesmoss/toml
package and you are using
a bleeding edge configuration format, as the spec of TOML is still subject to change.
Using plain PHP
If reading the config file on every request becomes a performance problem in production, you can use a plain PHP file instead, and it will get cached by APC.
You'll have to rewrite your config to be a PHP file that returns the array of
config data, and also make sure it ends with .php
:
$app->register(new MvbCoding\Silex\ConfigServiceProvider(__DIR__."/../config/prod.php"));
Multiple config files
You can use multiple config files, e. g. one for a whole application and a
specific one for a task by calling $app->register()
several times, each time
passing another instance of MvbCoding\Silex\ConfigServiceProvider
.
Register order
Make sure you register ConfigServiceProvider last with your application. If you do not do this, the default values of other Providers will override your configuration.