static function getUserPermissions($user_groups) { $model = new cmsModel(); $model->filterIn('group_id', $user_groups); $model->select('r.name', 'rule_name'); $model->select('r.type', 'rule_type'); $model->select('r.options', 'rule_options'); $model->joinInner('perms_rules', 'r FORCE INDEX (PRIMARY ) ', 'r.id = i.rule_id'); $items = $model->get('perms_users', false, false); if (!$items) { return false; } $values = array(); foreach ($items as $item) { // // Для правил, которые являются списками важен порядок опций // Здесь мы проверяем, что более приоритетная опция не была // уже присвоена ранее // Такое может быть, если пользователь состоит в нескольких // группах, тогда будет браться самая приоритетная из всех // доступных опций (значений) этого правила // if ($item['rule_type'] == 'list') { $rule_options = explode(',', $item['rule_options']); if (isset($values[$item['subject']][$item['rule_name']])) { $current_value = $values[$item['subject']][$item['rule_name']]; $current_priority = array_search($current_value, $rule_options); $next_priority = array_search($item['value'], $rule_options); if ($current_priority >= $next_priority) { continue; } } } $values[$item['subject']][$item['rule_name']] = $item['value']; } return $values; }
/** * Возвращает пользователей групп, для которых переданное правило включено * или установлено в значение $value * * @param string $controller Название компонента * @param string $name Название правила * @param mixed $value Значение правила. Если не передано, значение не учитывается * @param string $subject Субъект правила. Если не передан, то одинаков с компонентом * * @return array Массив пользователей с данными: id, email, nickname, avatar, notify_options, is_online */ static function getRulesGroupMembers($controller, $name, $value = false, $subject = false) { if (!$subject) { $subject = $controller; } $model = new cmsModel(); $rule = $model->filterEqual('controller', $controller)->filterEqual('name', $name)->getItem('perms_rules'); if (!$rule) { return array(); } $model->filterEqual('subject', $subject)->filterEqual('rule_id', $rule['id']); if ($value) { $model->filterEqual('value', $value); } $groups_ids = $model->selectOnly('group_id')->get('perms_users', function ($item, $model) { return $item['group_id']; }, 'group_id'); if (!$groups_ids) { return array(); } return $model->filterIn('group_id', $groups_ids)->selectOnly('user_id', 'id')->joinUser('user_id', array('u.notify_options' => 'notify_options', 'u.email' => 'email', 'u.nickname' => 'nickname', 'u.avatar' => 'avatar'))->get('{users}_groups_members', function ($item, $model) { $item['notify_options'] = cmsModel::yamlToArray($item['notify_options']); $item['is_online'] = cmsUser::userIsOnline($item['id']); return $item; }); }
public static function deleteOldSessions($current_user_id = 0) { $expired_users = array(); if (self::$online_users) { foreach (self::$online_users as $k => $user) { if (time() - self::$online_interval >= strtotime($user['date_created'])) { $expired_users[] = $user['user_id']; if ($current_user_id != $user['user_id']) { unset(self::$online_users[$k]); } } } } if ($expired_users) { $model = new cmsModel(); $model->filterIn('user_id', $expired_users)->deleteFiltered('sessions_online'); } }
public static function deleteOldSessions() { $model = new cmsModel(); $model->filterDateOlder('date_created', 3, 'MINUTE'); $users = $model->get('sessions_online', function ($item, $model) { return $item['user_id'] ? $item['user_id'] : false; }, false); if ($users) { $model->filterIn('id', $users)->updateFiltered('{users}', array('is_online' => 0)); $model->filterDateOlder('date_created', 3, 'MINUTE')->deleteFiltered('sessions_online'); } }