2012-05-08 1 views
-1

Так что я schemca очень похож на:Yii Создание Создание и обновление MVC с несвязанными таблицами

users 
-------------- 
userid, name, password, email 

userinroles 
-------------- 
pk, userid, roleid 

roles 
----------- 
roleid, level, description 

Как вы можете видеть роли таблицы, связанные с пользователями через таблицу userinroles, это так пользователь могут редактировать права в разных группах и иметь разные уровни доступа для разных вещей. Например, они, возможно, должны быть редактором страниц, обладая супер правами администратора на модуле.

Проблема в том, когда я обновляю или создаю запись. Я не знаю, как перечислять роли, чтобы вы могли установить флажок, какую роль они должны иметь, и вставить в таблицу userinroles.

Любые идеи о том, как это сделать?

Модель:

Yii::import('application.models._base.BaseUser'); 
class User extends BaseUser 
{ 
    public static function model($className=__CLASS__) { 
     return parent::model($className); 
    } 
     public function rules() { 
     return array(
       array('username, password, email', 'required'), 
       array('isActive, isDeleted, isLocked', 'numerical', 'integerOnly'=>true), 
       array('username', 'length', 'max'=>50), 
       // Throws error if user name is not unique 
       array('username', 'unique', 'attributeName'=> 'username', 'caseSensitive' => 'false'), 
       array('password', 'length', 'max'=>255), 
       array('email, organization, position', 'length', 'max'=>100), 
       array('salt', 'length', 'max'=>32), 
       array('organization, position, salt, isActive, isDeleted, isLocked', 'default', 'setOnEmpty' => true, 'value' => null), 
       array('userid, username, password, email, organization, position, salt, isActive, isDeleted, isLocked', 'safe', 'on'=>'search'), 
     ); 
    } 
    public function relations() { 
     return array(
      'toolaccesses' => array(self::HAS_MANY, 'Toolaccess', 'userID'), 
      'usergalleries' => array(self::HAS_MANY, 'Usergallery', 'userid'), 
      'userinroles' => array(self::HAS_MANY, 'Userinroles', 'userid'), 
         'tools' =>array(self::MANY_MANY, 'Tool', 'toolid'), 
     ); 
    }   
} 

Контроллер:

class UserController extends GxController { 


    public function actionView($id) { 
     $this->render('view', array(
      'model' => $this->loadModel($id, 'User'), 
     )); 
    } 

    public function actionCreate() { 
     $model = new User; 


     if (isset($_POST['User'])) { 
      $model->setAttributes($_POST['User']); 

         // salting the user's password before we insert 
         $model->password = md5(Yii::app()->params["salt"] . $model->password); 

      if ($model->save()) { 
       if (Yii::app()->getRequest()->getIsAjaxRequest()) 
        Yii::app()->end(); 
       else 
        $this->redirect(array('view', 'id' => $model->userid)); 
      } 
     } 

     $this->render('create', array('model' => $model)); 
    } 

    public function actionUpdate($id) { 
     $model = $this->loadModel($id, 'User'); 

     if (isset($_POST['User'])) { 
        // testing if we need to salt the password. 
        if(strcmp($_POST['User']['password'], $model->password)!=0) 
        { // passwords passed in are not the same. We need to now modify the post password 
         $_POST['User']['password'] = md5(Yii::app()->params["salt"] . $_POST['User']['password']); 
        } 
        $model->setAttributes($_POST['User']); 
        if ($model->save()) { 
          $this->redirect(array('view', 'id' => $model->userid)); 
        } 
     } 

     $this->render('update', array(
       'model' => $model, 
       )); 
    } 

    public function actionDelete($id) { 
      // prevent the deletion of the super user, who has the ID 1. 
      // This is sort of like a Unix "root" user or a Window's Administrator 
      if($id == 1) 
      { 
       throw new CHttpException(400, Yii::t('app', 'You cannot delete the super admin.')); 
      } 
      else 
      { 
     if (Yii::app()->getRequest()->getIsPostRequest()) { 
      $this->loadModel($id, 'User')->delete(); 

      if (!Yii::app()->getRequest()->getIsAjaxRequest()) 
       $this->redirect(array('admin')); 
     } else 
      throw new CHttpException(400, Yii::t('app', 'Your request is invalid.')); 
      } 
    } 

    public function actionIndex() { 
     $dataProvider = new CActiveDataProvider('User'); 
     $this->render('index', array(
      'dataProvider' => $dataProvider, 
     )); 
    } 

    public function actionAdmin() { 
     $model = new User('search'); 
     $model->unsetAttributes(); 

     if (isset($_GET['User'])) 
      $model->setAttributes($_GET['User']); 

     $this->render('admin', array(
      'model' => $model, 
     )); 
    } 

} 

ответ

1

Во-первых, я думаю, вы должны использовать много-много отношение между пользователями и ролями таблицы -

public function relations() { 
    return array(
     'toolaccesses' => array(self::HAS_MANY, 'Toolaccess', 'userID'), 
     'usergalleries' => array(self::HAS_MANY, 'Usergallery', 'userid'), 
     'roles' => array(self::MANY_MANY, 'Roles', 'userinroles(userid, roleid)'), 
     'tools' => array(self::MANY_MANY, 'Tool', 'toolid'), 
    ); 

После этого, вы сможет получить роли для пользователей с $user->roles. О некоторых действиях с ролями, связанных с конкретным пользователем: я использую this extension, чтобы сохранить много-много отношений. Извините, если я понял, что вы ошибаетесь.