Advanced Application Template

This page is dedicated for those who prefer to use more or less default Advanced Application Template provided by the Yii core team. Please check their readme file on why and when you should use it, for now we're going to explain on how Yii2 User Module extension could be used for the case if you prefer it.

We highly recommend you to use Sidekit Application Template which has sensible default packages, and everything you need to start project in no time with batteries included! ;-)

Check this manual page if you decided to use it.

If you want to use the default Basic Application Template with our extension, then check Basic Application Template documentation page.

Step 1 - Install Advanced Application template

Please check this document on how you can install Advanced Application Template. We're not going to cover this process here.

Step 2 - Configure your application

For now we will consider you need to setup user module for the backend tier of your project. User module needs to set and instantiate various settings, services, and parts to be used in application. That's why you have to include bootstrap class in your application bootstrapping workflow by adding the following lines in your %PROJECT_DIR%/backend/config/main.php:

return [
    // ... existing settings of the application
    'modules' => [
        'user' => [
            'class' => Da\User\Module::class,
        ],
    ],
    'components' => [
        // ... configuration of the existing application components
    ],
];

That's all from the part of the web application.

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,
            'migrationPath' => [
                '@app/migrations',
                '@yii/rbac/migrations', // Just in case you forgot to run it on console (see next note)
            ],
            'migrationNamespaces' => [
                'Da\User\Migration',
            ],
        ],
    ],
    // ...
];

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