2011-06-02 22:40:08 +02:00
|
|
|
<?php
|
2016-09-29 10:53:17 +02:00
|
|
|
|
2017-01-03 03:22:48 +01:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-01-02 03:57:23 +01:00
|
|
|
function admin_groups_title()
|
|
|
|
{
|
2017-01-03 14:12:17 +01:00
|
|
|
return _('Grouprights');
|
2013-11-25 21:04:58 +01:00
|
|
|
}
|
|
|
|
|
2017-01-03 03:22:48 +01:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-01-02 03:57:23 +01:00
|
|
|
function admin_groups()
|
|
|
|
{
|
2017-01-03 14:12:17 +01:00
|
|
|
$html = '';
|
|
|
|
$groups = sql_select('SELECT * FROM `Groups` ORDER BY `Name`');
|
|
|
|
if (!isset($_REQUEST['action'])) {
|
2017-01-02 03:57:23 +01:00
|
|
|
$groups_table = [];
|
|
|
|
foreach ($groups as $group) {
|
2017-01-02 15:43:36 +01:00
|
|
|
$privileges = sql_select("
|
|
|
|
SELECT *
|
|
|
|
FROM `GroupPrivileges`
|
|
|
|
JOIN `Privileges` ON (`GroupPrivileges`.`privilege_id` = `Privileges`.`id`)
|
|
|
|
WHERE `group_id`='" . sql_escape($group['UID']) . "'
|
|
|
|
");
|
2017-01-02 03:57:23 +01:00
|
|
|
$privileges_html = [];
|
2017-01-02 15:43:36 +01:00
|
|
|
|
2017-01-02 03:57:23 +01:00
|
|
|
foreach ($privileges as $priv) {
|
|
|
|
$privileges_html[] = $priv['name'];
|
|
|
|
}
|
2017-01-02 15:43:36 +01:00
|
|
|
|
2017-01-02 03:57:23 +01:00
|
|
|
$groups_table[] = [
|
2017-01-02 15:43:36 +01:00
|
|
|
'name' => $group['Name'],
|
|
|
|
'privileges' => join(', ', $privileges_html),
|
|
|
|
'actions' => button(
|
|
|
|
page_link_to('admin_groups') . '&action=edit&id=' . $group['UID'],
|
2017-01-03 14:12:17 +01:00
|
|
|
_('edit'),
|
2017-01-02 15:43:36 +01:00
|
|
|
'btn-xs'
|
|
|
|
)
|
|
|
|
];
|
2017-01-02 03:57:23 +01:00
|
|
|
}
|
2017-01-02 15:43:36 +01:00
|
|
|
|
2017-01-02 03:57:23 +01:00
|
|
|
return page_with_title(admin_groups_title(), [
|
2017-01-02 15:43:36 +01:00
|
|
|
table([
|
2017-01-03 14:12:17 +01:00
|
|
|
'name' => _('Name'),
|
|
|
|
'privileges' => _('Privileges'),
|
2017-01-02 15:43:36 +01:00
|
|
|
'actions' => ''
|
|
|
|
], $groups_table)
|
|
|
|
]);
|
2017-01-02 03:57:23 +01:00
|
|
|
} else {
|
2017-01-03 14:12:17 +01:00
|
|
|
switch ($_REQUEST['action']) {
|
2017-01-02 15:43:36 +01:00
|
|
|
case 'edit':
|
2017-01-03 14:12:17 +01:00
|
|
|
if (isset($_REQUEST['id']) && preg_match('/^-[0-9]{1,11}$/', $_REQUEST['id'])) {
|
2017-01-02 15:43:36 +01:00
|
|
|
$group_id = $_REQUEST['id'];
|
|
|
|
} else {
|
2017-01-03 14:12:17 +01:00
|
|
|
return error('Incomplete call, missing Groups ID.', true);
|
2017-01-02 15:43:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$group = sql_select("SELECT * FROM `Groups` WHERE `UID`='" . sql_escape($group_id) . "' LIMIT 1");
|
|
|
|
if (count($group) > 0) {
|
|
|
|
$privileges = sql_select("
|
|
|
|
SELECT `Privileges`.*, `GroupPrivileges`.`group_id`
|
|
|
|
FROM `Privileges`
|
|
|
|
LEFT OUTER JOIN `GroupPrivileges`
|
|
|
|
ON (
|
|
|
|
`Privileges`.`id` = `GroupPrivileges`.`privilege_id`
|
|
|
|
AND `GroupPrivileges`.`group_id`='" . sql_escape($group_id) . "'
|
|
|
|
)
|
|
|
|
ORDER BY `Privileges`.`name`
|
|
|
|
");
|
2017-01-03 14:12:17 +01:00
|
|
|
$privileges_html = '';
|
2017-01-02 15:43:36 +01:00
|
|
|
$privileges_form = [];
|
|
|
|
foreach ($privileges as $priv) {
|
|
|
|
$privileges_form[] = form_checkbox(
|
|
|
|
'privileges[]',
|
|
|
|
$priv['desc'] . ' (' . $priv['name'] . ')',
|
2017-01-03 14:12:17 +01:00
|
|
|
$priv['group_id'] != '',
|
2017-01-02 15:43:36 +01:00
|
|
|
$priv['id']
|
|
|
|
);
|
|
|
|
$privileges_html .= sprintf(
|
|
|
|
'<tr><td><input type="checkbox" name="privileges[]" value="%s" %s /></td> <td>%s</td> <td>%s</td></tr>',
|
|
|
|
$priv['id'],
|
2017-01-03 14:12:17 +01:00
|
|
|
($priv['group_id'] != '' ? 'checked="checked"' : ''),
|
2017-01-02 15:43:36 +01:00
|
|
|
$priv['name'],
|
|
|
|
$priv['desc']
|
|
|
|
);
|
2017-01-02 03:57:23 +01:00
|
|
|
}
|
2017-01-02 15:43:36 +01:00
|
|
|
|
2017-01-03 14:12:17 +01:00
|
|
|
$privileges_form[] = form_submit('submit', _('Save'));
|
|
|
|
$html .= page_with_title(_('Edit group'), [
|
2017-01-02 15:43:36 +01:00
|
|
|
form($privileges_form, page_link_to('admin_groups') . '&action=save&id=' . $group_id)
|
|
|
|
]);
|
|
|
|
} else {
|
2017-01-03 14:12:17 +01:00
|
|
|
return error('No Group found.', true);
|
2017-01-02 03:57:23 +01:00
|
|
|
}
|
2017-01-02 15:43:36 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'save':
|
2017-01-03 14:12:17 +01:00
|
|
|
if (isset($_REQUEST['id']) && preg_match('/^-[0-9]{1,11}$/', $_REQUEST['id'])) {
|
2017-01-02 15:43:36 +01:00
|
|
|
$group_id = $_REQUEST['id'];
|
|
|
|
} else {
|
2017-01-03 14:12:17 +01:00
|
|
|
return error('Incomplete call, missing Groups ID.', true);
|
2017-01-02 15:43:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$group = sql_select("SELECT * FROM `Groups` WHERE `UID`='" . sql_escape($group_id) . "' LIMIT 1");
|
|
|
|
if (!is_array($_REQUEST['privileges'])) {
|
|
|
|
$_REQUEST['privileges'] = [];
|
|
|
|
}
|
|
|
|
if (count($group) > 0) {
|
|
|
|
list($group) = $group;
|
|
|
|
sql_query("DELETE FROM `GroupPrivileges` WHERE `group_id`='" . sql_escape($group_id) . "'");
|
|
|
|
$privilege_names = [];
|
|
|
|
foreach ($_REQUEST['privileges'] as $priv) {
|
|
|
|
if (preg_match("/^[0-9]{1,}$/", $priv)) {
|
|
|
|
$group_privileges_source = sql_select("SELECT * FROM `Privileges` WHERE `id`='" . sql_escape($priv) . "' LIMIT 1");
|
|
|
|
if (count($group_privileges_source) > 0) {
|
|
|
|
sql_query("INSERT INTO `GroupPrivileges` SET `group_id`='" . sql_escape($group_id) . "', `privilege_id`='" . sql_escape($priv) . "'");
|
|
|
|
$privilege_names[] = $group_privileges_source[0]['name'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
engelsystem_log(
|
2017-01-03 14:12:17 +01:00
|
|
|
'Group privileges of group ' . $group['Name']
|
|
|
|
. ' edited: ' . join(', ', $privilege_names)
|
2017-01-02 15:43:36 +01:00
|
|
|
);
|
2017-01-03 14:12:17 +01:00
|
|
|
redirect(page_link_to('admin_groups'));
|
2017-01-02 15:43:36 +01:00
|
|
|
} else {
|
2017-01-03 14:12:17 +01:00
|
|
|
return error('No Group found.', true);
|
2017-01-02 15:43:36 +01:00
|
|
|
}
|
|
|
|
break;
|
2016-09-29 10:53:17 +02:00
|
|
|
}
|
2017-01-02 03:57:23 +01:00
|
|
|
}
|
|
|
|
return $html;
|
2011-06-02 22:40:08 +02:00
|
|
|
}
|