2amigos Application Template

This Application Template is our proposed structure for your Yii2 applications. It makes use of a special library named ConfigKit

For further information regarding the use of this template, please visit its README file.

Step 1 - Install The Application template

We will assume that you have composer installed globally on your computer and also the fxp/composer-asset/plugin:^1.3 that is required for all Yii2 apps.

composer create-project --prefer-dist --stability=dev 2amigos/yii2-app-template your-site-name

Step 2 - Configure your application

Go to the config/web/modules folder and create a new PHP file named user.php. Then on in its contents write the configuration for the module:


return [
    'class' => Da\User\Module::class

Step 3 - Apply database schema migrations

This is obvious extension like our which deals with users, roles, permissions, etc. have to use some database. Our migrations are namespaced and available in Da\User\Migration namespace.

Before starting to work with database, please ensure you have deleted m130524_201442_init.php migration file which comes from the default installation of the Advanced Application Template. It's located at %PROJECT_DIR%/console/migrations/m130524_201442_init.php path.

There are two ways to apply migrations of this extension, the first one:

./yii migrate --migrationNamespaces=Da\\User\\Migration
./yii migrate --migrationPath=@yii/rbac/migrations
./yii migrate

First command applies migration set of the user module, and the second one is for application migrations.

Note, you cannot mix two ways: choose one of them, and stick with it.

The second way is more comfortable, and you don't have to remember to launch first command every time you obtain new version of our extension. First of all add the following lines to the file %PROJECT_DIR%/console/config/main.php:

return [
    // ...
    'controllerMap' => [
        'migrate' => [
            'class' => \yii\console\controllers\MigrateController::class,
            'migrationNamespaces' => [
            'migrationPath' => [
    // ...

This basically instructs your application to always try to use migrations from the given namespace. Which again is very convenient way to track new migration classes coming from this and possibly other extensions and sources.

Namespaced migrations were introduced in Yii 2.0.10, so before using them consider updating your framework installation version.

© 2amigos 2013-2019