isAdmin()) { UI::exitError(getMLText("admin_tools"),getMLText("access_denied")); } if (isset($_POST["action"])) $action=$_POST["action"]; else $action=NULL; // add new user --------------------------------------------------------- if ($action == "adduser") { /* Check if the form data comes for a trusted request */ if(!checkFormKey('adduser')) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_request_token")); } $login = $_POST["login"]; $pwd = $_POST["pwd"]; if(!isset($_POST["pwdexpiration"])) $pwdexpiration = ''; else $pwdexpiration = $_POST["pwdexpiration"]; if(!isset($_POST["quota"])) $quota = 0; else $quota = (int) $_POST["quota"]; $name = $_POST["name"]; $email = $_POST["email"]; $comment = $_POST["comment"]; $role = preg_replace('/[^0-2]+/', '', $_POST["role"]); $isHidden = (isset($_POST["ishidden"]) && $_POST["ishidden"]==1 ? 1 : 0); $isDisabled = (isset($_POST["isdisabled"]) && $_POST["isdisabled"]==1 ? 1 : 0); $homefolder = (isset($_POST["homefolder"]) ? $_POST["homefolder"] : 0); $quota = (isset($_POST["quota"]) ? (int) $_POST["quota"] : 0); if (is_object($dms->getUserByLogin($login))) { UI::exitError(getMLText("admin_tools"),getMLText("user_exists")); } $newUser = $dms->addUser($login, md5($pwd), $name, $email, $settings->_language, $settings->_theme, $comment, $role, $isHidden, $isDisabled, $pwdexpiration, $homefolder); if ($newUser) { /* Set Quota */ $newUser->setQuota($quota); /* Set user image if uploaded */ if (isset($_FILES["userfile"]) && is_uploaded_file($_FILES["userfile"]["tmp_name"]) && $_FILES["userfile"]["size"] > 0 && $_FILES['userfile']['error']==0) { $userfiletype = $_FILES["userfile"]["type"]; $userfilename = $_FILES["userfile"]["name"]; $fileType = ".".pathinfo($userfilename, PATHINFO_EXTENSION); if ($fileType != ".jpg" && $filetype != ".jpeg") { UI::exitError(getMLText("admin_tools"),getMLText("only_jpg_user_images")); } else { resizeImage($_FILES["userfile"]["tmp_name"]); $newUser->setImage($_FILES["userfile"]["tmp_name"], $userfiletype); } } /* Set groups if set */ if(isset($_POST["groups"]) && $_POST["groups"]) { foreach($_POST["groups"] as $groupid) { $group = $dms->getGroup($groupid); $group->addUser($newUser); } } } else UI::exitError(getMLText("admin_tools"),getMLText("access_denied")); if(isset($_POST["workflows"]) && $_POST["workflows"]) { $workflows = array(); foreach($_POST["workflows"] as $workflowid) if($tmp = $dms->getWorkflow($workflowid)) $workflows[] = $tmp; if($workflows) $newUser->setMandatoryWorkflows($workflows); } if (isset($_POST["usrReviewers"])){ foreach ($_POST["usrReviewers"] as $revID) $newUser->setMandatoryReviewer($revID,false); } if (isset($_POST["grpReviewers"])){ foreach ($_POST["grpReviewers"] as $revID) $newUser->setMandatoryReviewer($revID,true); } if (isset($_POST["usrApprovers"])){ foreach ($_POST["usrApprovers"] as $appID) $newUser->setMandatoryApprover($appID,false); } if (isset($_POST["grpApprovers"])){ foreach ($_POST["grpApprovers"] as $appID) $newUser->setMandatoryApprover($appID,true); } $userid=$newUser->getID(); $session->setSplashMsg(array('type'=>'success', 'msg'=>getMLText('splash_add_user'))); add_log_line(".php&action=adduser&login=".$login); } // delete user ------------------------------------------------------------ else if ($action == "removeuser") { /* Check if the form data comes for a trusted request */ if(!checkFormKey('removeuser')) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_request_token")); } if (isset($_POST["userid"])) { $userid = $_POST["userid"]; } if (!isset($userid) || !is_numeric($userid) || intval($userid)<1) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_user_id")); } if(in_array($userid, explode(',', $settings->_undelUserIds))) { UI::exitError(getMLText("admin_tools"),getMLText("cannot_delete_user")); } /* This used to be a check if an admin is deleted. Now it checks if one * wants to delete herself. */ if ($userid==$user->getID()) { UI::exitError(getMLText("admin_tools"),getMLText("cannot_delete_yourself")); } $userToRemove = $dms->getUser($userid); if (!is_object($userToRemove)) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_user_id")); } $userToAssign = $dms->getUser($_POST["assignTo"]); if (!$userToRemove->remove($user, $userToAssign)) { UI::exitError(getMLText("admin_tools"),getMLText("error_occured")); } add_log_line(".php&action=removeuser&userid=".$userid); $session->setSplashMsg(array('type'=>'success', 'msg'=>getMLText('splash_rm_user'))); $userid=-1; } // modify user ------------------------------------------------------------ else if ($action == "edituser") { /* Check if the form data comes for a trusted request */ if(!checkFormKey('edituser')) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_request_token")); } if (!isset($_POST["userid"]) || !is_numeric($_POST["userid"]) || intval($_POST["userid"])<1) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_user_id")); } $userid=$_POST["userid"]; $editedUser = $dms->getUser($userid); if (!is_object($editedUser)) { UI::exitError(getMLText("admin_tools"),getMLText("invalid_user_id")); } $login = $_POST["login"]; $pwd = $_POST["pwd"]; if(isset($_POST["pwdexpiration"])) $pwdexpiration = $_POST["pwdexpiration"]; else $pwdexpiration = ''; if(!isset($_POST["quota"])) $quota = 0; else $quota = (int) $_POST["quota"]; $name = $_POST["name"]; $email = $_POST["email"]; $comment = $_POST["comment"]; $role = preg_replace('/[^0-2]+/', '', $_POST["role"]); $isHidden = (isset($_POST["ishidden"]) && $_POST["ishidden"]==1 ? 1 : 0); $isDisabled = (isset($_POST["isdisabled"]) && $_POST["isdisabled"]==1 ? 1 : 0); $homefolder = (isset($_POST["homefolder"]) ? $_POST["homefolder"] : 0); $quota = (isset($_POST["quota"]) ? (int) $_POST["quota"] : 0); if ($editedUser->getLogin() != $login) $editedUser->setLogin($login); if($pwdexpiration) $editedUser->setPwdExpiration($pwdexpiration); if (isset($pwd) && ($pwd != "")) { if($settings->_passwordStrength) { $ps = new Password_Strength(); $ps->set_password($_POST["pwd"]); if($settings->_passwordStrengthAlgorithm == 'simple') $ps->simple_calculate(); else $ps->calculate(); $score = $ps->get_score(); if($score >= $settings->_passwordStrength) { $editedUser->setPwd(md5($pwd)); } else { UI::exitError(getMLText("set_password"),getMLText("password_strength_insuffient")); } } else { $editedUser->setPwd(md5($pwd)); } } if ($editedUser->getFullName() != $name) $editedUser->setFullName($name); if ($editedUser->getEmail() != $email) $editedUser->setEmail($email); if ($editedUser->getComment() != $comment) $editedUser->setComment($comment); if ($editedUser->getRole() != $role) $editedUser->setRole($role); if ($editedUser->getQuota() != $quota) $editedUser->setQuota($quota); if ($editedUser->isHidden() != $isHidden) $editedUser->setHidden($isHidden); if ($editedUser->isDisabled() != $isDisabled) { $editedUser->setDisabled($isDisabled); if(!$isDisabled) $editedUser->clearLoginFailures(); } if ($editedUser->getHomeFolder() != $homefolder) $editedUser->setHomeFolder($homefolder); if ($editedUser->getQuota() != $quota) $editedUser->setQuota($quota); if(isset($_POST["workflows"]) && $_POST["workflows"]) { $workflows = array(); foreach($_POST["workflows"] as $workflowid) { if($tmp = $dms->getWorkflow($workflowid)) $workflows[] = $tmp; } if($workflows) $editedUser->setMandatoryWorkflows($workflows); } else { $editedUser->delMandatoryWorkflow(); } if (isset($_FILES['userfile']) && is_uploaded_file($_FILES["userfile"]["tmp_name"]) && $_FILES["userfile"]["size"] > 0 && $_FILES['userfile']['error']==0) { $userfiletype = $_FILES["userfile"]["type"]; $userfilename = $_FILES["userfile"]["name"]; $fileType = ".".pathinfo($userfilename, PATHINFO_EXTENSION); if ($fileType != ".jpg" && $filetype != ".jpeg") { UI::exitError(getMLText("admin_tools"),getMLText("only_jpg_user_images")); } else { resizeImage($_FILES["userfile"]["tmp_name"]); $editedUser->setImage($_FILES["userfile"]["tmp_name"], $userfiletype); } } $editedUser->delMandatoryReviewers(); if (isset($_POST["usrReviewers"])) foreach ($_POST["usrReviewers"] as $revID) $editedUser->setMandatoryReviewer($revID,false); if (isset($_POST["grpReviewers"])) foreach ($_POST["grpReviewers"] as $revID) $editedUser->setMandatoryReviewer($revID,true); $editedUser->delMandatoryApprovers(); if (isset($_POST["usrApprovers"])) foreach ($_POST["usrApprovers"] as $appID) $editedUser->setMandatoryApprover($appID,false); if (isset($_POST["grpApprovers"])) foreach ($_POST["grpApprovers"] as $appID) $editedUser->setMandatoryApprover($appID,true); /* Updates groups */ if(isset($_POST["groups"])) $newgroups = $_POST["groups"]; else $newgroups = array(); $oldgroups = array(); foreach($editedUser->getGroups() as $k) $oldgroups[] = $k->getID(); $addgroups = array_diff($newgroups, $oldgroups); foreach($addgroups as $groupid) { $group = $dms->getGroup($groupid); $group->addUser($editedUser); } $delgroups = array_diff($oldgroups, $newgroups); foreach($delgroups as $groupid) { $group = $dms->getGroup($groupid); $group->removeUser($editedUser); } $session->setSplashMsg(array('type'=>'success', 'msg'=>getMLText('splash_edit_user'))); add_log_line(".php&action=edituser&userid=".$userid); } else UI::exitError(getMLText("admin_tools"),getMLText("unknown_command")); function resizeImage($imageFile) { // Not perfect. Creates a new image even if the old one is acceptable, // and the output quality is low. Now uses the function imagecreatetruecolor(), // though, so at least the pictures are in colour. // read original image $origImg = imagecreatefromjpeg($imageFile); $width = imagesx($origImg); $height = imagesy($origImg); // Create thumbnail in memory $newHeight = 150; $newWidth = ($width/$height) * $newHeight; $newImg = imagecreatetruecolor($newWidth, $newHeight); // resize imagecopyresized($newImg, $origImg, 0, 0, 0, 0, $newWidth, $newHeight, $width, $height); // save to file imagejpeg($newImg, $imageFile); // Clean up imagedestroy($origImg); imagedestroy($newImg); return true; } header("Location:../out/out.UsrMgr.php?userid=".$userid); ?>