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.
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
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
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
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
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