2004-09-26 09:48:58 +00:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
$Id$
|
|
|
|
|
|
|
|
This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam)
|
2006-03-03 17:30:35 +00:00
|
|
|
Copyright (C) 2004 - 2006 Roland Gruber
|
2004-09-26 09:48:58 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates LDAP accounts for file upload.
|
|
|
|
*
|
|
|
|
* @author Roland Gruber
|
|
|
|
* @package tools
|
|
|
|
*/
|
|
|
|
|
2006-03-26 17:51:25 +00:00
|
|
|
/** security functions */
|
|
|
|
include_once("../lib/security.inc");
|
2004-09-26 09:48:58 +00:00
|
|
|
/** access to configuration */
|
|
|
|
include_once('../lib/config.inc');
|
|
|
|
/** LDAP handle */
|
|
|
|
include_once('../lib/ldap.inc');
|
|
|
|
/** status messages */
|
|
|
|
include_once('../lib/status.inc');
|
|
|
|
/** account modules */
|
|
|
|
include_once('../lib/modules.inc');
|
2005-08-04 15:14:44 +00:00
|
|
|
/** LAM cache */
|
|
|
|
include_once('../lib/cache.inc');
|
2004-09-26 09:48:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Start session
|
2006-03-26 17:51:25 +00:00
|
|
|
startSecureSession();
|
2004-09-26 09:48:58 +00:00
|
|
|
|
2007-12-30 13:15:39 +00:00
|
|
|
// die if no write access
|
|
|
|
if (!checkIfWriteAccessIsAllowed()) die();
|
|
|
|
|
2004-09-26 09:48:58 +00:00
|
|
|
// Redirect to startpage if user is not loged in
|
2008-05-15 17:32:59 +00:00
|
|
|
if (!isset($_SESSION['loggedIn']) || ($_SESSION['loggedIn'] !== true)) {
|
2004-09-26 09:48:58 +00:00
|
|
|
metaRefresh("login.php");
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set correct language, codepages, ....
|
|
|
|
setlanguage();
|
|
|
|
|
|
|
|
echo $_SESSION['header'];
|
|
|
|
echo "<title>account upload</title>\n";
|
|
|
|
echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n";
|
|
|
|
|
|
|
|
// create accounts
|
|
|
|
$accounts = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_accounts']));
|
2004-10-19 18:18:46 +00:00
|
|
|
if (($_SESSION['mass_counter'] < sizeof($accounts)) || !isset($_SESSION['mass_postActions']['finished'])) {
|
2004-09-26 09:48:58 +00:00
|
|
|
$startTime = time();
|
2005-07-19 12:19:50 +00:00
|
|
|
$maxTime = get_cfg_var('max_execution_time') - 5;
|
|
|
|
if ($maxTime > 60) $maxTime = 60;
|
2005-11-28 14:24:52 +00:00
|
|
|
if ($maxTime <= 0) $maxTime = 60;
|
2005-07-19 12:19:50 +00:00
|
|
|
$refreshTime = $maxTime + 7;
|
|
|
|
echo "<meta http-equiv=\"refresh\" content=\"" . $refreshTime . "; URL=massDoUpload.php\">\n";
|
2004-09-26 09:48:58 +00:00
|
|
|
echo "</head>\n<body>\n";
|
|
|
|
echo "<h1>" . _("LDAP upload in progress. Please wait.") . "</h1>\n";
|
|
|
|
echo "<table align=\"center\" width=\"80%\" style=\"border-color: grey\" border=\"2\" cellspacing=\"0\" rules=\"none\">\n";
|
|
|
|
echo "<tr><td bgcolor=\"blue\" width=\"" . ($_SESSION['mass_counter'] * 100) / sizeof($accounts) . "%\"> </td>";
|
|
|
|
echo "<td bgcolor=\"grey\" width=\"" . (100 - (($_SESSION['mass_counter'] * 100) / sizeof($accounts))) . "%\"> </td></tr>\n";
|
|
|
|
echo "</table>";
|
|
|
|
flush(); // send HTML to browser
|
2004-10-19 18:18:46 +00:00
|
|
|
// add accounts to LDAP
|
2005-07-19 12:19:50 +00:00
|
|
|
while (($_SESSION['mass_counter'] < sizeof($accounts)) && (($startTime + $maxTime) > time())) {
|
2004-09-26 09:48:58 +00:00
|
|
|
// create accounts as long as max_execution_time is not near
|
|
|
|
$attrs = $accounts[$_SESSION['mass_counter']];
|
|
|
|
$dn = $attrs['dn'];
|
|
|
|
unset($attrs['dn']);
|
2007-07-08 10:51:01 +00:00
|
|
|
$success = @ldap_add($_SESSION['ldap']->server(), $dn, $attrs);
|
2004-09-26 09:48:58 +00:00
|
|
|
if (!$success) {
|
|
|
|
$errorMessage = array(
|
|
|
|
"ERROR",
|
|
|
|
_("LAM was unable to create account %s! An LDAP error occured."),
|
2007-07-08 10:51:01 +00:00
|
|
|
ldap_errno($_SESSION['ldap']->server()) . ": " . ldap_error($_SESSION['ldap']->server()),
|
2004-09-26 09:48:58 +00:00
|
|
|
array($_SESSION['mass_counter']));
|
|
|
|
$_SESSION['mass_errors'][] = $errorMessage;
|
2004-10-19 18:18:46 +00:00
|
|
|
$_SESSION['mass_failed'][] = $_SESSION['mass_counter'];
|
2004-09-26 09:48:58 +00:00
|
|
|
}
|
|
|
|
$_SESSION['mass_counter']++;
|
|
|
|
}
|
2004-10-19 18:18:46 +00:00
|
|
|
// do post upload actions
|
|
|
|
if ($_SESSION['mass_counter'] >= sizeof($accounts)) {
|
|
|
|
$data = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_data']));
|
2004-10-24 09:48:49 +00:00
|
|
|
$return = doUploadPostActions($_SESSION['mass_scope'], $data, $_SESSION['mass_ids'], $_SESSION['mass_failed']);
|
2004-10-19 18:18:46 +00:00
|
|
|
if ($return['status'] == 'finished') {
|
|
|
|
$_SESSION['mass_postActions']['finished'] = true;
|
|
|
|
}
|
|
|
|
for ($i = 0; $i < sizeof($return['errors']); $i++) $_SESSION['mass_errors'][] = $return['errors'][$i];
|
2006-11-28 19:45:30 +00:00
|
|
|
echo "<h1>" . _("Additional tasks for module:") . ' ' . getModuleAlias($return['module'], $_SESSION['mass_scope']) . "</h1>\n";
|
2004-10-19 18:18:46 +00:00
|
|
|
echo "<table align=\"center\" width=\"80%\" style=\"border-color: grey\" border=\"2\" cellspacing=\"0\" rules=\"none\">\n";
|
|
|
|
echo "<tr><td bgcolor=\"blue\" width=\"" . $return['progress'] . "%\"> </td>";
|
|
|
|
echo "<td bgcolor=\"grey\" width=\"" . (100 - $return['progress']) . "%\"> </td></tr>\n";
|
|
|
|
echo "</table>";
|
|
|
|
flush();
|
2005-07-19 12:19:50 +00:00
|
|
|
while (!isset($_SESSION['mass_postActions']['finished']) && (($startTime + $maxTime) > time())) {
|
2004-10-24 09:48:49 +00:00
|
|
|
$return = doUploadPostActions($_SESSION['mass_scope'], $data, $_SESSION['mass_ids'], $_SESSION['mass_failed']);
|
2004-10-19 18:18:46 +00:00
|
|
|
if ($return['status'] == 'finished') {
|
|
|
|
$_SESSION['mass_postActions']['finished'] = true;
|
|
|
|
}
|
|
|
|
for ($i = 0; $i < sizeof($return['errors']); $i++) $_SESSION['mass_errors'][] = $return['errors'][$i];
|
|
|
|
}
|
|
|
|
}
|
2004-09-26 09:48:58 +00:00
|
|
|
echo "</body></html>";
|
|
|
|
}
|
|
|
|
// all accounts have been created
|
|
|
|
else {
|
2005-08-04 15:14:44 +00:00
|
|
|
$_SESSION['cache']->refresh_cache(true);
|
2004-09-26 09:48:58 +00:00
|
|
|
echo "</head>\n<body>\n";
|
|
|
|
echo "<h1>" . _("LDAP upload has finished") . "</h1>\n";
|
|
|
|
if (sizeof($_SESSION['mass_errors']) > 0) {
|
|
|
|
echo "<h2>" . _("There were errors while uploading:") . "</h2>\n";
|
|
|
|
for ($i = 0; $i < sizeof($_SESSION['mass_errors']); $i++) {
|
|
|
|
call_user_func_array('StatusMessage', $_SESSION['mass_errors'][$i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "</body></html>";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
?>
|