2017 © Pedro Peláez
 

library module-user-management

User with improved RBAC

image

webvimark/module-user-management

User with improved RBAC

  • Monday, October 24, 2016
  • by webvimark
  • Repository
  • 38 Watchers
  • 126 Stars
  • 28,804 Installations
  • PHP
  • 2 Dependents
  • 0 Suggesters
  • 104 Forks
  • 48 Open issues
  • 15 Versions
  • 6 % Grown

The README.md

User management module for Yii 2

This repository is not actively maintained. If you want to add some changes, just fork it and safely use your fork., (*1)

Perks

  • User management
  • RBAC (roles, permissions and stuff) with web interface
  • Registration, authorization, password recovery and so on
  • Visit log
  • Optimised (zero DB queries during usual user workflow)
  • Nice widgets like GhostMenu or GhostHtml::a where elements are visible only if user has access to route where they point

Installation

The preferred way to install this extension is through composer., (*2)

Either run, (*3)

composer require webvimark/module-user-management

or add, (*4)

"webvimark/module-user-management": "^1"

to the require section of your composer.json file., (*5)

Configuration

1) In your config/web.php, (*6)


'components'=>[ 'user' => [ 'class' => 'webvimark\modules\UserManagement\components\UserConfig', // Comment this if you don't want to record user logins 'on afterLogin' => function($event) { \webvimark\modules\UserManagement\models\UserVisitLog::newVisitor($event->identity->id); } ], ], 'modules'=>[ 'user-management' => [ 'class' => 'webvimark\modules\UserManagement\UserManagementModule', // 'enableRegistration' => true, // Add regexp validation to passwords. Default pattern does not restrict user and can enter any set of characters. // The example below allows user to enter : // any set of characters // (?=\S{8,}): of at least length 8 // (?=\S*[a-z]): containing at least one lowercase letter // (?=\S*[A-Z]): and at least one uppercase letter // (?=\S*[\d]): and at least one number // $: anchored to the end of the string //'passwordRegexp' => '^\S*(?=\S{8,})(?=\S*[a-z])(?=\S*[A-Z])(?=\S*[\d])\S*$', // Here you can set your handler to change layout for any controller or action // Tip: you can use this event in any module 'on beforeAction'=>function(yii\base\ActionEvent $event) { if ( $event->action->uniqueId == 'user-management/auth/login' ) { $event->action->controller->layout = 'loginLayout.php'; }; }, ], ],

To learn about events check:, (*7)

  • http://www.yiiframework.com/doc-2.0/guide-concept-events.html
  • http://www.yiiframework.com/doc-2.0/guide-concept-configurations.html#configuration-format

Layout handler example in AuthHelper::layoutHandler(), (*8)

To see full list of options check UserManagementModule file, (*9)

2) In your config/console.php (this is needed for migrations and working with console), (*10)


'modules'=>[ 'user-management' => [ 'class' => 'webvimark\modules\UserManagement\UserManagementModule', 'controllerNamespace'=>'vendor\webvimark\modules\UserManagement\controllers', // To prevent yii help from crashing ], ],

3) Run migrations, (*11)


./yii migrate --migrationPath=vendor/webvimark/module-user-management/migrations/

4) In you base controller, (*12)


public function behaviors() { return [ 'ghost-access'=> [ 'class' => 'webvimark\modules\UserManagement\components\GhostAccessControl', ], ]; }

Where you can go


false, 'activateParents'=>true, 'items' => [ [ 'label' => 'Backend routes', 'items'=>UserManagementModule::menuItems() ], [ 'label' => 'Frontend routes', 'items'=>[ ['label'=>'Login', 'url'=>['/user-management/auth/login']], ['label'=>'Logout', 'url'=>['/user-management/auth/logout']], ['label'=>'Registration', 'url'=>['/user-management/auth/registration']], ['label'=>'Change own password', 'url'=>['/user-management/auth/change-own-password']], ['label'=>'Password recovery', 'url'=>['/user-management/auth/password-recovery']], ['label'=>'E-mail confirmation', 'url'=>['/user-management/auth/confirm-email']], ], ], ], ]); ?>

First steps

From the menu above at first you'll se only 2 element: "Login" and "Logout" because you have no permission to visit other urls and to render menu we using GhostMenu::widget(). It's render only element that active user can visit., (*13)

Also same functionality has GhostNav::widget() and GhostHtml:a(), (*14)

1) Login as superadmin/superadmin, (*15)

2) Go to "Permissions" and play there, (*16)

3) Go to "Roles" and play there, (*17)

4) Go to "User" and play there, (*18)

5) Relax, (*19)

Usage

You controllers may have two properties that will make whole controller or selected action accessible to everyone, (*20)

public $freeAccess = true;

Or, (*21)

public $freeAccessActions = ['first-action', 'another-action'];

Here are list of the useful helpers. For detailed explanation look in the corresponding functions., (*22)


User::hasRole($roles, $superAdminAllowed = true) User::hasPermission($permission, $superAdminAllowed = true) User::canRoute($route, $superAdminAllowed = true) User::assignRole($userId, $roleName) User::revokeRole($userId, $roleName) User::getCurrentUser($fromSingleton = true)

Role, Permission and Route all have following methods, (*23)


Role::create($name, $description = null, $groupCode = null, $ruleName = null, $data = null) Role::addChildren($parentName, $childrenNames, $throwException = false) Role::removeChildren($parentName, $childrenNames)

Events

Events can be handled via config file like following, (*24)


'modules'=>[ 'user-management' => [ 'class' => 'webvimark\modules\UserManagement\UserManagementModule', 'on afterRegistration' => function(UserAuthEvent $event) { // Here you can do your own stuff like assign roles, send emails and so on }, ], ],

List of supported events can be found in UserAuthEvent class, (*25)

FAQ

Question: Do you have API docs?, (*26)

Answer: Check this one http://opensource.id5.com.br/webvimark/doc/index.html (Credits to lukBarros), (*27)

Question: I want users to register and login with they e-mails! Mmmmm... And they should confirm it too!, (*28)

Answer: See configuration properties $useEmailAsLogin and $emailConfirmationRequired, (*29)

Question: I want to have profile for user with avatar, birthday and stuff. What should I do ?, (*30)

Answer: Profiles are to project-specific, so you'll have to implement them yourself (but you can find example here - https://github.com/webvimark/user-management/wiki/Profile-and-custom-registration). Here is how to do it without modifying this module, (*31)

1) Create table and model for profile, that have user_id (connect with "user" table), (*32)

2) Check AuthController::actionRegistration() how it works (you can skip this part), (*33)

3) Define your layout for registration. Check example in AuthHelper::layoutHandler(). Now use theming to change registraion.php file, (*34)

4) Define your own UserManagementModule::$registrationFormClass. In this class you can do whatever you want like validating custom forms and saving profiles, (*35)

5) Create your controller where user can view profiles, (*36)

The Versions