256 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
		
		
			
		
	
	
			256 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
|  | <?php | ||
|  | /* | ||
|  | $Id$ | ||
|  | 
 | ||
|  |   This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam) | ||
|  |   Copyright (C) 2003  Tilo Lutz | ||
|  | 
 | ||
|  |   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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | ||
|  | 
 | ||
|  | 
 | ||
|  |   LDAP Account Manager Delete user, hosts or groups | ||
|  | */ | ||
|  | 
 | ||
|  | include_once('../lib/ldap.inc'); | ||
|  | include_once('../lib/account.inc'); | ||
|  | include_once('../lib/config.inc'); | ||
|  | // start session
 | ||
|  | session_save_path('../sess'); | ||
|  | @session_start(); | ||
|  | // Redirect to startpage if user is not loged in
 | ||
|  | if (!isset($_SESSION['loggedIn'])) { | ||
|  | 	metaRefresh("login.php"); | ||
|  | 	die; | ||
|  | 	} | ||
|  | 
 | ||
|  | // set language
 | ||
|  | setlanguage(); | ||
|  | 
 | ||
|  | // use references because session-vars can change in future
 | ||
|  | $ldap_intern =& $_SESSION['ldap']; | ||
|  | $header_intern =& $_SESSION['header']; | ||
|  | $config_intern =& $_SESSION['config']; | ||
|  | $delete_dn =& $_SESSION['delete_dn']; | ||
|  | 
 | ||
|  | if ($_POST['backmain']) { | ||
|  | 	// back to list page
 | ||
|  | 	if (isset($_SESSION['delete_dn'])) unset ($_SESSION['delete_dn']); | ||
|  | 	metaRefresh("lists/list".$_POST['type']."s.php"); | ||
|  | 	// stop script because we don't want to reate invalid html-code
 | ||
|  | 	die; | ||
|  | 	} | ||
|  | 
 | ||
|  | // Print header and part of body
 | ||
|  | echo $header_intern; | ||
|  | echo '<title>'; | ||
|  | echo _('Delete Account'); | ||
|  | echo '</title>'."\n". | ||
|  | 	'<link rel="stylesheet" type="text/css" href="../style/layout.css">'."\n". | ||
|  | 	'<meta http-equiv="pragma" content="no-cache">'."\n". | ||
|  | 	'<meta http-equiv="cache-control" content="no-cache">'."\n". | ||
|  | 	'</head>'."\n". | ||
|  | 	'<body>'."\n". | ||
|  | 	'<form action="delete.php" method="post">'."\n"; | ||
|  | 
 | ||
|  | 
 | ||
