2011-11-02 66 views
0

yiic shell運行自定義命令時,出現以下錯誤。 我對OS X 10.7.2在yiic shell工具中使用authManager使用RBAC ACL導致CException錯誤

採用最新MAMP 2.0.2我不知道是什麼錯誤由readermember意味着不存在?

線56:$role->addChild("reader");和自定義命令的完整代碼和終端輸出低於:

users-MacBook-Air:protected user$ ./yiic shell ../index.php 
Yii Interactive Tool v1.1 (based on Yii v1.1.2) 
Please type 'help' for help. Type 'exit' to quit. 
>> rbac 
This command will create three roles: Owner, Member, and Reader and the following permissions: 
create, read, update and delete user 
create, read, update and delete project 
create, read, update and delete issue 
Would you like to continue? [Yes|No]y 
exception 'CException' with message 'Either "member" or "reader" does not exist.' in /Users/user/Dropbox/localhost/yii/framework/web/auth/CDbAuthManager.php:203 
Stack trace: 
#0 /Users/user/Dropbox/localhost/yii/framework/web/auth/CAuthItem.php(185): CDbAuthManager->addItemChild('member', 'reader') 
#1 /Users/user/Dropbox/localhost/trackstar/protected/commands/shell/RbacCommand.php(56): CAuthItem->addChild('reader') 
#2 /Users/user/Dropbox/localhost/yii/framework/cli/commands/ShellCommand.php(144): RbacCommand->run(Array) 
#3 /Users/user/Dropbox/localhost/yii/framework/cli/commands/ShellCommand.php(99): ShellCommand->runShell() 
#4 /Users/user/Dropbox/localhost/yii/framework/console/CConsoleCommandRunner.php(62): ShellCommand->run(Array) 
#5 /Users/user/Dropbox/localhost/yii/framework/console/CConsoleApplication.php(88): CConsoleCommandRunner->run(Array) 
#6 /Users/user/Dropbox/localhost/yii/framework/base/CApplication.php(135): CConsoleApplication->processRequest() 
#7 /Users/user/Dropbox/localhost/yii/framework/yiic.php(33): CApplication->run() 
#8 /Users/user/Dropbox/localhost/trackstar/protected/yiic.php(7): require_once('/Users/user/Dro...') 
#9 /Users/user/Dropbox/localhost/trackstar/protected/yiic(4): require_once('/Users/user/Dro...') 
#10 {main} 
>> 

RBAC命令:

<?php 

    class RbacCommand extends CConsoleCommand 
    { 
     private $_authManager; 

     public function getHelp() 
     { 
      return "<<<EOD 

      USAGE 
       rbac 

      DESCRIPTION 
       This command generates an initial RBAC authorization hierarchy. 

      EOD"; 
     } 

     public function run($args) 
     { 
      if(($this->_authManager=Yii::app()->authManager)===null) 
      { 
       echo "Error: an authorization manager, named 'authManager' must be configured to use this command.\n"; 
       echo "If you already added 'authManager' component in applicaton configuration,\n"; 
       echo "please quit and re-enter the yiic shell.\n"; 
       return; 
      } 

      echo "This command will create three roles: Owner, Member, and Reader and the following permissions:\n"; 
      echo "create, read, update and delete user\n"; 
      echo "create, read, update and delete project\n"; 
      echo "create, read, update and delete issue\n"; 
      echo "Would you like to continue? [Yes|No]"; 

      if(!strncasecmp(trim(fgets(STDIN)),'y',1)) 
      { 
       $this->_authManager->clearAll(); 

       $this->_authManager->createOperation("createUser","create a new user"); 
       $this->_authManager->createOperation("readUser","read user profile information"); 
       $this->_authManager->createOperation("updateUser","update a users information"); 
       $this->_authManager->createOperation("deleteUser","remove a user from a project"); 

       $this->_authManager->createOperation("createProject","create a new project"); 
       $this->_authManager->createOperation("readProject","read project information"); 
       $this->_authManager->createOperation("updateProject","update project information"); 
       $this->_authManager->createOperation("deleteProject","delete a project"); 

       $this->_authManager->createOperation("createIssue","create a new issue"); 
       $this->_authManager->createOperation("readIssue","read issue information"); 
       $this->_authManager->createOperation("updateIssue","update issue information"); 
       $this->_authManager->createOperation("deleteIssue","delete a issue"); 

       $role=$this->_authManager->createRole("member"); 
       $role->addChild("reader"); 
       $role->addChild("createIssue"); 
       $role->addChild("updateIssue"); 
       $role->addChild("deleteIssue"); 

       $role=$this->_authManager->createRole("owner"); 
       $role->addChild("reader"); 
       $role->addChild("member"); 
       $role->addChild("createUser"); 
       $role->addChild("updateUser"); 
       $role->addChild("deleteUser"); 
       $role->addChild("createProject"); 
       $role->addChild("updateProject"); 
       $role->addChild("deleteProject"); 
      } 
     } 
    } 

?> 

回答

0

我認爲你需要創建「讀者「操作(或任務或角色),然後才能使用addChild()將其添加到」成員「角色。事情是這樣的:

<?php 
// define reader role 
$role=$this->_authManager->createRole("reader"); 
// add some operations 
$role->addChild("readIssue"); 
// NOW create the member role 
$role=$this->_authManager->createRole("member"); 
// and now that reader is defined, we can add it to member 
$role->addChild("reader"); 
?> 

我相信你已經找到這一點,但也有對Yii Guide page for Role-based ACL更多細節。