Loads constants variables from .const.ini
, .const.[APP_ENV].ini
files.
Make sure the .const.ini
, .const.*.ini
, file is added to your .gitignore so it is not checked-in the code.
Add this to your .gitignore :
.const.ini
.const.*.ini
Create your .const.ini
and put any variables in !
Dotconst work with .ini file.
Every sections will be flatten. Each variable will be prefixed with the section name.
Every variable will be UPPERIZED. e.g.
[database]
user = db_user
Will become
DATABASE_USER === 'db_user'
base_path = @php/dir
app_env = @php/env:APP_ENV
php_v = @php/const:PHP_VERSION_ID
Will become :
BASE_PATH === {base path of .const.ini file}
APP_ENV === getenv('APP_ENV')
PHP_V === PHP_VERSION_ID
And compile :
define('BASE_PATH', '{base path of .const.ini file}');
define('APP_ENV', getenv('APP_ENV'));
define('PHP_V', PHP_VERSION_ID);
It's really simple, just add this to your bootstrap :
\Neutrino\Dotconst::load('/ini_path' [, '/compile_path']);
The first file called is ".const.ini". If the variable "APP_ENV" is defined in this file, dotconst will look for the file ".const. {APP_ENV} .ini", and override the base values. Useful when working on multiple environments.
; .const.ini
[app]
env = production
[database]
host = localhost
; .const.production.ini
[database]
host = 10.0.0.0
Will become
DATABASE_HOST === '10.0.0.0'
For the best performance, you can compile the variables loaded into a php file, by calling :
\Neutrino\Dotconst\Compile::compile('/ini_path', '/compile_path');
Will generate for this ini file :
; .const.ini
[database]
user = db_user
define('DATABASE_USER', 'db_user');
I can easily extends Dotconst :
class MyExtention extends \Neutrino\Dotconst\Extensions\Extension{
protected $identifier = "php/my";
public function parse($value, $path) {
return 'my';
}
public function compile($value, $path){
return "'my'";
}
}
\Neutrino\Dotconst::addExtension(MyExtention::class);
In your .const.ini file :
[foo]
bar = @php/my
Will be parse :
FOO_BAR === 'my'
And compile :
define('FOO_BAR', 'my');