我正在使用Ion Auth作为我的codeigniter应用程序,除了一件事,一切看起来都很好。
我需要显示一个用户列表以及他们所在的组。如何在不创建自己的模型并查询的情况下检索特定用户的组ID。
$this->ion_auth->user($id)->row();
无法检索组ID。
答案 0 :(得分:8)
Ion Auth已更新并删除了最新版本中的 get_user 功能。因此,下面应该返回登录用户的当前组ID:
$this->ion_auth->get_users_groups()->row()->id
如果您想获取特定用户的组ID,可以将用户ID传递给 get_users_groups 方法。
答案 1 :(得分:3)
获取对象:
$user_groups = $this->ion_auth->get_users_groups($user->id)->result();
获取该组的名称:
$this->ion_auth->get_users_groups($data['id'])->row()->name;
就我而言:
$data['groups'] = $this->ion_auth->get_users_groups($data['id'])->row()
您可以查看有关获取用户群组的官方文档:
答案 2 :(得分:3)
我遇到过这个问题,因为我想在成功登录后向会话中添加用户的group_id。如果有人感兴趣,我就是这样做的(一旦我设法弄清楚一切都在哪里)。
在ion_auth_model.php中,我使用了set_session函数:
public function set_session($user)
{
$this->trigger_events('pre_set_session');
$session_data = array(
'identity' => $user->{$this->identity_column},
'username' => $user->username,
'email' => $user->email,
'user_id' => $user->id, //everyone likes to overwrite id so we'll use user_id
'old_last_login' => $user->last_login
);
$this->session->set_userdata($session_data);
$this->trigger_events('post_set_session');
return TRUE;
}
并将其修改为:
public function set_session($user)
{
$this->trigger_events('pre_set_session');
$session_data = array(
'identity' => $user->{$this->identity_column},
'username' => $user->username,
'email' => $user->email,
'user_id' => $user->id, //everyone likes to overwrite id so we'll use user_id
'old_last_login' => $user->last_login
);
//get user group ids for user and pass to session
$groups = $this->ion_auth->get_users_groups($user->id)->result();
foreach ($groups as $row){
$session_data['groups'][] = $row->id;
}
$this->session->set_userdata($session_data);
$this->trigger_events('post_set_session');
return TRUE;
}
现在它将一个数组写入名为groups的会话,该会话是用户所属的所有组的列表。
我唯一需要做的就是修改Ion_auth.php中的注销功能(在应用程序/库中),以确保通过添加
取消设置组会话变量$this->session->unset_userdata('groups');
到其他unset_userdata()语句的列表。
我知道我可能应该扩展库/模型以保持核心不受影响,但你可以采取我所做的并轻松地做到这一点。
希望这有助于某人。
罗布
答案 3 :(得分:0)
尝试将此添加到ion_auth_model.php (或将查询放在其他地方)
/**
* get_all_users_with_group
*
* @return array
**/
public function get_all_users_with_group()
{
$this->trigger_events('get_all_users_with_groups');
return $this->db->select(
$this->tables['users'].'.*, '.
$this->tables['users_groups'].'.'.$this->join['groups'].' as group_id, '.
$this->tables['groups'].'.name as group_name, '.
$this->tables['groups'].'.description as group_desc'
)
->join($this->tables['users_groups'], $this->tables['users_groups'].'.'.$this->join['users'].'='.$this->tables['users'].'.id')
->join($this->tables['groups'], $this->tables['users_groups'].'.'.$this->join['groups'].'='.$this->tables['groups'].'.id')
->get($this->tables['users']);
}
答案 4 :(得分:0)
在控制器中使用:
$groups = array(1,2,3,4);
$this->data['list_staff'] = $this->ion_auth->users($groups)->result(); // выбираем всех teachers из зарегистрированных пользователей
foreach ($this->data['list_staff'] as $k => $one_staff)
{
$this->data['list_staff'][$k]->groups = $this->ion_auth->get_users_groups($one_staff->id)->result();
}
并在视图中使用:
<?php foreach($list_staff as $one):?>
<?php foreach ($one->groups as $group):?>
<?php echo $group->description;?>,
<?php endforeach?>
<?endforeach;?>
但是如何获取当前登录用户的组(例如在我的个人资料中)我会找到下一个决定。
控制器:
$this->data['this_user_groups'] = $this->ion_auth->get_users_groups()->result();
并查看:
<?php foreach ($this_user_groups as $group):?>
<?php echo $group->description;?>,
<?php endforeach?>