added post upload actions
This commit is contained in:
parent
46e5af15ef
commit
4638db3d33
|
@ -507,8 +507,29 @@ class baseModule {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function executes one post upload action.
|
||||||
|
*
|
||||||
|
* @param array $data array containing one account in each element
|
||||||
|
* @param array $ids array(<column_name> => <column number>)
|
||||||
|
* @param array $failed list of accounts which were not created successfully
|
||||||
|
* @param array $temp variable to store temporary data between two post actions
|
||||||
|
* @return array current status
|
||||||
|
* <br> array (
|
||||||
|
* <br> 'status' => 'finished' | 'inProgress'
|
||||||
|
* <br> 'progress' => 0..100
|
||||||
|
* <br> 'errors' => array (<array of parameters for StatusMessage>)
|
||||||
|
* <br> )
|
||||||
|
*/
|
||||||
|
function doUploadPostActions($data, $ids, $failed, &$temp) {
|
||||||
|
return array(
|
||||||
|
'status' => 'finished',
|
||||||
|
'progress' => 100,
|
||||||
|
'errors' => array()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
?>
|
?>
|
|
@ -479,6 +479,53 @@ function buildUploadAccounts($scope, $data, $ids) {
|
||||||
else return $partialAccounts;
|
else return $partialAccounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function executes one post upload action.
|
||||||
|
*
|
||||||
|
* @param string $scope account type
|
||||||
|
* @param array $data array containing one account in each element
|
||||||
|
* @param array $ids array(<column_name> => <column number>)
|
||||||
|
* @param array $failed list of accounts which were not created successfully
|
||||||
|
* @return array current status
|
||||||
|
* <br> array (
|
||||||
|
* <br> 'status' => 'finished' | 'inProgress'
|
||||||
|
* <br> 'module' => <name of active module>
|
||||||
|
* <br> 'progress' => 0..100
|
||||||
|
* <br> 'errors' => array (<array of parameters for StatusMessage>)
|
||||||
|
* <br> )
|
||||||
|
*/
|
||||||
|
function doUploadPostActions($scope, $data, $ids, $failed) {
|
||||||
|
// check if function is called the first time
|
||||||
|
if (! isset($_SESSION['mass_postActions']['remainingModules'])) {
|
||||||
|
// make list of remaining modules
|
||||||
|
$moduleList = $_SESSION['config']->get_AccountModules($scope);
|
||||||
|
$_SESSION['mass_postActions']['remainingModules'] = $moduleList;
|
||||||
|
}
|
||||||
|
$activeModule = $_SESSION['mass_postActions']['remainingModules'][0];
|
||||||
|
// initialize temporary variable
|
||||||
|
if (!isset($_SESSION['mass_postActions'][$activeModule])) {
|
||||||
|
$_SESSION['mass_postActions'][$activeModule] = array();
|
||||||
|
}
|
||||||
|
// let first module do one post action
|
||||||
|
$module = new $activeModule($scope);
|
||||||
|
$return = $module->doUploadPostActions($data, $ids, $failed, $_SESSION['mass_postActions'][$activeModule]);
|
||||||
|
// remove active module from list if already finished
|
||||||
|
if ($return['status'] == 'finished') {
|
||||||
|
unset($_SESSION['mass_postActions']['remainingModules'][0]);
|
||||||
|
$_SESSION['mass_postActions']['remainingModules'] = array_values($_SESSION['mass_postActions']['remainingModules']);
|
||||||
|
}
|
||||||
|
// update status and return back to upload page
|
||||||
|
$return['module'] = $activeModule;
|
||||||
|
if (sizeof($_SESSION['mass_postActions']['remainingModules']) > 0) {
|
||||||
|
$return['status'] = 'inProgress';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$return['status'] = 'finished';
|
||||||
|
}
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class includes all modules and attributes of an account.
|
* This class includes all modules and attributes of an account.
|
||||||
*
|
*
|
||||||
|
|
|
@ -13,7 +13,11 @@ masscreate:
|
||||||
- mass_counter: aktuelle Position im Account-Array
|
- mass_counter: aktuelle Position im Account-Array
|
||||||
- mass_errors: Fehlermeldungen beim Upload
|
- mass_errors: Fehlermeldungen beim Upload
|
||||||
- mass_csv: CSV-Datei als Vorlage für Upload
|
- mass_csv: CSV-Datei als Vorlage für Upload
|
||||||
|
- mass_failed: Liste der Accounts, die nicht erzeugt werden konnten
|
||||||
|
- mass_postActions: temporäre Daten für den Upload
|
||||||
|
- mass_data: Eingabedaten
|
||||||
|
- mass_ids: Tabelle Spaltenname => Spaltennummer
|
||||||
|
- mass_scope: Account-Typ
|
||||||
|
|
||||||
main:
|
main:
|
||||||
- domain_message: Wird auf der "neue Domain" Seite ausgegeben, wenn keine Domäne gefunden wurde
|
- domain_message: Wird auf der "neue Domain" Seite ausgegeben, wenn keine Domäne gefunden wurde
|
||||||
|
|
|
@ -179,6 +179,11 @@ if ($_FILES['inputfile'] && ($_FILES['inputfile']['size'] > 0)) {
|
||||||
$_SESSION['mass_accounts'] = $_SESSION['ldap']->encrypt(serialize($accounts));
|
$_SESSION['mass_accounts'] = $_SESSION['ldap']->encrypt(serialize($accounts));
|
||||||
$_SESSION['mass_counter'] = 0;
|
$_SESSION['mass_counter'] = 0;
|
||||||
$_SESSION['mass_errors'] = array();
|
$_SESSION['mass_errors'] = array();
|
||||||
|
$_SESSION['mass_failed'] = array();
|
||||||
|
$_SESSION['mass_postActions'] = array();
|
||||||
|
$_SESSION['mass_data'] = $_SESSION['ldap']->encrypt(serialize($data));
|
||||||
|
$_SESSION['mass_ids'] = $ids;
|
||||||
|
$_SESSION['mass_scope'] = $_POST['scope'];
|
||||||
// show links for upload and LDIF export
|
// show links for upload and LDIF export
|
||||||
echo "<h1 align=\"center\">" . _("LAM has checked your input and is now ready to create the accounts.") . "</h1>\n";
|
echo "<h1 align=\"center\">" . _("LAM has checked your input and is now ready to create the accounts.") . "</h1>\n";
|
||||||
echo "<p> </p>\n";
|
echo "<p> </p>\n";
|
||||||
|
|
|
@ -57,7 +57,7 @@ echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n
|
||||||
|
|
||||||
// create accounts
|
// create accounts
|
||||||
$accounts = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_accounts']));
|
$accounts = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_accounts']));
|
||||||
if ($_SESSION['mass_counter'] < sizeof($accounts)) {
|
if (($_SESSION['mass_counter'] < sizeof($accounts)) || !isset($_SESSION['mass_postActions']['finished'])) {
|
||||||
$maxTime = get_cfg_var('max_execution_time') - 5;
|
$maxTime = get_cfg_var('max_execution_time') - 5;
|
||||||
$refreshTime = get_cfg_var('max_execution_time') + 1;
|
$refreshTime = get_cfg_var('max_execution_time') + 1;
|
||||||
$startTime = time();
|
$startTime = time();
|
||||||
|
@ -69,6 +69,7 @@ if ($_SESSION['mass_counter'] < sizeof($accounts)) {
|
||||||
echo "<td bgcolor=\"grey\" width=\"" . (100 - (($_SESSION['mass_counter'] * 100) / sizeof($accounts))) . "%\"> </td></tr>\n";
|
echo "<td bgcolor=\"grey\" width=\"" . (100 - (($_SESSION['mass_counter'] * 100) / sizeof($accounts))) . "%\"> </td></tr>\n";
|
||||||
echo "</table>";
|
echo "</table>";
|
||||||
flush(); // send HTML to browser
|
flush(); // send HTML to browser
|
||||||
|
// add accounts to LDAP
|
||||||
while (($_SESSION['mass_counter'] < sizeof($accounts)) && ($startTime + $maxTime > time())) {
|
while (($_SESSION['mass_counter'] < sizeof($accounts)) && ($startTime + $maxTime > time())) {
|
||||||
// create accounts as long as max_execution_time is not near
|
// create accounts as long as max_execution_time is not near
|
||||||
$attrs = $accounts[$_SESSION['mass_counter']];
|
$attrs = $accounts[$_SESSION['mass_counter']];
|
||||||
|
@ -82,9 +83,32 @@ if ($_SESSION['mass_counter'] < sizeof($accounts)) {
|
||||||
ldap_errno($_SESSION[ldap]->server) . ": " . ldap_error($_SESSION[ldap]->server),
|
ldap_errno($_SESSION[ldap]->server) . ": " . ldap_error($_SESSION[ldap]->server),
|
||||||
array($_SESSION['mass_counter']));
|
array($_SESSION['mass_counter']));
|
||||||
$_SESSION['mass_errors'][] = $errorMessage;
|
$_SESSION['mass_errors'][] = $errorMessage;
|
||||||
|
$_SESSION['mass_failed'][] = $_SESSION['mass_counter'];
|
||||||
}
|
}
|
||||||
$_SESSION['mass_counter']++;
|
$_SESSION['mass_counter']++;
|
||||||
}
|
}
|
||||||
|
// do post upload actions
|
||||||
|
if ($_SESSION['mass_counter'] >= sizeof($accounts)) {
|
||||||
|
$data = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_data']));
|
||||||
|
$return = doUploadPostActions($_SESSION['mass_scope'], $data, $_SESSION['mass_ids'], $failed);
|
||||||
|
if ($return['status'] == 'finished') {
|
||||||
|
$_SESSION['mass_postActions']['finished'] = true;
|
||||||
|
}
|
||||||
|
for ($i = 0; $i < sizeof($return['errors']); $i++) $_SESSION['mass_errors'][] = $return['errors'][$i];
|
||||||
|
echo "<h1>" . _("Additional tasks for module: ") . $return['module'] . "</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=\"" . $return['progress'] . "%\"> </td>";
|
||||||
|
echo "<td bgcolor=\"grey\" width=\"" . (100 - $return['progress']) . "%\"> </td></tr>\n";
|
||||||
|
echo "</table>";
|
||||||
|
flush();
|
||||||
|
while (!isset($_SESSION['mass_postActions']['finished']) && ($startTime + $maxTime > time())) {
|
||||||
|
$return = doUploadPostActions($_SESSION['mass_scope'], $data, $_SESSION['mass_ids'], $failed);
|
||||||
|
if ($return['status'] == 'finished') {
|
||||||
|
$_SESSION['mass_postActions']['finished'] = true;
|
||||||
|
}
|
||||||
|
for ($i = 0; $i < sizeof($return['errors']); $i++) $_SESSION['mass_errors'][] = $return['errors'][$i];
|
||||||
|
}
|
||||||
|
}
|
||||||
echo "</body></html>";
|
echo "</body></html>";
|
||||||
}
|
}
|
||||||
// all accounts have been created
|
// all accounts have been created
|
||||||
|
|
Loading…
Reference in New Issue