| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | $Id$ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 18:47:12 +00:00
										 |  |  |   This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/) | 
					
						
							| 
									
										
										
										
											2011-12-20 20:48:04 +00:00
										 |  |  |   Copyright (C) 2004 - 2011  Roland Gruber | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +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 the accounts by parsing the uploaded file. | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | * @author Roland Gruber | 
					
						
							|  |  |  | * @package tools | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-26 17:51:25 +00:00
										 |  |  | /** security functions */ | 
					
						
							|  |  |  | include_once("../lib/security.inc"); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | /** access to configuration */ | 
					
						
							|  |  |  | include_once('../lib/config.inc'); | 
					
						
							|  |  |  | /** status messages */ | 
					
						
							|  |  |  | include_once('../lib/status.inc'); | 
					
						
							|  |  |  | /** account modules */ | 
					
						
							|  |  |  | include_once('../lib/modules.inc'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Start session
 | 
					
						
							| 
									
										
										
										
											2006-03-26 17:51:25 +00:00
										 |  |  | startSecureSession(); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-30 13:15:39 +00:00
										 |  |  | // die if no write access
 | 
					
						
							|  |  |  | if (!checkIfWriteAccessIsAllowed()) die(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +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-21 18:39:11 +00:00
										 |  |  | 	metaRefresh("login.php"); | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Set correct language, codepages, ....
 | 
					
						
							|  |  |  | setlanguage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // show LDIF if requested
 | 
					
						
							|  |  |  | if (isset($_GET['showldif'])) { | 
					
						
							|  |  |  | 	//download file
 | 
					
						
							|  |  |  | 	if(isset($HTTP_SERVER_VARS['HTTP_USER_AGENT']) and strpos($HTTP_SERVER_VARS['HTTP_USER_AGENT'],'MSIE')) { | 
					
						
							|  |  |  | 		Header('Content-Type: application/force-download'); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		Header('Content-Type: text/plain'); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	Header('Content-disposition: attachment; filename=lam.ldif'); | 
					
						
							|  |  |  | 	$accounts = unserialize($_SESSION['ldap']->decrypt($_SESSION['mass_accounts'])); | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($accounts); $i++) { | 
					
						
							|  |  |  | 		echo "DN: " . $accounts[$i]['dn'] . "\n"; | 
					
						
							|  |  |  | 		unset($accounts[$i]['dn']); | 
					
						
							|  |  |  | 		$keys = array_keys($accounts[$i]); | 
					
						
							|  |  |  | 		for ($k = 0; $k < sizeof($keys); $k++) { | 
					
						
							|  |  |  | 			if (is_array($accounts[$i][$keys[$k]])) { | 
					
						
							|  |  |  | 				for ($x = 0; $x < sizeof($accounts[$i][$keys[$k]]); $x++) { | 
					
						
							|  |  |  | 					echo $keys[$k] . ": " . $accounts[$i][$keys[$k]][$x] . "\n"; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				echo $keys[$k] . ": " . $accounts[$i][$keys[$k]] . "\n"; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		echo "\n"; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-01 17:21:46 +00:00
										 |  |  | include 'main_header.php'; | 
					
						
							| 
									
										
										
										
											2011-02-13 11:46:52 +00:00
										 |  |  | echo '<div class="' . $_POST['scope'] . 'list-bright smallPaddingContent">'; | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-28 13:29:05 +00:00
										 |  |  | $selectedModules = explode(',', $_POST['selectedModules']); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | if ($_FILES['inputfile'] && ($_FILES['inputfile']['size'] > 0)) { | 
					
						
							|  |  |  | 	// check if input file is well formated
 | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	$data = array();  // input values without first row
 | 
					
						
							|  |  |  | 	$ids = array();  // <column name> => <column number for $data>
 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	// get input fields from modules
 | 
					
						
							| 
									
										
										
										
											2010-02-15 20:21:44 +00:00
										 |  |  | 	$columns = getUploadColumns($_POST['scope'], $selectedModules); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	// read input file
 | 
					
						
							|  |  |  | 	$handle = fopen ($_FILES['inputfile']['tmp_name'], "r"); | 
					
						
							|  |  |  | 	if (($head = fgetcsv($handle, 2000)) !== false ) { // head row
 | 
					
						
							|  |  |  | 		for ($i = 0; $i < sizeof($head); $i++) { | 
					
						
							|  |  |  | 			$ids[$head[$i]] = $i; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	while (($line = fgetcsv($handle, 2000)) !== false ) { // account rows
 | 
					
						
							|  |  |  | 		$data[] = $line; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	$errors = array(); | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	// check if all required columns are present
 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	$checkcolumns = array(); | 
					
						
							|  |  |  | 	$columns = call_user_func_array('array_merge', $columns); | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($columns); $i++) { | 
					
						
							| 
									
										
										
										
											2004-10-10 11:16:34 +00:00
										 |  |  | 		if (isset($columns[$i]['required']) && ($columns[$i]['required'] == true)) { | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 			if (isset($ids[$columns[$i]['name']])) $checkcolumns[] = $ids[$columns[$i]['name']]; | 
					
						
							|  |  |  | 			else $errors[] = array(_("A required column is missing in your CSV file."), $columns[$i]['name']); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	// check if all required attributes are given
 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	$invalidColumns = array(); | 
					
						
							|  |  |  | 	$id_names = array_keys($ids); | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($checkcolumns); $i++) { | 
					
						
							|  |  |  | 		for ($r = 0; $r < sizeof($data); $r++) { | 
					
						
							|  |  |  | 			if ($data[$r][$checkcolumns[$i]] == "") { | 
					
						
							|  |  |  | 				$invalidColumns[] = $id_names[$checkcolumns[$i]]; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($data); $i++) { | 
					
						
							|  |  |  | 		if ($data[$i][$ids['dn_rdn']] == "") { | 
					
						
							|  |  |  | 			$invalidColumns[] = 'dn_rdn'; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($invalidColumns); $i++) { | 
					
						
							|  |  |  | 		$errors[] = array(_("One or more values of the required column \"$invalidColumns[$i]\" are missing."), ""); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	// check if values in unique columns are correct
 | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($columns); $i++) { | 
					
						
							| 
									
										
										
										
											2008-09-16 17:12:25 +00:00
										 |  |  | 		if (isset($columns[$i]['unique']) && ($columns[$i]['unique'] == true)) { | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 			$colNumber = $ids[$columns[$i]['name']]; | 
					
						
							|  |  |  | 			$values_given = array(); | 
					
						
							|  |  |  | 			for ($r = 0; $r < sizeof($data); $r++) { | 
					
						
							|  |  |  | 				$values_given[] = $data[$r][$colNumber]; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			$values_unique = array_unique($values_given); | 
					
						
							|  |  |  | 			if (sizeof($values_given) != sizeof($values_unique)) { | 
					
						
							|  |  |  | 				$errors[] = array(_("This column is defined to include unique entries but duplicates were found:"), $columns[$i]['name']); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2004-09-27 19:13:06 +00:00
										 |  |  | 	// if input data is invalid just display error messages (max 50)
 | 
					
						
							|  |  |  | 	if (sizeof($errors) > 0) { | 
					
						
							|  |  |  | 		for ($i = 0; $i < sizeof($errors); $i++) StatusMessage("ERROR", $errors[$i][0], $errors[$i][1]); | 
					
						
							| 
									
										
										
										
											2011-12-20 20:48:04 +00:00
										 |  |  | 		massPrintBackButton($_POST['scope'], $selectedModules); | 
					
						
							| 
									
										
										
										
											2004-09-27 19:13:06 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-10-09 11:09:53 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	// let modules build accounts
 | 
					
						
							| 
									
										
										
										
											2004-09-27 19:13:06 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2010-02-15 20:21:44 +00:00
										 |  |  | 		$accounts = buildUploadAccounts($_POST['scope'], $data, $ids, $selectedModules); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 		if ($accounts != false) { | 
					
						
							| 
									
										
										
										
											2010-02-15 20:21:44 +00:00
										 |  |  | 			$rdnList = getRDNAttributes($_POST['scope'], $selectedModules); | 
					
						
							| 
									
										
										
										
											2009-11-27 18:49:56 +00:00
										 |  |  | 			$suffix = $_SESSION['config']->get_Suffix($_POST['scope']); | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 			// set DN
 | 
					
						
							|  |  |  | 			for ($i = 0; $i < sizeof($accounts); $i++) { | 
					
						
							| 
									
										
										
										
											2005-06-03 11:54:08 +00:00
										 |  |  | 				// check against list of possible RDN attributes
 | 
					
						
							| 
									
										
										
										
											2009-11-27 18:49:56 +00:00
										 |  |  | 				if (!in_array($data[$i][$ids['dn_rdn']], $rdnList)) { | 
					
						
							| 
									
										
										
										
											2005-06-03 11:54:08 +00:00
										 |  |  | 					$errors[] = array(_('Account %s:') . ' dn_rdn' . $accounts[$i][$data[$i][$ids['dn_rdn']]], _("Invalid RDN attribute!"), array($i)); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 				else { | 
					
						
							|  |  |  | 					$account_dn = $data[$i][$ids['dn_rdn']] . "=" . $accounts[$i][$data[$i][$ids['dn_rdn']]] . ","; | 
					
						
							| 
									
										
										
										
											2009-11-27 18:49:56 +00:00
										 |  |  | 					if ($data[$i][$ids['dn_suffix']] == "") $account_dn = $account_dn . $suffix; | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 					else $account_dn = $account_dn . $data[$i][$ids['dn_suffix']]; | 
					
						
							|  |  |  | 					$accounts[$i]['dn'] = $account_dn; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2004-10-10 11:16:34 +00:00
										 |  |  | 			// print errors if DN could not be built
 | 
					
						
							|  |  |  | 			if (sizeof($errors) > 0) { | 
					
						
							|  |  |  | 				for ($i = 0; $i < sizeof($errors); $i++) StatusMessage("ERROR", $errors[$i][0], $errors[$i][1], $errors[$i][2]); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				// store accounts in session
 | 
					
						
							|  |  |  | 				$_SESSION['mass_accounts'] = $_SESSION['ldap']->encrypt(serialize($accounts)); | 
					
						
							|  |  |  | 				$_SESSION['mass_counter'] = 0; | 
					
						
							|  |  |  | 				$_SESSION['mass_errors'] = array(); | 
					
						
							| 
									
										
										
										
											2004-10-19 18:18:46 +00:00
										 |  |  | 				$_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']; | 
					
						
							| 
									
										
										
										
											2010-02-16 17:32:48 +00:00
										 |  |  | 				$_SESSION['mass_selectedModules'] = $selectedModules; | 
					
						
							| 
									
										
										
										
											2004-10-10 11:16:34 +00:00
										 |  |  | 				// show links for upload and LDIF export
 | 
					
						
							| 
									
										
										
										
											2010-10-24 13:53:44 +00:00
										 |  |  | 				echo "<div class=\"title\">\n"; | 
					
						
							|  |  |  | 				echo "<h2 class=\"titleText\">" . _("LAM has checked your input and is now ready to create the accounts.") . "</h2>\n"; | 
					
						
							|  |  |  | 				echo "</div>"; | 
					
						
							| 
									
										
										
										
											2004-10-10 11:16:34 +00:00
										 |  |  | 				echo "<p> </p>\n"; | 
					
						
							| 
									
										
										
										
											2011-12-20 20:48:04 +00:00
										 |  |  | 				echo "<a id=\"uploadLink\" href=\"massDoUpload.php\">" . _("Upload accounts to LDAP") . "</a>"; | 
					
						
							|  |  |  | 				echo "    "; | 
					
						
							|  |  |  | 				echo "<a id=\"createLDIFLink\" href=\"massBuildAccounts.php?showldif=true\">" . _("Show LDIF file") . "</a>"; | 
					
						
							|  |  |  | 				?>
 | 
					
						
							|  |  |  | 				<script type="text/javascript"> | 
					
						
							|  |  |  | 				jQuery(document).ready(function() { | 
					
						
							|  |  |  | 					jQuery('#uploadLink').button(); | 
					
						
							|  |  |  | 					jQuery('#createLDIFLink').button(); | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 				</script> | 
					
						
							|  |  |  | 				<?php | 
					
						
							| 
									
										
										
										
											2004-10-10 11:16:34 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-11-28 13:29:05 +00:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			massPrintBackButton($_POST['scope'], $selectedModules); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-02-16 17:32:48 +00:00
										 |  |  | else { | 
					
						
							|  |  |  | 	StatusMessage('ERROR', _('Please provide a file to upload.')); | 
					
						
							| 
									
										
										
										
											2010-11-28 13:29:05 +00:00
										 |  |  | 	massPrintBackButton($_POST['scope'], $selectedModules); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:32:48 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-24 13:53:44 +00:00
										 |  |  | echo '</div>'; | 
					
						
							| 
									
										
										
										
											2010-08-21 09:43:52 +00:00
										 |  |  | include 'main_footer.php'; | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-28 13:29:05 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Prints a back button to the page where the user enters a file to upload. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param String $scope account type (e.g. user) | 
					
						
							|  |  |  |  * @param array $selectedModules selected modules for upload | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | function massPrintBackButton($scope, $selectedModules) { | 
					
						
							|  |  |  | 	echo '<form enctype="multipart/form-data" action="masscreate.php" method="post">'; | 
					
						
							|  |  |  | 	$container = new htmlTable(); | 
					
						
							|  |  |  | 	$container->addElement(new htmlSpacer(null, '10px'), true); | 
					
						
							|  |  |  | 	$container->addElement(new htmlButton('submit', _('Back'))); | 
					
						
							|  |  |  | 	$container->addElement(new htmlHiddenInput('type', $scope)); | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($selectedModules); $i++) { | 
					
						
							|  |  |  | 		$container->addElement(new htmlHiddenInput($scope . '_' . $selectedModules[$i], 'on')); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	$tabindex = 1; | 
					
						
							|  |  |  | 	parseHtml(null, $container, array(), false, $tabindex, $scope); | 
					
						
							|  |  |  | 	echo '</form>'; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-21 18:39:11 +00:00
										 |  |  | ?>
 |