mirror of
				https://git.code.sf.net/p/seeddms/code
				synced 2025-10-26 18:51:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			145 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| //    MyDMS. Document Management System
 | |
| //    Copyright (C) 2002-2005  Markus Westphal
 | |
| //    Copyright (C) 2006-2008 Malcolm Cowe
 | |
| //    Copyright (C) 2010-2016 Uwe Steinmann
 | |
| //
 | |
| //    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");
 | |
| include("../inc/inc.Utils.php");
 | |
| include("../inc/inc.LogInit.php");
 | |
| include("../inc/inc.Language.php");
 | |
| include("../inc/inc.Init.php");
 | |
| include("../inc/inc.Extension.php");
 | |
| include("../inc/inc.DBInit.php");
 | |
| include("../inc/inc.ClassUI.php");
 | |
| include("../inc/inc.Authentication.php");
 | |
| include("../inc/inc.ClassPasswordStrength.php");
 | |
| include("../inc/inc.ClassPasswordHistoryManager.php");
 | |
| 
 | |
| if ($user->isGuest()) {
 | |
| 	UI::exitError(getMLText("edit_user_details"),getMLText("access_denied"));
 | |
| }
 | |
| 
 | |
| if (!$user->isAdmin() && ($settings->_disableSelfEdit)) {
 | |
| 	UI::exitError(getMLText("edit_user_details"),getMLText("access_denied"));
 | |
| }
 | |
| 
 | |
| /* Check if the form data comes from a trusted request */
 | |
| if(!checkFormKey('edituserdata')) {
 | |
| 	UI::exitError(getMLText("edit_user_details"),getMLText("invalid_request_token"));
 | |
| }
 | |
| 
 | |
| $fullname = $_POST["fullname"];
 | |
| $email    = $_POST["email"];
 | |
| $comment  = $_POST["comment"];
 | |
| $language  = $_POST["language"];
 | |
| /* 'theme' won't be set, if themeselector is turned off */
 | |
| if(isset($_POST["theme"]))
 | |
| 	$mytheme  = $_POST["theme"];
 | |
| $current_pwd  = $_POST["currentpwd"];
 | |
| 
 | |
| if(!seed_pass_verify($current_pwd, $user->getPwd())) {
 | |
| 	UI::exitError(getMLText("edit_user_details"),getMLText("password_wrong"));
 | |
| }
 | |
| 
 | |
| if (isset($_POST["pwd"]) && ($_POST["pwd"] != "")) {
 | |
| 	if($settings->_passwordStrength) {
 | |
| 		$ps = new Password_Strength();
 | |
| 		$ps->set_password($_POST["pwd"]);
 | |
| 		$ps->calculate();
 | |
| 		$score = $ps->get_score();
 | |
| 		if($score > $settings->_passwordStrength) {
 | |
| 			if($settings->_passwordHistory > 0) {
 | |
| 				if ($current_pwd == $_POST["pwd"]) // history doesn't have the initial pw stored yet
 | |
| 					UI::exitError(getMLText("set_password"),getMLText("password_already_used"));
 | |
| 				$phm = new SeedDMS_PasswordHistoryManager($db);
 | |
| 				$oldpwd = $phm->search($user, seed_pass_hash($_POST["pwd"]));
 | |
| 				if($oldpwd) {
 | |
| 					UI::exitError(getMLText("set_password"),getMLText("password_already_used"));
 | |
| 				} else {
 | |
| 					$phm->add($user, seed_pass_hash($_POST["pwd"]));
 | |
| 				}
 | |
| 			}
 | |
| 			$user->setPwd(seed_pass_hash($_POST["pwd"]));
 | |
| 			$user->setPwdExpiration(date('Y-m-d H:i:s', time()+$settings->_passwordExpiration*86400));
 | |
| 		} else {
 | |
| 			UI::exitError(getMLText("set_password"),getMLText("password_strength_insuffient"));
 | |
| 		}
 | |
| 	} else {
 | |
| 		if($settings->_passwordHistory > 0) {
 | |
| 			$phm = new SeedDMS_PasswordHistoryManager($db);
 | |
| 			$oldpwd = $phm->search($user, seed_pass_hash($_POST["pwd"]));
 | |
| 			if($oldpwd) {
 | |
| 				UI::exitError(getMLText("set_password"),getMLText("password_already_used"));
 | |
| 			} else {
 | |
| 				$phm->add($user, seed_pass_hash($_POST["pwd"]));
 | |
| 			}
 | |
| 		}
 | |
| 		$user->setPwd(seed_pass_hash($_POST["pwd"]));
 | |
| 		$user->setPwdExpiration(date('Y-m-d H:i:s', time()+$settings->_passwordExpiration*86400));
 | |
| 	}
 | |
| }
 | |
| 
 | |
| if ($user->getFullName() != $fullname)
 | |
| 	$user->setFullName($fullname);
 | |
| 
 | |
| if ($user->getEmail() != $email)
 | |
| 	$user->setEmail($email);
 | |
| 
 | |
| if ($user->getComment() != $comment)
 | |
| 	$user->setComment($comment);
 | |
| 
 | |
| if ($user->getLanguage() != $language)
 | |
| 	$user->setLanguage($language);
 | |
| 
 | |
| if (isset($mytheme) && $user->getTheme() != $mytheme)
 | |
| 	$user->setTheme($mytheme);
 | |
| 
 | |
| if (isset($_FILES["userfile"]) && is_uploaded_file($_FILES["userfile"]["tmp_name"]) && $_FILES["userfile"]["size"] > 0 && $_FILES['userfile']['error']==0)
 | |
| {
 | |
| 	$finfo = new finfo(FILEINFO_MIME);
 | |
| 	// echo $finfo->file($_FILES["userfile"]["tmp_name"]);
 | |
| 	if(substr($finfo->file($_FILES["userfile"]["tmp_name"]), 0, 10) != "image/jpeg") {;
 | |
| 		UI::exitError(getMLText("user_info"),getMLText("only_jpg_user_images"));
 | |
| 	}
 | |
| 	// shrink the image to a max height of 150 px
 | |
| 	// read original image
 | |
| 	$origImg = imagecreatefromjpeg($_FILES["userfile"]["tmp_name"]);
 | |
| 	$width = imagesx($origImg);
 | |
| 	$height = imagesy($origImg);
 | |
| 	// create thumbnail in memory
 | |
| 	$newHeight = 150;
 | |
| 	$newWidth = ($width/$height) * $newHeight;
 | |
| 	$newImg = imagecreatetruecolor($newWidth, $newHeight);
 | |
| 	// shrink image
 | |
| 	imagecopyresized($newImg, $origImg, 0, 0, 0, 0, $newWidth, $newHeight, $width, $height);
 | |
| 	// save image to file
 | |
| 	imagejpeg($newImg, $_FILES["userfile"]["tmp_name"]);
 | |
| 	// clean up
 | |
| 	imagedestroy($origImg);
 | |
| 	imagedestroy($newImg);
 | |
| 	$user->setImage($_FILES["userfile"]["tmp_name"], $_FILES["userfile"]["type"]);
 | |
| }
 | |
| 
 | |
| $session->setSplashMsg(array('type'=>'success', 'msg'=>getMLText('splash_save_user_data')));
 | |
| 
 | |
| add_log_line("?user=".$user->getLogin());
 | |
| 
 | |
| header("Location:../out/out.MyAccount.php");
 | |
| 
 | |
| ?>
 | 
