seeddms-code/out/out.UsrMgr.php

435 lines
14 KiB
PHP
Raw Normal View History

<?php
// MyDMS. Document Management System
// Copyright (C) 2002-2005 Markus Westphal
// Copyright (C) 2006-2008 Malcolm Cowe
2010-10-29 13:19:51 +00:00
// Copyright (C) 2010 Matteo Lucarelli
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
include("../inc/inc.Settings.php");
2010-10-29 13:19:51 +00:00
include("../inc/inc.DBInit.php");
include("../inc/inc.Language.php");
include("../inc/inc.ClassUI.php");
include("../inc/inc.Authentication.php");
2010-10-29 13:19:51 +00:00
if (!$user->isAdmin()) {
UI::exitError(getMLText("admin_tools"),getMLText("access_denied"));
2010-10-29 13:19:51 +00:00
}
$users = $dms->getAllUsers($settings->_sortUsersInList);
2010-10-29 13:19:51 +00:00
if (is_bool($users)) {
UI::exitError(getMLText("admin_tools"),getMLText("internal_error"));
2010-10-29 13:19:51 +00:00
}
$groups = $dms->getAllGroups();
2010-10-29 13:19:51 +00:00
if (is_bool($groups)) {
UI::exitError(getMLText("admin_tools"),getMLText("internal_error"));
2010-10-29 13:19:51 +00:00
}
UI::htmlStartPage(getMLText("admin_tools"));
UI::globalNavigation();
2010-10-29 13:19:51 +00:00
UI::pageNavigation(getMLText("admin_tools"), "admin_tools");
?>
<script type="text/javascript" src='../js/jquery.passwordstrength.js'></script>
<script language="JavaScript">
function checkForm(num)
{
msg = "";
eval("var formObj = document.form" + num + ";");
if (formObj.login.value == "") msg += "<?php printMLText("js_no_login");?>\n";
if ((num == '0') && (formObj.pwd.value == "")) msg += "<?php printMLText("js_no_pwd");?>\n";
if ((formObj.pwd.value != formObj.pwdconf.value)&&(formObj.pwd.value != "" )&&(formObj.pwd.value != "" )) msg += "<?php printMLText("js_pwd_not_conf");?>\n";
if (formObj.name.value == "") msg += "<?php printMLText("js_no_name");?>\n";
if (formObj.email.value == "") msg += "<?php printMLText("js_no_email");?>\n";
//if (formObj.comment.value == "") msg += "<?php printMLText("js_no_comment");?>\n";
if (msg != "")
{
alert(msg);
return false;
}
else
return true;
}
obj = -1;
function showUser(selectObj) {
if (obj != -1)
obj.style.display = "none";
id = selectObj.options[selectObj.selectedIndex].value;
if (id == -1)
return;
obj = document.getElementById("keywords" + id);
obj.style.display = "";
}
$(document).ready( function() {
$(".pwd").passStrength({
url: "../op/op.Ajax.php",
minscore: <?php echo (int) $settings->_passwordStrength; ?>
});
});
2010-10-29 13:19:51 +00:00
</script>
<?php
UI::contentHeading(getMLText("user_management"));
UI::contentContainerStart();
?>
2010-10-29 13:19:51 +00:00
<table><tr>
<td><?php echo getMLText("selection")?>:
<select onchange="showUser(this)" id="selector">
2010-10-29 13:19:51 +00:00
<option value="-1"><?php echo getMLText("choose_user")?>
<option value="0"><?php echo getMLText("add_user")?>
<?php
2010-10-29 13:19:51 +00:00
$selected=0;
$count=2;
foreach ($users as $currUser) {
if (isset($_GET["userid"]) && $currUser->getID()==$_GET["userid"]) $selected=$count;
print "<option value=\"".$currUser->getID()."\">" . htmlspecialchars($currUser->getLogin() . " - ". $currUser->getFullName());
$count++;
}
?>
2010-10-29 13:19:51 +00:00
</select>
&nbsp;&nbsp;
</td>
<td id="keywords0" style="display : none;">
<form action="../op/op.UsrMgr.php" method="post" enctype="multipart/form-data" name="form0" onsubmit="return checkForm('0');">
<?php echo createHiddenFieldWithKey('adduser'); ?>
<input type="Hidden" name="action" value="adduser">
<table>
<tr>
<td><?php printMLText("user_login");?>:</td>
<td><input name="login"></td>
</tr>
<tr>
<td><?php printMLText("password");?>:</td>
<td><input class="pwd" name="pwd" type="Password"> <div id="outerstrength" style="min-width: 100px; height: 14px; display: inline-block; border: 1px solid black; padding: 1px;"><div id="innerstrength" style="width: 0px; height: 14px; display: inline-block; border: 0px; padding: 0px; background-color: red;">&nbsp;</div> <div id="strength" style="display: inline-block;"></div></div></td>
2010-10-29 13:19:51 +00:00
</tr>
<tr>
<td><?php printMLText("confirm_pwd");?>:</td>
<td><input type="Password" name="pwdconf"></td>
</tr>
<?php
if($settings->_passwordExpiration > 0) {
?>
<tr>
<td><?php printMLText("password_expiration");?>:</td>
<td><select name="pwdexpiration"><option value="<?php echo date('Y-m-d H:i:s'); ?>"><?php printMLText("now");?></option><option value="<?php echo date('Y-m-d H:i:s', time()+$settings->_passwordExpiration*86400); ?>"><?php printMLText("according_settings");?></option></select></td>
</tr>
<?php
}
?>
<tr>
<td><?php printMLText("user_name");?>:</td>
<td><input name="name"></td>
</tr>
<tr>
<td><?php printMLText("email");?>:</td>
<td><input name="email"></td>
</tr>
<tr>
<td><?php printMLText("comment");?>:</td>
<td><textarea name="comment" rows="4" cols="50"></textarea></td>
</tr>
<tr>
<td><?php printMLText("role");?>:</td>
2012-02-07 10:31:31 +00:00
<td><select name="role"><option value="<?php echo LetoDMS_Core_User::role_user ?>"><?php printMLText("role_user"); ?></option><option value="<?php echo LetoDMS_Core_User::role_admin ?>"><?php printMLText("role_admin"); ?></option><option value="<?php echo LetoDMS_Core_User::role_guest ?>"><?php printMLText("role_guest"); ?></option></select></td>
</tr>
<tr>
<td><?php printMLText("is_hidden");?>:</td>
<td><input type="checkbox" name="ishidden" value="1"></td>
</tr>
<tr>
<td><?php printMLText("is_disabled");?>:</td>
<td><input type="checkbox" name="isdisabled" value="1"></td>
</tr>
2010-10-29 13:19:51 +00:00
<?php if ($settings->_enableUserImage){ ?>
<tr>
<td><?php printMLText("user_image");?>:</td>
<td><input type="File" name="userfile"></td>
2010-10-29 13:19:51 +00:00
</tr>
2010-10-29 13:19:51 +00:00
<?php } ?>
2010-10-29 13:19:51 +00:00
<tr>
<td><?php printMLText("reviewers");?>:</td>
<td>
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
<div class="cbSelectContainer">
<ul class="cbSelectList"><?php
2010-10-29 13:19:51 +00:00
foreach ($users as $usr) {
if ($usr->isGuest()) continue;
2012-10-05 19:56:37 +00:00
print "<li class=\"cbSelectItem\"><input id='revUsr".$usr->getID()."' type='checkbox' name='usrReviewers[]' value='". $usr->getID() ."'>".htmlspecialchars($usr->getLogin());
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
foreach ($groups as $grp) {
print "<li class=\"cbSelectItem\"><input id='revGrp".$grp->getID()."' type='checkbox' name='grpReviewers[]' value='". $grp->getID() ."'>".htmlspecialchars($grp->getName());
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
</td>
2010-10-29 13:19:51 +00:00
</tr>
2010-10-29 13:19:51 +00:00
<tr>
<td><?php printMLText("approvers");?>:</td>
2010-10-29 13:19:51 +00:00
<td>
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
foreach ($users as $usr) {
if ($usr->isGuest()) continue;
2012-10-05 19:56:37 +00:00
print "<li class=\"cbSelectItem\"><input id='appUsr".$usr->getID()."' type='checkbox' name='usrApprovers[]' value='". $usr->getID() ."'>".htmlspecialchars($usr->getLogin());
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
foreach ($groups as $grp) {
print "<li class=\"cbSelectItem\"><input id='revGrp".$grp->getID()."' type='checkbox' name='grpApprovers[]' value='". $grp->getID() ."'>".htmlspecialchars($grp->getName());
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
</td>
</tr>
<tr>
<td colspan="2"><input type="Submit" value="<?php printMLText("add_user");?>"></td>
</tr>
</table>
2010-10-29 13:19:51 +00:00
</form>
</td>
<?php
2010-10-29 13:19:51 +00:00
foreach ($users as $currUser) {
2010-10-29 13:19:51 +00:00
print "<td id=\"keywords".$currUser->getID()."\" style=\"display : none;\">";
2012-10-05 19:56:37 +00:00
UI::contentSubHeading(getMLText("user")." : ".htmlspecialchars($currUser->getLogin()));
2010-10-29 13:19:51 +00:00
?>
<a class="standardText" href="../out/out.RemoveUser.php?userid=<?php print $currUser->getID();?>"><img src="images/del.gif" width="15" height="15" border="0" align="absmiddle" alt=""> <?php printMLText("rm_user");?></a>
2010-10-29 13:19:51 +00:00
<?php UI::contentSubHeading(getMLText("edit_user"));?>
<form action="../op/op.UsrMgr.php" method="post" enctype="multipart/form-data" name="form<?php print $currUser->getID();?>" onsubmit="return checkForm('<?php print $currUser->getID();?>');">
<?php echo createHiddenFieldWithKey('edituser'); ?>
<input type="Hidden" name="userid" value="<?php print $currUser->getID();?>">
<input type="Hidden" name="action" value="edituser">
<table>
<tr>
<td><?php printMLText("user_login");?>:</td>
2012-10-05 19:56:37 +00:00
<td><input name="login" value="<?php print htmlspecialchars($currUser->getLogin());?>"></td>
</tr>
<tr>
<td><?php printMLText("password");?>:</td>
<td><input type="Password" name="pwd"></td>
</tr>
<tr>
<td><?php printMLText("confirm_pwd");?>:</td>
<td><input type="Password" name="pwdconf"></td>
</tr>
<?php
if($settings->_passwordExpiration > 0) {
?>
<tr>
<td><?php printMLText("password_expiration");?>:</td>
<td><select name="pwdexpiration"><option value="<?php echo date('Y-m-d H:i:s'); ?>"><?php printMLText("now");?></option><option value="<?php echo date('Y-m-d H:i:s', time()+$settings->_passwordExpiration*86400); ?>"><?php printMLText("according_settings");?></option></select> <?php echo $currUser->getPwdExpiration(); ?></td>
</tr>
<?php
}
?>
<tr>
<td><?php printMLText("user_name");?>:</td>
<td><input name="name" value="<?php print htmlspecialchars($currUser->getFullName());?>"></td>
2010-10-29 13:19:51 +00:00
</tr>
<tr>
<td><?php printMLText("email");?>:</td>
2011-12-06 12:29:09 +00:00
<td><input name="email" value="<?php print htmlspecialchars($currUser->getEmail()) ;?>"></td>
</tr>
<tr>
<td><?php printMLText("comment");?>:</td>
<td><textarea name="comment" rows="4" cols="50"><?php print htmlspecialchars($currUser->getComment());?></textarea></td>
</tr>
<tr>
<td><?php printMLText("role");?>:</td>
2012-02-07 10:31:31 +00:00
<td><select name="role"><option value="<?php echo LetoDMS_Core_User::role_user ?>"><?php printMLText("role_user"); ?></option><option value="<?php echo LetoDMS_Core_User::role_admin ?>" <?php if($currUser->getRole() == LetoDMS_Core_User::role_admin) echo "selected"; ?>><?php printMLText("role_admin"); ?></option><option value="<?php echo LetoDMS_Core_User::role_guest ?>" <?php if($currUser->getRole() == LetoDMS_Core_User::role_guest) echo "selected"; ?>><?php printMLText("role_guest"); ?></option></select></td>
</tr>
<tr>
<td><?php printMLText("is_hidden");?>:</td>
<td><input type="checkbox" name="ishidden" value="1"<?php print ($currUser->isHidden() ? " checked='checked'" : "");?>></td>
</tr>
<tr>
<td><?php printMLText("is_disabled");?>:</td>
<td><input type="checkbox" name="isdisabled" value="1"<?php print ($currUser->isDisabled() ? " checked='checked'" : "");?>></td>
</tr>
2010-10-29 13:19:51 +00:00
<?php if ($settings->_enableUserImage){ ?>
<tr>
<td><?php printMLText("user_image");?>:</td>
<td>
<?php
if ($currUser->hasImage())
print "<img src=\"".$settings->_httpRoot . "out/out.UserImage.php?userid=".$currUser->getId()."\">";
else
printMLText("no_user_image");
?>
</td>
2010-10-29 13:19:51 +00:00
</tr>
<tr>
<td><?php printMLText("new_user_image");?>:</td>
<td><input type="file" name="userfile" accept="image/jpeg"></td>
</tr>
2010-10-29 13:19:51 +00:00
<?php } ?>
2010-10-29 13:19:51 +00:00
<tr>
<td><?php printMLText("reviewers");?>:</td>
2010-10-29 13:19:51 +00:00
<td>
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
$res=$currUser->getMandatoryReviewers();
2010-10-29 13:19:51 +00:00
foreach ($users as $usr) {
if ($usr->isGuest() || ($usr->getID() == $currUser->getID()))
2010-10-29 13:19:51 +00:00
continue;
2010-10-29 13:19:51 +00:00
$checked=false;
foreach ($res as $r) if ($r['reviewerUserID']==$usr->getID()) $checked=true;
2012-10-05 19:56:37 +00:00
print "<li class=\"cbSelectItem\"><input id='revUsr".$usr->getID()."' type='checkbox' ".($checked?"checked='checked' ":"")."name='usrReviewers[]' value='". $usr->getID() ."'>".htmlspecialchars($usr->getLogin())."</li>\n";
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
foreach ($groups as $grp) {
2010-10-29 13:19:51 +00:00
$checked=false;
foreach ($res as $r) if ($r['reviewerGroupID']==$grp->getID()) $checked=true;
print "<li class=\"cbSelectItem\"><input id='revGrp".$grp->getID()."' type='checkbox' ".($checked?"checked='checked' ":"")."name='grpReviewers[]' value='". $grp->getID() ."'>".htmlspecialchars($grp->getName())."</li>\n";
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
</td>
2010-10-29 13:19:51 +00:00
</tr>
2010-10-29 13:19:51 +00:00
<tr>
<td><?php printMLText("approvers");?>:</td>
2010-10-29 13:19:51 +00:00
<td>
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
$res=$currUser->getMandatoryApprovers();
2010-10-29 13:19:51 +00:00
foreach ($users as $usr) {
if ($usr->isGuest() || ($usr->getID() == $currUser->getID()))
2010-10-29 13:19:51 +00:00
continue;
2010-10-29 13:19:51 +00:00
$checked=false;
foreach ($res as $r) if ($r['approverUserID']==$usr->getID()) $checked=true;
2012-10-05 19:56:37 +00:00
print "<li class=\"cbSelectItem\"><input id='appUsr".$usr->getID()."' type='checkbox' ".($checked?"checked='checked' ":"")."name='usrApprovers[]' value='". $usr->getID() ."'>".htmlspecialchars($usr->getLogin())."</li>\n";
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
<div class="cbSelectContainer">
2010-10-29 13:19:51 +00:00
<ul class="cbSelectList">
<?php
2010-10-29 13:19:51 +00:00
foreach ($groups as $grp) {
2010-10-29 13:19:51 +00:00
$checked=false;
foreach ($res as $r) if ($r['approverGroupID']==$grp->getID()) $checked=true;
print "<li class=\"cbSelectItem\"><input id='revGrp".$grp->getID()."' type='checkbox' ".($checked?"checked='checked' ":"")."name='grpApprovers[]' value='". $grp->getID() ."'>".htmlspecialchars($grp->getName())."</li>\n";
}
?>
</ul>
2010-10-29 13:19:51 +00:00
</div>
</td>
2010-10-29 13:19:51 +00:00
</tr>
<tr>
<td colspan="2"><input type="Submit" value="<?php printMLText("save");?>"></td>
</tr>
</table>
</form>
</td>
<?php } ?>
2010-10-29 13:19:51 +00:00
</tr></table>
<script language="JavaScript">
2010-10-29 13:19:51 +00:00
sel = document.getElementById("selector");
sel.selectedIndex=<?php print $selected ?>;
showUser(sel);
2010-10-29 13:19:51 +00:00
</script>
<?php
2010-10-29 13:19:51 +00:00
UI::contentContainerEnd();
UI::htmlEndPage();
?>