131 lines
4.6 KiB
PHP
131 lines
4.6 KiB
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');
|
|
session_save_path('../sess');
|
|
@session_start();
|
|
|
|
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
|
|
"http://www.w3.org/TR/html4/loose.dtd">';
|
|
echo '<html><head><title>';
|
|
echo _('Delete Account');
|
|
echo '</title>
|
|
<link rel="stylesheet" type="text/css" href="../style/layout.css">
|
|
<meta http-equiv="pragma" content="no-cache">
|
|
<meta http-equiv="cache-control" content="no-cache">
|
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
|
</head>
|
|
<body>
|
|
<form action="delete.php" method="post">
|
|
<table rules="all" class="delete" width="100%">
|
|
<tr><td>';
|
|
|
|
if ($_GET['type']) {
|
|
$DN2 = explode(";", str_replace("\'", '',$_GET['DN']));
|
|
echo '<input name="type5" type="hidden" value="'.$_GET['type'].'">';
|
|
echo '<input name="DN" type="hidden" value="'.$_GET['DN'].'">';
|
|
switch ($_GET['type']) {
|
|
case 'user':
|
|
echo _('Do you really want to delete user(s):');
|
|
break;
|
|
case 'host':
|
|
echo _('Do you really want to delete host(s):');
|
|
break;
|
|
case 'group':
|
|
echo _('Do you really want to delete group(s):');
|
|
break;
|
|
}
|
|
echo '</td></tr>';
|
|
foreach ($DN2 as $dn) echo '<tr><td>'.$dn.'</td></tr>';
|
|
echo '<tr><td><br></td></tr><tr><td>
|
|
<input name="delete_yes" type="submit" value="';
|
|
echo _('Commit'); echo '"></td><td></td><td>
|
|
<input name="delete_no" type="submit" value="';
|
|
echo _('Cancel'); echo '">';
|
|
}
|
|
|
|
if ($_POST['delete_yes']) {
|
|
$DN2 = explode(";", str_replace("\\", '',str_replace("\'", '',$_POST['DN'])));
|
|
foreach ($DN2 as $dn) {
|
|
switch ($_POST['type5']) {
|
|
case 'user':
|
|
$temp=explode(',', $dn);
|
|
$username = str_replace('uid=', '', $temp[0]);
|
|
if ($_SESSION['config']->scriptServer) {
|
|
remhomedir($username);
|
|
remquotas($username, $_POST['type5']);
|
|
}
|
|
$result = ldap_search($_SESSION['ldap']->server(), $_SESSION['config']->get_GroupSuffix(), 'objectClass=PosixGroup', array('memberUid'));
|
|
$entry = ldap_first_entry($_SESSION['ldap']->server(), $result);
|
|
while ($entry) {
|
|
$attr2 = ldap_get_attributes($_SESSION['ldap']->server(), $entry);
|
|
if ($attr2['memberUid']) {
|
|
array_shift($attr2['memberUid']);
|
|
foreach ($attr2['memberUid'] as $nam) {
|
|
if ($nam==$username) {
|
|
$todelete['memberUid'] = $nam;
|
|
$success = ldap_mod_del($_SESSION['ldap']->server(), ldap_get_dn($_SESSION['ldap']->server(), $entry) ,$todelete);
|
|
}
|
|
}
|
|
}
|
|
$entry = ldap_next_entry($_SESSION['ldap']->server(), $entry);
|
|
}
|
|
$success = ldap_delete($_SESSION['ldap']->server(), $dn);
|
|
if (!$success) $error = _('Could not delete user: ').$dn;
|
|
break;
|
|
case 'host':
|
|
$success = ldap_delete($_SESSION['ldap']->server(), $dn);
|
|
if (!$success) $error = _('Could not delete host: ').$dn;
|
|
break;
|
|
case 'group':
|
|
$temp=explode(',', $dn);
|
|
$groupname = str_replace('cn=', '', $temp[0]);
|
|
$result = ldap_search($_SESSION['ldap']->server(), $dn, 'objectClass=*', array('gidNumber');
|
|
$entry = ldap_first_entry($_SESSION['ldap']->server(), $result);
|
|
while ($entry) {
|
|
$attr2 = ldap_get_attributes($_SESSION['ldap']->server(), $entry);
|
|
if ($attr2['gidNumber']==getgid($groupname)) $error = _('Could not delete group. Still users in group: ').$dn;
|
|
$entry = ldap_next_entry($_SESSION['ldap']->server(), $entry);
|
|
}
|
|
if (!$error) {
|
|
if ($_SESSION['config']->scriptServer) remquotas($groupname, $_POST['type5']);
|
|
$success = ldap_delete($_SESSION['ldap']->server(), $dn);
|
|
if (!$success) $error = _('Could not delete group: ').$dn;
|
|
}
|
|
break;
|
|
}
|
|
if (!$error) echo $dn. _(' deleted.');
|
|
else echo $error;
|
|
echo '</td></tr><tr><td>';
|
|
}
|
|
}
|
|
|
|
if ($_POST['delete_no']) echo _('Nothing was deleted.');
|
|
|
|
echo '</td></tr>';
|
|
echo '</table></form></body></html>';
|
|
?>
|