|  | if ($_GET['type']) { | ||
|  | 	// $_GET['type'] is true if delete.php was called from *list.php
 | ||
|  | 	// Store $_GET['type'] as $_POST['type']
 | ||
|  | 	// Replace wrong chars from Session
 | ||
|  | 	echo '<input name="type" type="hidden" value="'.$_GET['type'].'">'; | ||
|  | 	switch ($_GET['type']) { | ||
|  | 		// Select which layout and text should be displayed
 | ||
|  | 		case 'user': | ||
|  | 			echo "<fieldset class=\"useredit-bright\"><legend class=\"useredit-bright\"><b>"; | ||
|  | 			echo _('Delete user(s)'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo '<b>'._('Do you really want to delete user(s):').'</b>'; | ||
|  | 			break; | ||
|  | 		case 'host': | ||
|  | 			echo "<fieldset class=\"hostedit-bright\"><legend class=\"hostedit-bright\"><b>"; | ||
|  | 			echo _('Delete host(s)'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo '<b>'._('Do you really want to delete host(s):').'</b>'; | ||
|  | 			break; | ||
|  | 		case 'group': | ||
|  | 			echo "<fieldset class=\"groupedit-bright\"><legend class=\"groupedit-bright\"><b>"; | ||
|  | 			echo _('Delete group(s)'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo '<b>'._('Do you really want to delete group(s):').'</b>'; | ||
|  | 			break; | ||
|  | 		} | ||
|  | 	echo "<br>\n"; | ||
|  | 	// display all DNs in a tables
 | ||
|  | 	echo "<table border=0 width=\"100%\">\n"; | ||
|  | 	foreach ($delete_dn as $dn) echo '<tr><td>'.$dn.'</td></tr>'; | ||
|  | 	echo "</table>\n"; | ||
|  | 
 | ||
|  | 	// Ask if lam should delete homedirs if users are deleted and lamdaemon.pl is in use
 | ||
|  | 	if (($_GET['type']== user) && $config_intern->scriptServer) { | ||
|  | 		echo "<br>\n"; | ||
|  | 		echo "<table border=0>\n"; | ||
|  | 		echo '<tr><td>'; | ||
|  | 		echo _('Delete also Homedirectories'); | ||
|  | 		echo '</td>'."\n".'<td><input name="f_rem_home" type="checkbox">'. | ||
|  | 			'</td></tr>'."\n"; | ||
|  | 		echo "</table>\n"; | ||
|  | 		} | ||
|  | 
 | ||
|  | 	// Print buttons
 | ||
|  | 	echo "<br><table border=0>\n"; | ||
|  | 	echo '<tr><td>'. | ||
|  | 		'<input name="delete_no" type="submit" value="'; | ||
|  | 	echo _('Cancel'); echo '"></td><td></td><td>'. | ||
|  | 		'<input name="delete_yes" type="submit" value="'; | ||
|  | 	echo _('Commit'); echo '"></td></tr>'; | ||
|  | 	echo "</table></fieldset>\n"; | ||
|  | 	} | ||
|  | 
 | ||
|  | 
 | ||
|  | if ($_POST['delete_yes']) { | ||
|  | 	// deletion has been confirmed.
 | ||
|  | 	switch ($_POST['type']) { | ||
|  | 		case 'user': | ||
|  | 			echo "<fieldset class=\"useredit-bright\"><legend class=\"useredit-bright\"><b>"; | ||
|  | 			echo _('Deleting user(s)...'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			break; | ||
|  | 		case 'host': | ||
|  | 			echo "<fieldset class=\"hostedit-bright\"><legend class=\"hostedit-bright\"><b>"; | ||
|  | 			echo _('Deleting host(s)...'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			break; | ||
|  | 		case 'group': | ||
|  | 			echo "<fieldset class=\"groupedit-bright\"><legend class=\"groupedit-bright\"><b>"; | ||
|  | 			echo _('Deleting group(s)...'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			break; | ||
|  | 		} | ||
|  | 	echo '<input name="type" type="hidden" value="'.$_POST['type'].'">'; | ||
|  | 	echo "<br><table border=0 >\n"; | ||
|  | 	// Store kind of DNs
 | ||
|  | 	foreach ($delete_dn as $dn) { | ||
|  | 		// Loop for every DN which should be deleted
 | ||
|  | 		switch ($_POST['type']) { | ||
|  | 			case 'user': | ||
|  | 				// Get username from DN
 | ||
|  | 				$temp=explode(',', $dn); | ||
|  | 				$username = str_replace('uid=', '', $temp[0]); | ||
|  | 				// Fill array with groupnames
 | ||
|  | 				$usernames[] = $username; | ||
|  | 				// Search for groups which have memberUid set to username
 | ||
|  | 				$result = ldap_search($ldap_intern->server(), $config_intern->get_GroupSuffix(), "(&(objectClass=PosixGroup)(memberUid=$username))", array('')); | ||
|  | 				$entry = ldap_first_entry($ldap_intern->server(), $result); | ||
|  | 				// loop for every found group and remove membership
 | ||
|  | 				while ($entry) { | ||
|  | 					$success = ldap_mod_del($ldap_intern->server(), ldap_get_dn($ldap_intern->server(), $entry) , array('memberUid' => $username)); | ||
|  | 					// *** fixme add error-message if memberUid couldn't be deleted
 | ||
|  | 					$entry = ldap_next_entry($ldap_intern->server(), $entry); | ||
|  | 					} | ||
|  | 				// Delete user itself
 | ||
|  | 				$success = ldap_delete($ldap_intern->server(), $dn); | ||
|  | 				if (!$success) $error = _('Could not delete user:').' '.$dn; | ||
|  | 				break; | ||
|  | 			case 'host': | ||
|  | 				// Delete host itself
 | ||
|  | 				$success = ldap_delete($ldap_intern->server(), $dn); | ||
|  | 				if (!$success) $error = _('Could not delete host:').' '.$dn; | ||
|  | 				break; | ||
|  | 			case 'group': | ||
|  | 				/* First we have to check if any user uses $group | ||
|  | 				* as primary group. It's not allowed to delete a | ||
|  | 				* group if it still contains primaty members | ||
|  | 				*/ | ||
|  | 				$temp=explode(',', $dn); | ||
|  | 				$groupname = str_replace('cn=', '', $temp[0]); | ||
|  | 				// Fill array with groupnames
 | ||
|  | 				$usernames[] = $groupname; | ||
|  | 				// Get group GIDNumber
 | ||
|  | 				$groupgid = getgid($groupname); | ||
|  | 				// Search for users which have gid set to current gid
 | ||
|  | 				$result = ldap_search($ldap_intern->server(), $config_intern->get_UserSuffix(), "gidNumber=$groupgid", array('')); | ||
|  | 				// Print error if still users in group
 | ||
|  | 				if (!$result) $error = _('Could not delete group. Still users in group:').' '.$dn; | ||
|  | 				else { | ||
|  | 					// Delete group itself
 | ||
|  | 					$success = ldap_delete($ldap_intern->server(), $dn); | ||
|  | 					if (!$success) $error = _('Could not delete group:').' '.$dn; | ||
|  | 					} | ||
|  | 				break; | ||
|  | 			} | ||
|  | 		if ($config_intern->scriptServer && isset($usernames)) { | ||
|  | 			// Remove homedir if required
 | ||
|  | 			if ($_POST['f_rem_home']) remhomedir($usernames); | ||
|  | 			// Remove quotas if lamdaemon.pl is used
 | ||
|  | 			remquotas($usernames, 'user'); | ||
|  | 			} | ||
|  | 		// Remove DNs from cache-array
 | ||
|  | 		if ($success && isset($_SESSION[$_POST['type'].'DN'][$dn])) unset($_SESSION[$_POST['type'].'DN'][$dn]); | ||
|  | 		// Display success or error-message
 | ||
|  | 		if (!$error) echo "<tr><td><b>$dn ". _('deleted').".</b></td></tr>\n"; | ||
|  | 		 else echo "<tr><td><b>$error</b></td></tr>\n"; | ||
|  | 		} | ||
|  | 	echo "</table><br>\n"; | ||
|  | 	switch ($_POST['type']) { | ||
|  | 		// Select which page should be displayd if back-button will be pressed
 | ||
|  | 		case 'user': | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to user list'); echo '">'; | ||
|  | 			break; | ||
|  | 		case 'group': | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to group list'); echo '">'; | ||
|  | 			break; | ||
|  | 		case 'host': | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to host list'); echo '">'; | ||
|  | 			break; | ||
|  | 		} | ||
|  | 	echo "<br></fieldset>\n"; | ||
|  | 	} | ||
|  | 
 | ||
|  | if ($_POST['delete_no']) { | ||
|  | 	// Delete no accounts
 | ||
|  | 	echo '<input name="type" type="hidden" value="'.$_POST['type'].'">'; | ||
|  | 	switch ($_POST['type']) { | ||
|  | 		// Select which page should be displayd if back-button will be pressed
 | ||
|  | 		case 'user': | ||
|  | 			echo "<fieldset class=\"useredit-bright\"><legend class=\"useredit-bright\"><b>"; | ||
|  | 			echo _('Deleting user(s) canceled.'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo _('No user(s) were deleted'); | ||
|  | 			echo "<br>"; | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to user list'); echo '">'; | ||
|  | 			break; | ||
|  | 		case 'host': | ||
|  | 			echo "<fieldset class=\"hostedit-bright\"><legend class=\"hostedit-bright\"><b>"; | ||
|  | 			echo _('Deleting host(s) canceled.'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo _('No host(s) were deleted'); | ||
|  | 			echo "<br>"; | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to host list'); echo '">'; | ||
|  | 			break; | ||
|  | 		case 'group': | ||
|  | 			echo "<fieldset class=\"groupedit-bright\"><legend class=\"groupedit-bright\"><b>"; | ||
|  | 			echo _('Deleting group(s) canceled.'); | ||
|  | 			echo "</b></legend>\n"; | ||
|  | 			echo _('No group(s) were deleted'); | ||
|  | 			echo "<br>"; | ||
|  | 			echo '<input name="backmain" type="submit" value="'; echo _('Back to group list'); echo '">'; | ||
|  | 			break; | ||
|  | 		} | ||
|  | 	echo "<br></fieldset>\n"; | ||
|  | 	} | ||
|  | 
 | ||
|  | echo '</form></body></html>'."\n"; | ||
|  | ?>
 |