|
74 | 74 | WHERE ug.id = :id AND (NOT ug.deleted OR ug.deleted IS NULL)', ['id' => $_POST['cms_usergroups_id'][0]]); |
75 | 75 | $is_admin = $_SESSION['user']['is_admin']; |
76 | 76 | $organisation_allowed = ($_SESSION['organisation']['id'] == $posteduser['organisation_id']); |
77 | | - // allow admins to create another admin account |
| 77 | + // allow HoO to create another HoO account |
78 | 78 | // related to this trello card https://trello.com/c/YAF3Az4P |
79 | 79 | $userlevel_allowed = ($_SESSION['usergroup']['userlevel'] > $posteduser['userlevel']) || ($_SESSION['usergroup']['userlevel'] == $posteduser['userlevel'] && '100' == $_SESSION['usergroup']['userlevel']); |
80 | 80 |
|
| 81 | + // Prevent HoO user from downgrading their usergroup if they're the only HoO |
| 82 | + if (!$is_admin |
| 83 | + && $_POST['id'] == $_SESSION['user']['id'] |
| 84 | + && 100 == $_SESSION['usergroup']['userlevel']) { |
| 85 | + // Count how many HoO users exist in this organization |
| 86 | + $hoo_count = db_value( |
| 87 | + ' |
| 88 | + SELECT COUNT(DISTINCT u.id) |
| 89 | + FROM cms_users AS u |
| 90 | + LEFT JOIN cms_usergroups AS ug ON ug.id = u.cms_usergroups_id |
| 91 | + LEFT JOIN cms_usergroups_levels AS ugl ON ugl.id = ug.userlevel |
| 92 | + WHERE ug.organisation_id = :org_id |
| 93 | + AND ugl.level = 100 |
| 94 | + AND (NOT u.deleted OR u.deleted IS NULL) |
| 95 | + AND (NOT ug.deleted OR ug.deleted IS NULL) |
| 96 | + AND NOT (u.valid_lastday < CURDATE() AND UNIX_TIMESTAMP(u.valid_lastday) != 0)', |
| 97 | + ['org_id' => $_SESSION['organisation']['id']] |
| 98 | + ); |
| 99 | + |
| 100 | + // If this is the last HoO, prevent the change |
| 101 | + if ($hoo_count <= 1) { |
| 102 | + if ($posteduser['userlevel'] < $_SESSION['usergroup']['userlevel']) { |
| 103 | + redirect('?action=cms_users_edit&id='.$_POST['id'].'&origin='.$_POST['_origin'].'&warning=1&message=You cannot downgrade yourself. Your organisation must have at least one Head of Operations user.'); |
| 104 | + trigger_error('You cannot downgrade yourself. Your organisation must have at least one Head of Operations user.', E_USER_NOTICE); |
| 105 | + } elseif (('' !== $_POST['valid_firstday']) || ('' !== $_POST['valid_lastday'])) { |
| 106 | + redirect('?action=cms_users_edit&id='.$_POST['id'].'&origin='.$_POST['_origin'].'&warning=1&message=You cannot edit yourself. Your organisation must have at least one Head of Operations user.'); |
| 107 | + trigger_error('You cannot edit yourself. Your organisation must have at least one Head of Operations user.', E_USER_NOTICE); |
| 108 | + } |
| 109 | + } |
| 110 | + } |
| 111 | + |
81 | 112 | if ($is_admin || ($organisation_allowed && $userlevel_allowed)) { |
82 | 113 | $keys = ['naam', 'email', 'cms_usergroups_id', 'valid_firstday', 'valid_lastday']; |
83 | 114 | $userId = db_transaction(function () use ($table, $keys, $userId) { |
|
114 | 145 | FROM cms_usergroups AS ug |
115 | 146 | LEFT OUTER JOIN cms_usergroups_levels AS ugl ON ugl.id=ug.userlevel |
116 | 147 | WHERE ug.id = :id AND (NOT ug.deleted OR ug.deleted IS NULL)', ['id' => $data['cms_usergroups_id']]); |
117 | | - if (!$_SESSION['user']['is_admin'] && ($data && ($data['is_admin'] || ($_SESSION['organisation']['id'] != $requesteduser['organisation_id']) || ($_SESSION['usergroup']['userlevel'] <= $requesteduser['userlevel'])))) { |
| 148 | + if (!$_SESSION['user']['is_admin'] |
| 149 | + && $data |
| 150 | + && $data['id'] != $_SESSION['user']['id'] |
| 151 | + && ($data['is_admin'] |
| 152 | + || $_SESSION['organisation']['id'] != $requesteduser['organisation_id'] |
| 153 | + || $_SESSION['usergroup']['userlevel'] <= $requesteduser['userlevel'])) { |
118 | 154 | throw new Exception('You do not have access to this user!', 403); |
119 | 155 | } |
120 | 156 |
|
|
130 | 166 | // display admin role in the usergroup - only for user with admin roles |
131 | 167 | // related to this trello card https://trello.com/c/YAF3Az4P |
132 | 168 | $usergroups = db_array(' |
133 | | - SELECT ug.id AS value, ug.label |
134 | | - FROM cms_usergroups AS ug |
135 | | - LEFT OUTER JOIN cms_usergroups_levels AS ugl ON (ugl.id=ug.userlevel) |
136 | | - WHERE ug.organisation_id = :organisation_id AND (ugl.level < :userlevel OR :is_admin OR (ugl.level <= :userlevel AND 100 = :userlevel)) AND (NOT ug.deleted OR ug.deleted IS NULL) |
137 | | - ORDER BY ug.label', ['organisation_id' => $_SESSION['organisation']['id'], 'userlevel' => $_SESSION['usergroup']['userlevel'], 'is_admin' => $_SESSION['user']['is_admin']]); |
| 169 | + SELECT ug.id AS value, ug.label |
| 170 | + FROM cms_usergroups AS ug |
| 171 | + LEFT OUTER JOIN cms_usergroups_levels AS ugl ON (ugl.id=ug.userlevel) |
| 172 | + WHERE ug.organisation_id = :organisation_id |
| 173 | + AND (:is_admin OR (ugl.level < :userlevel OR (ugl.level <= :userlevel AND 100 = :userlevel))) |
| 174 | + AND (:is_admin OR ug.label != "Boxtribute God") |
| 175 | + AND (NOT ug.deleted OR ug.deleted IS NULL) |
| 176 | + ORDER BY ug.label', ['organisation_id' => $_SESSION['organisation']['id'], 'userlevel' => $_SESSION['usergroup']['userlevel'], 'is_admin' => $_SESSION['user']['is_admin']]); |
138 | 177 | addfield('select', 'Select user group', 'cms_usergroups_id', ['required' => true, 'options' => $usergroups, 'testid' => 'user_group']); |
139 | 178 |
|
140 | 179 | addfield('line'); |
|
0 commit comments