Example #1
0
 /**
  * Displays a particular model.
  * @param integer $id the ID of the model to be displayed
  */
 public function actionView($id)
 {
     Acl::hasPrivilege($this->privileges, $this->resource, Acl::ACTION_VIEW);
     $model = UserRoles::model()->loadModel($id);
     $this->pageTitle = $model->name;
     $this->showPageTitle = TRUE;
     $this->pageDescription = $model->description;
     $forbidden_resources = Acl::getForbiddenResources(UserLevels::LEVEL_ENGINEER);
     $resources = UserResources::model()->getResources($forbidden_resources);
     if (isset($_POST['RolesOnResources'])) {
         $roles_on_resources = $_POST['RolesOnResources'];
         foreach ($roles_on_resources as $key => $rr) {
             UserRolesOnResources::model()->set($key, $id, $rr);
         }
         Yii::app()->user->setFlash('success', Lang::t('SUCCESS_MESSAGE'));
         $this->refresh();
     }
     $this->render('view', array('model' => $model, 'resources' => $resources));
 }
Example #2
0
 /**
  * Gets system-wide privileges of a user;
  * @param type $user_id
  */
 public static function getPrivileges($user_id = NULL)
 {
     /*
      * 1. get all the resources
      * 2. get user_type & role
      * 3. for each resources check whether it is forbidden
      * 4.If user type =system_engineer or super_admin return true
      * 5.Check if the role has privilege
      */
     if (empty($user_id)) {
         $user_id = Yii::app()->user->id;
     }
     //get all resources
     $resources = UserResources::model()->getResources();
     $user_model = Users::model()->loadModel($user_id);
     $forbidden_resources = self::getForbiddenResources($user_model->user_level);
     $role_on_resources = UserRolesOnResources::model()->getData('*', '`role_id`=:t1', array(':t1' => $user_model->role_id));
     return self::check($resources, $user_model, $forbidden_resources, $role_on_resources);
 }
Example #3
0
    } else {
        ?>
N/A<?php 
    }
    ?>
</td><td><?php 
    if (UserResources::model()->get($r['id'], 'updateable') == 1) {
        echo CHtml::hiddenField('RolesOnResources[' . $r['id'] . '][update]', 0);
        echo CHtml::checkBox('RolesOnResources[' . $r['id'] . '][update]', UserRolesOnResources::model()->getValue($r['id'], $model->id, 'update'), array('class' => 'my-roles-checkbox'));
    } else {
        ?>
N/A<?php 
    }
    ?>
</td><td><?php 
    if (UserResources::model()->get($r['id'], 'deleteable') == 1) {
        echo CHtml::hiddenField('RolesOnResources[' . $r['id'] . '][delete]', 0);
        echo CHtml::checkBox('RolesOnResources[' . $r['id'] . '][delete]', UserRolesOnResources::model()->getValue($r['id'], $model->id, 'delete'), array('class' => 'my-roles-checkbox'));
    } else {
        ?>
N/A<?php 
    }
    ?>
</td></tr>
                                        <?php 
}
?>
                                </tbody>
                        </table>
                </div>
                <?php 
 public function actionIndex()
 {
     $this->hasPrivilege(Acl::ACTION_VIEW);
     $this->pageTitle = Lang::t($this->resourceLabel . 's');
     $this->showPageTitle = TRUE;
     $this->render('index', array('model' => UserResources::model()->searchModel(array(), $this->settings[Constants::KEY_PAGINATION], 'id')));
 }