277 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			277 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| /*
 | |
| $Id$
 | |
| 
 | |
|   This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
 | |
|   Copyright (C) 2004 - 2013  Roland Gruber
 | |
| 
 | |
|   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
 | |
| */
 | |
| 
 | |
| /** security functions */
 | |
| include_once("../lib/security.inc");
 | |
| /** 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');
 | |
| /** PDF */
 | |
| include_once('../lib/pdf.inc');
 | |
| 
 | |
| 
 | |
| // Start session
 | |
| startSecureSession();
 | |
| 
 | |
| // check if this tool may be run
 | |
| checkIfToolIsActive('toolFileUpload');
 | |
| 
 | |
| // die if no write access
 | |
| if (!checkIfWriteAccessIsAllowed()) die();
 | |
| 
 | |
| // Redirect to startpage if user is not loged in
 | |
| if (!isLoggedIn()) {
 | |
| 	metaRefresh("login.php");
 | |
| 	exit;
 | |
| }
 | |
| 
 | |
| // Set correct language, codepages, ....
 | |
| setlanguage();
 | |
| 
 | |
| include 'main_header.php';
 | |
| $scope = htmlspecialchars($_SESSION['mass_scope']);
 | |
| 
 | |
| // check if account type is ok
 | |
| if (isAccountTypeHidden($scope)) {
 | |
| 	logNewMessage(LOG_ERR, 'User tried to access hidden upload: ' . $scope);
 | |
| 	die();
 | |
| }
 | |
| if (!checkIfNewEntriesAreAllowed($scope) || !checkIfWriteAccessIsAllowed($scope)) {
 | |
| 	logNewMessage(LOG_ERR, 'User tried to access forbidden upload: ' . $scope);
 | |
| 	die();
 | |
| }
 | |
| 
 | |
| echo '<div class="' . $scope . '-bright smallPaddingContent">';
 | |
| 
 | |
| // create accounts
 | |
| $accounts = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_accounts']));
 | |
