ConfigKit
, (*1)
In order to provide ourselves a higher flexibility with the way we build templates for our Yii based projects, we built this kit. It is, in a way, the newest generation of the widely used YiiBootstrap
, but it is so much better structured and less complex than the previously mentioned was., (*2)
As we all know, Yii has a very cumbersome array configuration for its bootstrap process. The main.php
script normally
contains a lot of information in it regarding application settings, components, modules and parameters, and many times
we find ourselves dealing with a huge file with settings that, even though they are ordered by keys, fails to be
clear due to the amount of lines within it., (*3)
ConfigKit tries to solve that issue, allowing us to create project templates with a different bootstrap and
configuration building process. It proposes the following configuration folder structure:, (*4)
config
โโโ codeception [ application name that contains its configuration ]
| โโโ app.php
โโโ console [ application name ]
| |
| โโโ components
| โโโ params
| โโโapp.php [ app.php contains simple attribute configuration ]
|
โโโ web [ application name ]
|
โโโ components [ main section on configuration ]
| โโโ cache.php [ the name of the file, is the name of the component ]
| โโโ db.php [ the contents of the file, are the settings of the component ]
| โโโ log.php
โโโ params [ main section on app configuration ]
| โโโ mail.php
โโโ app.php
Please, keep in mind that the above configuration folder structure is really up to you. ConfigKit
requires a ConfigurationBuilder
that you are responsible to develop and it can have the above recommendation or another one. For an example of a ConfigurationBuilder
please visit https://github.com/sidekit/yii2-app-template/blob/master/src/App/Configuration/ConfigurationBuilder.php, (*5)
Config File Examples
Example of app.php
<?php
use Da\Config\Configuration;
return [
/*
* --------------------------------------------------------------------------
* Application
* --------------------------------------------------------------------------
*
* Base class for all application classes. Here we configure the attributes
* that do not hold any object configuration such as "components" or
* "modules". The configuration of those properties are within submodules of
* the same name.
*/
'id' => 'application-id',
'basePath' => Configuration::app()->getBasePath(),
'vendorPath' => Configuration::app()->getVendorPath(),
'runtimePath' => Configuration::app()->getRuntimePath(),
'language' => Configuration::env()->get('APP_LANGUAGE'),
'bootstrap' => ['log'],
];
Example of a component file: db.php
<?php
use Da\Config\Configuration;
return [
/*
* --------------------------------------------------------------------------
* Connection
* --------------------------------------------------------------------------
*
* Represents a connection to a database via PDO.
*/
'class' => 'yii\db\Connection',
'dsn' => Configuration::env()->get('DATABASE_DSN'),
'username' => Configuration::env()->get('DATABASE_USER'),
'password' => Configuration::env()->get('DATABASE_PASSWORD'),
'charset' => Configuration::env()->get('DATABASE_CHARSET'),
'tablePrefix' => Configuration::env()->get('DATABASE_TABLE_PREFIX'),
];
Environment Settings Overrides
We know how important settings for different environments are , such as: test, local, stage and prod environments. The proposed solution to dealing with them is as simple as adding a config folder with the name of the environment needed that has the same structure within, as the previously mentioned the folder. We never found ourselves having to clone the entire structure, so you can just simply place in it the files that contains the settings you wish to override., (*6)
env
|
โโโ local [ the environment name ]
โโโ web [ the application which settings we need to override ]
|
โโโ components
| โโโ db.php [ the component (filename) and its settings that we wish to override ]
โโโ params
โโโ mail.php [ the parameters to override ]
Bootstrapping
We believe that application bootstrapping should also be as structured as its configuration. That way, all
processes are much clear and easier to manage and scale. In the Yii 2 proposed project's template
https://github.com/2amigos/yii2-app-template you can see a working
sample of ConfigKit
library + a proposed bootstrapping process. The following is the startup process of a web
application:, (*7)
<?php
/*
* --------------------------------------------------------------------------
* Register auto loaders
* --------------------------------------------------------------------------
*
* Add registered class loaders required for our application.
*
*/
require __DIR__ . '/../bootstrap/autoload.php';
/*
* --------------------------------------------------------------------------
* Initialize SideKit library
* --------------------------------------------------------------------------
*
* This step is required *prior* adding the application script.
*
*/
require __DIR__ . '/../bootstrap/sidekit.php';
/*
* --------------------------------------------------------------------------
* Initialize custom aliases
* --------------------------------------------------------------------------
*
* Add custom aliases to the application. Added after sidekit to take
* advantage of its loaded configuration values
*/
require __DIR__ . '/../bootstrap/aliases.php';
/*
* --------------------------------------------------------------------------
* Configure and Go!
* --------------------------------------------------------------------------
*
* Bootstrap the configuration processes and get and Application ready to use.
* Applying configuration details in a different file allow us to free up
* unnecessary code on the entry script.
*/
$app = require __DIR__ . '/../bootstrap/web.php';
$app->run();
Clean code
We have added some development tools for you to contribute to the library with clean code:, (*8)
- PHP mess detector: Takes a given PHP source code base and look for several potential problems within that source.
- PHP code sniffer: Tokenizes PHP, JavaScript and CSS files and detects violations of a defined set of coding standards.
- PHP code fixer: Analyzes some PHP source code and tries to fix coding standards issues.
And you should use them in that order., (*9)
Using php mess detector
Sample with all options available:, (*10)
./vendor/bin/phpmd ./src text codesize,unusedcode,naming,design,controversial,cleancode
Using code sniffer
./vendor/bin/phpcs -s --report=source --standard=PSR2 ./src
Using code fixer
We have added a PHP code fixer to standardize our code. It includes Symfony, PSR2 and some contributors rules., (*11)
./vendor/bin/php-cs-fixer fix ./src --config .php_cs.dist
Testing
, (*12)