Аккуратный способ проверить уровни групп пользователей? - PullRequest
0 голосов
/ 30 мая 2011

Что такое аккуратный солютон для проверки уровня группы пользователей для выполнения определенных задач

Группы: 2 администратора, 3 модератора, 4 технологических заказа

Предположим, data['user']['group_id'] равно 3

Я придумал это решение.

Решение 1:

$allowGroup = array(2, 3, 4);
if (in_array($this->data['user']['group_id'], $allowGroup)) {
    //Show a list of records
    if ($this->data['user']['group_id'] == 2) {
      //Show buttons to delete records (only admin can do this)
     }
}

Решение 2:

if (($this->data['user']['group_id'] == 3) || ($this->data['user']['group_id'] == 4)) {
      //Member can do this action..
}

Ответы [ 2 ]

2 голосов
/ 30 мая 2011

Немного более эффективным, но менее читаемым методом было бы указать ваши «разрешенные» уровни в качестве ключей массива. Тогда это простой поиск в массиве, без необходимости вызывать in_array (), что сделало бы (более) дорогой цикл:

$rawAllow = array(2,3,4);
$allowed = array_flip($rawAllow);

if (isset($allowed[$this->data['user']['group_id']])) {
   ... this user is allowed to perform the action...
}
1 голос
/ 30 мая 2011

Посмотрите на: Битовые операторы

С этим вы можете сделать что-то вроде (знайте, что это очень простой пример!):

<?php
// example actions
$actions = array(
    'create'    => 1,
    'read'      => 2,
    'update'    => 4,
    'delete'    => 8,
);

// example groups
$groups = array(
    // Admins
    2 => $actions['create'] ^ $actions['read'] ^ $actions['update'] ^ $actions['delete'],

    // Moderators
    3 => $actions['create'] ^ $actions['read'] ^ $actions['update'],

    // Process Orders
    4 => $actions['read'] ^ $actions['update'],
);

// example users
$users = array(
    // Admin
    (object)array(
        'id' => 1,
        'groupId' => 2, 
    ),

    // Moderator
    (object)array(
        'id' => 2,
        'groupId' => 3, 
    ),

    // Process Order
    (object)array(
        'id' => 3,
        'groupId' => 4,
    ),
);

foreach ($users as $user) {
    if (isset($groups[$user->groupId])) {
        printf('User: %s is allowed to: ' . "\n", $user->id);   

        if ($groups[$user->groupId] & $actions['create']) {
            echo ' create';
        }

        if ($groups[$user->groupId] & $actions['read']) {
            echo ' read';
        }

        if ($groups[$user->groupId] & $actions['update']) {
            echo ' update';
        }

        if ($groups[$user->groupId] & $actions['delete']) {
            echo ' delete';
        }

        echo "\n\n";
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...