-
-
Notifications
You must be signed in to change notification settings - Fork 207
/
GroupModel.php
146 lines (126 loc) · 3.66 KB
/
GroupModel.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
<?php namespace Myth\Auth\Authorization;
use CodeIgniter\Model;
class GroupModel extends Model
{
protected $table = 'auth_groups';
protected $primaryKey = 'id';
protected $allowedFields = [
'name', 'description'
];
protected $useTimestamps = false;
protected $validationRules = [
'name' => 'required|max_length[255]|is_unique[auth_groups.name,name,{name}]',
'description' => 'max_length[255',
];
protected $validationMessages = [];
protected $skipValidation = false;
//--------------------------------------------------------------------
// Users
//--------------------------------------------------------------------
/**
* Adds a single user to a single group.
*
* @param $userId
* @param $groupId
*
* @return object
*/
public function addUserToGroup(int $userId, int $groupId)
{
$data = [
'user_id' => (int)$userId,
'group_id' => (int)$groupId
];
return $this->db->insert('auth_groups_users', $data);
}
/**
* Removes a single user from a single group.
*
* @param $userId
* @param $groupId
*
* @return bool
*/
public function removeUserFromGroup(int $userId, $groupId)
{
return $this->db->where([
'user_id' => (int)$userId,
'group_id' => (int)$groupId
])->delete('auth_groups_users');
}
/**
* Removes a single user from all groups.
*
* @param $userId
*
* @return mixed
*/
public function removeUserFromAllGroups(int $userId)
{
return $this->db->where('user_id', (int)$userId)
->delete('auth_groups_users');
}
/**
* Returns an array of all groups that a user is a member of.
*
* @param $userId
*
* @return object
*/
public function getGroupsForUser(int $userId)
{
return $this->select('auth_groups_users.*, auth_groups.name, auth_groups.description')
->join('auth_groups_users', 'auth_groups_users.group_id = auth_groups.id', 'left')
->where('user_id', $userId)
->as_array()
->find_all();
}
//--------------------------------------------------------------------
// Permissions
//--------------------------------------------------------------------
/**
* Add a single permission to a single group, by IDs.
*
* @param $permissionId
* @param $groupId
*
* @return mixed
*/
public function addPermissionToGroup(int $permissionId, int $groupId)
{
$data = [
'permission_id' => (int)$permissionId,
'group_id' => (int)$groupId
];
return $this->db->insert('auth_groups_permissions', $data);
}
//--------------------------------------------------------------------
/**
* Removes a single permission from a single group.
*
* @param $permissionId
* @param $groupId
*
* @return mixed
*/
public function removePermissionFromGroup(int $permissionId, int $groupId)
{
return $this->db->where([
'permission_id' => $permissionId,
'group_id' => $groupId
])->delete('auth_groups_permissions');
}
//--------------------------------------------------------------------
/**
* Removes a single permission from all groups.
*
* @param $permissionId
*
* @return mixed
*/
public function removePermissionFromAllGroups(int $permissionId)
{
return $this->db->where('permission_id', $permissionId)
->delete('auth_groups_permissions');
}
}