You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

210 lines
7.5 KiB

<?php
/**
* @package tikiwiki
*/
// (c) Copyright by authors of the Tiki Wiki CMS Groupware Project
//
// All Rights Reserved. See copyright.txt for details and a complete list of authors.
// Licensed under the GNU LESSER GENERAL PUBLIC LICENSE. See license.txt for details.
// $Id$
// This script is used to assign groups to a particular user
// ASSIGN USER TO GROUPS
require_once('tiki-setup.php');
$auto_query_args = ['sort_mode', 'offset', 'find', 'assign_user', 'group', 'maxRecords'];
$access->check_permission_either(['tiki_p_admin_users', 'tiki_p_subscribe_groups']);
if (! isset($_REQUEST["assign_user"]) || ($tiki_p_admin != 'y' && $tiki_p_admin_users != 'y')) {
$_REQUEST['assign_user'] = $user;
$userChoice = 'y';
$smarty->assign_by_ref('userChoice', $userChoice);
} else {
if (! $userlib->user_exists($_REQUEST['assign_user'])) {
$smarty->assign('msg', tra("User doesn't exist"));
$smarty->display("error.tpl");
die;
}
$userChoice = '';
$smarty->assign_by_ref('assign_user', $_REQUEST['assign_user']);
}
$assign_user = $_REQUEST["assign_user"];
if (isset($_REQUEST["action"])) {
$canProcess = true;
if ($prefs['users_admin_actions_require_validation'] == 'y') {
if ($userlib->isAutologin()) {
Feedback::error($userlib->getAutologinAdminActionError());
}
if (empty($_POST['confirmpassword'])) {
Feedback::error(tr('Password confirmation is required perform this group operation'));
$canProcess = false;
} else {
$passwordCheck = $userlib->validate_user($user, $_POST['confirmpassword']);
if (empty($passwordCheck[0])) {
Feedback::error(tr('Invalid password confirmation. Group operation was not performed.'));
$canProcess = false;
}
}
}
if (! isset($_REQUEST["group"])) {
Feedback::error(tr('A group must be indicated'));
$canProcess = false;
}
if ($canProcess) {
if ($userChoice == 'y') {
$gps = $userlib->get_groups(0, -1, 'groupName_asc', '', '', '', '', $userChoice);
$groups = [];
foreach ($gps['data'] as $g) {
$groups[$g['groupName']] = $g;
}
} elseif ($tiki_p_admin != 'y') {
$groups = $userlib->get_user_groups_inclusion($user);
}
if ($_REQUEST["action"] == 'assign' && $access->checkCsrf()) {
if (! $userlib->group_exists($_REQUEST["group"])) {
Feedback::error(tr('Invalid group'));
} elseif (
$tiki_p_admin_users == 'y'
|| ($tiki_p_admin_users == 'y' && array_key_exists($_REQUEST["group"], $groups))
) {
$result = $userlib->assign_user_to_group($_REQUEST["assign_user"], $_REQUEST["group"]);
if ($result && $result->numRows()) {
Feedback::success(tr(
'Assigned user %0 to group %1',
htmlspecialchars($_REQUEST["assign_user"]),
htmlspecialchars($_REQUEST["group"])
));
$logslib->add_log('perms', sprintf("Assigned %s in group %s", $_REQUEST["assign_user"], $_REQUEST["group"]));
} else {
Feedback::error(tr(
'User %0 not assigned to group %1',
htmlspecialchars($_REQUEST["assign_user"]),
htmlspecialchars($_REQUEST["group"])
));
}
}
} elseif (
$_REQUEST["action"] == 'removegroup' && ($tiki_p_admin == 'y' && $access->checkCsrf()
|| ($tiki_p_admin_users == 'y' && array_key_exists($_REQUEST["group"], $groups) && $access->checkCsrf()))
) {
$result = $userlib->remove_user_from_group($_REQUEST["assign_user"], $_REQUEST["group"]);
if ($result && $result->numRows()) {
Feedback::success(tr(
'Removed user %0 from group %1',
htmlspecialchars($_REQUEST["assign_user"]),
htmlspecialchars($_REQUEST["group"])
));
$logslib->add_log('perms', sprintf("Removed %s from group %s", $_REQUEST["assign_user"], $_REQUEST["group"]));
} else {
Feedback::error(tr(
'User %0 not removed from group %1',
htmlspecialchars($_REQUEST["assign_user"]),
htmlspecialchars($_REQUEST["group"])
));
}
}
}
}
if (isset($_REQUEST['set_default']) && $access->checkCsrf()) {
$result = $userlib->set_default_group($_REQUEST['login'], $_REQUEST['defaultgroup']);
if ($result && $result->numRows()) {
Feedback::success(tr('Default group set'));
} else {
Feedback::error(tr('Default group not set'));
}
}
$user_info = $userlib->get_user_info($assign_user, true);
$smarty->assign_by_ref('user_info', $user_info);
if (! empty($_REQUEST['save']) && $access->checkCsrf()) {
foreach ($_REQUEST as $r => $v) {
if (strpos($r, 'new_') === 0) {
$g = substr($r, 4);
if ($_REQUEST['new_' . $g] != $_REQUEST['old_' . $g]) {
$t = strtotime($_REQUEST['new_' . $g]);
$t = $tikilib->make_time(date('H', $t), date('i', $t), 0, date('m', $t), date('d', $t), date('Y', $t));
if ($t !== false) {
$g_info = $userlib->get_groupId_info($g);
$result = $userlib->extend_membership($assign_user, $g_info['groupName'], 0, $t);
if ($result && $result->numRows()) {
Feedback::success(tr('Default group set'));
} else {
Feedback::error(tr('Default group not set'));
}
}
}
}
}
}
$dates = $userlib->get_user_groups_date($user_info['userId']);
$smarty->assign_by_ref('dates', $dates);
if (! isset($_REQUEST["sort_mode"])) {
$sort_mode = 'groupName_asc';
} else {
$sort_mode = $_REQUEST["sort_mode"];
}
$smarty->assign_by_ref('sort_mode', $sort_mode);
// If offset is set use it if not then use offset =0
// use the maxRecords php variable to set the limit
// if sortMode is not set then use lastModif_desc
if (! isset($_REQUEST["offset"])) {
$offset = 0;
} else {
$offset = $_REQUEST["offset"];
}
$smarty->assign_by_ref('offset', $offset);
if (isset($_REQUEST["find"])) {
$find = $_REQUEST["find"];
} else {
$find = '';
}
$smarty->assign('find', $find);
if (isset($_REQUEST['maxRecords'])) {
$maxRecords = $_REQUEST['maxRecords'];
}
if ($tiki_p_admin != 'y' && $userChoice != 'y') {
$ingroups = $userlib->get_user_groups_inclusion($user);
foreach ($user_info['groups'] as $grp => $i) {
if (! isset($ingroups[$grp])) {
unset($user_info['groups'][$grp]);
}
}
} else {
$ingroups = '';
}
$users = $userlib->get_groups($offset, $maxRecords, $sort_mode, $find, '', 'y', $ingroups, $userChoice);
foreach ($users['data'] as $key => $gr) {
if (isset($user_info['groups'][$gr['groupName']])) {
$users['data'][$key]['what'] = $user_info['groups'][$gr['groupName']];
}
}
$smarty->assign_by_ref('cant_pages', $users["cant"]);
// Get users (list of users)
$smarty->assign_by_ref('users', $users["data"]);
// disallow robots to index page:
$smarty->assign('metatag_robots', 'NOINDEX, NOFOLLOW');
// Display the template
$smarty->assign('mid', 'tiki-assignuser.tpl');
$smarty->display("tiki.tpl");