| if (($_SESSION['mass_counter'] < sizeof($accounts)) || !isset($_SESSION['mass_postActions']['finished']) || !isset($_SESSION['mass_pdf']['finished'])) {
 | |
| 	$startTime = time();
 | |
| 	$maxTime = get_cfg_var('max_execution_time') - 5;
 | |
| 	if ($maxTime > 60) $maxTime = 60;
 | |
| 	if ($maxTime <= 0) $maxTime = 60;
 | |
| 	echo "<div class=\"title\">\n";
 | |
| 	echo "<h2 class=\"titleText\">" . _("LDAP upload in progress. Please wait.") . "</h2>\n";
 | |
| 	echo "</div>";
 | |
| 	$progress = ($_SESSION['mass_counter'] * 100) / sizeof($accounts);
 | |
| 	?>
 | |
| 		<div id="progressbarGeneral"></div>
 | |
| 		<script type="text/javascript">
 | |
| 			$(function() {
 | |
| 				$( "#progressbarGeneral" ).progressbar({
 | |
| 					value: <?php echo $progress; ?>
 | |
| 				});
 | |
| 			});
 | |
| 		</script>
 | |
| 	<?php
 | |
| 	flush();  // send HTML to browser
 | |
| 	// add accounts to LDAP
 | |
| 	while (($_SESSION['mass_counter'] < sizeof($accounts)) && (($startTime + $maxTime) > time())) {
 | |
| 		// create accounts as long as max_execution_time is not near
 | |
| 		$attrs = $accounts[$_SESSION['mass_counter']];
 | |
| 		$dn = $attrs['dn'];
 | |
| 		unset($attrs['dn']);
 | |
| 		// remove informational attributes
 | |
| 		foreach ($attrs as $key => $value) {
 | |
| 			if (strpos($key, 'INFO.') === 0) {
 | |
| 				unset($attrs[$key]);
 | |
| 			}
 | |
| 		}
 | |
| 		// run preactions
 | |
| 		$preAttributes = array();
 | |
| 		foreach ($attrs as $key => $value) {
 | |
| 			$preAttributes[$key] = &$attrs[$key];
 | |
| 		}
 | |
| 		$preAttributes['dn'] = &$dn;
 | |
| 		$preMessages = doUploadPreActions($scope, $_SESSION['mass_selectedModules'], $preAttributes);
 | |
| 		$preActionOk = true;
 | |
| 		for ($i = 0; $i < sizeof($preMessages); $i++) {
 | |
| 			if (($preMessages[$i][0] == 'ERROR') || ($preMessages[$i][0] == 'WARN')) {
 | |
| 				$preActionOk = false;
 | |
| 				$_SESSION['mass_errors'][] = $preMessages[$i];
 | |
| 			}
 | |
| 		}
 | |
| 		if ($preActionOk) {
 | |
| 			// add LDAP entry
 | |
| 			$success = @ldap_add($_SESSION['ldap']->server(), $dn, $attrs);
 | |
| 			if (!$success) {
 | |
| 				$errorMessage = array(
 | |
| 					"ERROR",
 | |
| 					_("LAM was unable to create account %s! An LDAP error occured."),
 | |
| 					getDefaultLDAPErrorString($_SESSION['ldap']->server()),
 | |
| 					array($_SESSION['mass_counter']));
 | |
| 				$_SESSION['mass_errors'][] = $errorMessage;
 | |
| 				$_SESSION['mass_failed'][] = $_SESSION['mass_counter'];
 | |
| 			}
 | |
| 		}
 | |
| 		$_SESSION['mass_counter']++;
 | |
| 	}
 | |
| 	$progress = ($_SESSION['mass_counter'] * 100) / sizeof($accounts);
 | |
| 	?>
 | |
| 		<script type="text/javascript">
 | |
| 			jQuery(function() {
 | |
| 				jQuery( "#progressbarGeneral" ).progressbar({
 | |
| 					value: <?php echo $progress; ?>
 | |
| 				});
 | |
| 			});
 | |
| 		</script>
 | |
| 	<?php
 | |
| 	flush();  // send HTML to browser
 | |
| 	// do post upload actions after all accounts are created
 | |
| 	if (($_SESSION['mass_counter'] >= sizeof($accounts)) && !isset($_SESSION['mass_postActions']['finished'])) {
 | |
| 		$data = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_data']));
 | |
| 		$return  = doUploadPostActions($scope, $data, $_SESSION['mass_ids'], $_SESSION['mass_failed'], $_SESSION['mass_selectedModules'], $accounts);
 | |
| 		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:") . ' ' . getModuleAlias($return['module'], $scope) . "</h1>\n";
 | |
| 		?>
 | |
| 			<div id="progressbar<?php echo $return['module']; ?>"></div>
 | |
| 			<script type="text/javascript">
 | |
| 				jQuery(function() {
 | |
| 					jQuery( "#progressbar<?php echo $return['module']; ?>" ).progressbar({
 | |
| 						value: <?php echo $return['progress']; ?>
 | |
| 					});
 | |
| 				});
 | |
| 			</script>
 | |
| 		<?php
 | |
| 		flush();
 | |
| 		while (!isset($_SESSION['mass_postActions']['finished']) && (($startTime + $maxTime) > time())) {
 | |
| 			$return  = doUploadPostActions($scope, $data, $_SESSION['mass_ids'], $_SESSION['mass_failed'], $_SESSION['mass_selectedModules'], $accounts);
 | |
| 			if ($return['status'] == 'finished') {
 | |
| 				$_SESSION['mass_postActions']['finished'] = true;
 | |
| 			}
 | |
| 			if (isset($return['errors'])) {
 | |
| 				for ($i = 0; $i < sizeof($return['errors']); $i++) {
 | |
| 					$_SESSION['mass_errors'][] = $return['errors'][$i];
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	// create PDF when upload post actions are done
 | |
| 	if (isset($_SESSION['mass_postActions']['finished'])) {
 | |
| 		if (($_SESSION['mass_pdf']['structure'] != null) && !isset($_SESSION['mass_pdf']['finished'])) {
 | |
| 			$file = $_SESSION['mass_pdf']['file'];
 | |
| 			$pdfStructure = $_SESSION['mass_pdf']['structure'];
 | |
| 			$pdfZip = new ZipArchive();
 | |
| 			if ($_SESSION['mass_pdf']['counter'] == 0) {
 | |
| 				$pdfZipResult = @$pdfZip->open($_SESSION['mass_pdf']['file'], ZipArchive::CREATE);
 | |
| 				if (!$pdfZipResult === true) {
 | |
| 					$_SESSION['mass_errors'][] = array('ERROR', _('Unable to create ZIP file for PDF export.'), $file);
 | |
| 					$_SESSION['mass_pdf']['finished'] = true;
 | |
| 				}
 | |
| 			}
 | |
| 			else {
 | |
| 				@$pdfZip->open($_SESSION['mass_pdf']['file']);
 | |
| 			}
 | |
| 			// show progress bar
 | |
| 			$progress = ($_SESSION['mass_pdf']['counter'] * 100) / sizeof($accounts);
 | |
| 			echo "<h1>" . _('Create PDF files') . "</h1>\n";
 | |
| 			?>
 | |
| 				<div id="progressbarPDF"></div>
 | |
| 				<script type="text/javascript">
 | |
| 					jQuery(function() {
 | |
| 						jQuery( "#progressbarPDF" ).progressbar({
 | |
| 							value: <?php echo $progress; ?>
 | |
| 						});
 | |
| 					});
 | |
| 				</script>
 | |
| 			<?php
 | |
| 			flush();
 | |
| 			while (!isset($_SESSION['mass_pdf']['finished']) && (($startTime + $maxTime) > time())) {
 | |
| 				$attrs = $accounts[$_SESSION['mass_pdf']['counter']];
 | |
| 				$dn = $attrs['dn'];
 | |
| 				// get informational attributes
 | |
| 				$infoAttributes = array();
 | |
| 				foreach ($attrs as $key => $value) {
 | |
| 					if (strpos($key, 'INFO.') === 0) {
 | |
| 						$infoAttributes[$key] = $value;
 | |
| 					}
 | |
| 				}
 | |
| 				// load account
 | |
| 				$_SESSION['pdfAccount'] = new accountContainer($scope, 'pdfAccount');
 | |
| 				$pdfErrors = $_SESSION['pdfAccount']->load_account($dn, $infoAttributes);
 | |
| 				if (sizeof($pdfErrors) > 0) {
 | |
| 					$_SESSION['mass_errors'] = array_merge($_SESSION['mass_errors'], $pdfErrors);
 | |
| 					$_SESSION['mass_pdf']['finished'] = true;
 | |
| 					break;
 | |
| 				}
 | |
| 				// create and save PDF
 | |
| 				$pdfContent = createModulePDF(array($_SESSION['pdfAccount']), $pdfStructure, true);
 | |
| 				$fileName = $dn . '.pdf';
 | |
| 				$pdfZip->addFromString($fileName, $pdfContent);
 | |
| 				$_SESSION['mass_pdf']['counter'] ++;
 | |
| 				if ($_SESSION['mass_pdf']['counter'] >= sizeof($accounts)) {
 | |
| 					$_SESSION['mass_pdf']['finished'] = true;
 | |
| 				}
 | |
| 			}
 | |
| 			@$pdfZip->close();
 | |
| 		}
 | |
| 		else {
 | |
| 			$_SESSION['mass_pdf']['finished'] = true;
 | |
| 		}
 | |
| 	}
 | |
| 	// refresh with JavaScript
 | |
| 	echo "<script type=\"text/javascript\">\n";
 | |
| 	echo "top.location.href = \"massDoUpload.php\";\n";
 | |
| 	echo "</script>\n";
 | |
| }
 | |
| // all accounts have been created
 | |
| else {
 | |
| 	echo "<div class=\"title\">\n";
 | |
| 	echo "<h2  class=\"titleText\">" . _("Upload has finished") . "</h2>\n";
 | |
| 	echo "</div>";
 | |
| 	if (sizeof($_SESSION['mass_errors']) > 0) {
 | |
| 		echo "<div class=\"subTitle\">\n";
 | |
| 		echo "<h4  class=\"subTitleText\">" . _("There were errors while uploading:") . "</h4>\n";
 | |
| 		echo "</div>";
 | |
| 		for ($i = 0; $i < sizeof($_SESSION['mass_errors']); $i++) {
 | |
| 			call_user_func_array('StatusMessage', $_SESSION['mass_errors'][$i]);
 | |
| 			echo "<br>";
 | |
| 		}
 | |
| 	}
 | |
| 	else {
 | |
| 		// redirect to list if no errors occured
 | |
| 		echo "<script type=\"text/javascript\">\n";
 | |
| 		echo "top.location.href = \"lists/list.php?type=" . $scope . "&uploadAllOk\";\n";
 | |
| 		echo "</script>\n";
 | |
| 	}
 | |
| }
 | |
| echo '</div>';
 | |
| include 'main_footer.php';
 | |
| 
 | |
| 
 | |
| ?>
 |