Getting started
Controllers
Databases
Command line
Packages
Learn more
Configuration
The configuration of the Mako core is done in the index.php
file. This is where you set the error reporting level and define the paths to the application and framework directories.
You do not need to edit the paths unless you move the application and framework directories out of your webserver's document root.
All of the remaining framework configuration is done by editing the files that are located in the app/config
directory.
Config Files
Mako config files are just simple arrays:
<?php
return array
(
'key_1' => 'value',
'key_2' => 'value',
);
And loading a config file is done by using the Config::get
method.
config = Config::get('redis'); // Loads the redis.php file
You can also fetch config items using dot notation
:
$default = Config::get('redis.default');
It is also easy to override settings or add new configurations:
// Adds a new Crypto configuration named "user" that you can
// use when creating a Crypto instance "Crypto::instance('user');"
Config::set('crypto.configurations.user', array
(
'library' => 'mcrypt',
'cipher' => MCRYPT_RIJNDAEL_256,
'key' => 'ksMGBr_yR>=IiRicJFUhD4XlRnE%|11mvRGNJsD',
'mode' => MCRYPT_MODE_ECB,
));
Removing the custom configuration is done using the Config::delete
method:
Config::delete('crypto.configurations.user');
Cascading configuration
Sometimes you might want to edit the configuration files of a third party package. You can edit the package config file directly but the changes you make will be overwritten when you update the package. This is where cascading config files come become handy.
Lets say you have a packaged named foobar
with a config file.
/app
/packages
/foobar
/config
config.php
Just copy the file into app/config/packages/foobar
and the application will load that file instead of the one located in the package. This makes it possible to update the package while keeping your custom settings.
Environment aware configuration
Mako supports environment aware configuration. This means that you can have separate configuration files for your different environments. All you have to do is create a subdirectory with the name of your environment in the app/config
directory and copy the environment specific files into it.
Setting the environment in Apache:
SetEnv MAKO_ENV dev
Setting the environment in Nginx:
fastcgi_param MAKO_ENV dev;
Setting the environment in a linux/unix shell:
export MAKO_ENV=dev # for Bourne, bash, and related shells
setenv MAKO_ENV=dev # for csh and related shells
You can also manually set the environment in the CLI using the env option.
php reactor <task> --env=dev