繁体   English   中英

Yii2用户个人资料和Rbac

[英]Yii2 user profile and Rbac

我在基于Yii2的应用程序(SuperAdmin,Admin,User)中使用Rbac担任3个角色。 我如何将配置文件分配给这些用户。

我想要SuperAdmin配置文件的某些字段和Admin配置文件的其他字段,...

最初,最好通过编写迁移脚本并运行该脚本来为Yii2 rbac中的用户分配角色。 我的脚本看起来像这样

<?php

use yii\db\Schema;
use yii\db\Migration;
use yii\base\InvalidConfigException; 

use yii\rbac\DbManager;
use app\models\User;

class m141210_101111_user_authorize extends Migration
{
    /**
     * @throws yii\base\InvalidConfigException
     * @return DbManager
     *
     * Get the applications Authorization manager and make sure it's a valid 
     */
    protected function getAuthManager()
    {
        $authManager = Yii::$app->getAuthManager();
        if (!$authManager instanceof DbManager) {
            throw new InvalidConfigException('You should configure "authManager" component to use database before executing this migration.');
        }
        return $authManager;
    }

    public function up()
    {
        $authManager = $this->getAuthManager();
        $this->db = $authManager->db;

    $authManager = Yii::$app->getAuthManager();
        if (!$authManager instanceof DbManager) {
            throw new InvalidConfigException('You should configure "authManager" component in console.php to use database before executing this migration.');
        }

    $tableOptions = null;
        if ($this->db->driverName === 'mysql') {
            // http://stackoverflow.com/questions/766809/whats-the-difference-between-utf8-general-ci-and-utf8-unicode-ci
            $tableOptions = 'CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE=InnoDB';
        }

    $admin = $authManager->createRole('admin');
    $admin->description = 'Administrator - can do anything';
    $authManager->add($admin);

    $manager=$authManager->createRole('manager');
    $manager->description = 'Manager level access';
    $authManager->add($manager);

    $user=$authManager->createRole('end-user');
    $user->description = 'Normal user';
    $authManager->add($user);

    // let user admin have admin rights.

    if (!User::findOne(['username' => 'admin']))
         echo ('No user named "admin" was found to assign admin rights to!');

    $authManager->assign($admin, User::findOne(['username' => 'admin'])->id);

    }

    public function down()
    {
        echo "m141210_101111_user_authorize cannot be reverted.\n";
        return false;
    }
}

关键线是

 $authManager->assign($admin, User::findOne(['username' => 'admin'])->id);

一旦您的应用程序增长一点,您将必须构建一个管理界面,该界面允许您为用户分配角色。 (我现在正在建造那一点!)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM