LDAPAccountManager/lam/templates/massBuildAccounts.php

291 lines
10 KiB
PHP
Raw Normal View History

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/)
Copyright (C) 2004 - 2014 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
2012-08-13 17:43:48 +00:00
// check if this tool may be run
checkIfToolIsActive('toolFileUpload');
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++) {
2012-01-15 14:15:56 +00:00
if (strpos($keys[$k], 'INFO.') === 0) {
continue;
}
2004-09-21 18:39:11 +00:00
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';
2012-03-18 18:24:25 +00:00
$scope = htmlspecialchars($_POST['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();
}
2013-02-10 19:21:56 +00:00
echo '<form enctype="multipart/form-data" action="masscreate.php" method="post">';
2013-01-19 13:18:52 +00:00
echo '<div class="' . $scope . '-bright smallPaddingContent">';
2013-02-10 19:21:56 +00:00
$container = new htmlTable();
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
$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
2012-03-18 18:24:25 +00:00
$columns = getUploadColumns($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-09-21 18:39:11 +00:00
$errors = array();
// 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++) {
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']);
}
}
// check if all required attributes are given
2004-09-21 18:39:11 +00:00
$invalidColumns = array();
$id_names = array_keys($ids);
2014-09-21 15:06:11 +00:00
foreach ($checkcolumns as $checkcolumn) {
foreach ($data as $dataRow) {
if (empty($dataRow[$checkcolumn])) {
$invalidColumns[] = $id_names[$checkcolumn];
2004-09-21 18:39:11 +00:00
break;
}
}
}
2014-09-21 15:06:11 +00:00
foreach ($data as $dataRow) {
if (empty($dataRow[$ids['dn_rdn']])) {
2004-09-21 18:39:11 +00:00
$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."), "");
}
// check if values in unique columns are correct
for ($i = 0; $i < sizeof($columns); $i++) {
if (isset($columns[$i]['unique']) && ($columns[$i]['unique'] == true) && isset($ids[$columns[$i]['name']])) {
$colNumber = $ids[$columns[$i]['name']];
$values_given = array();
2014-09-21 15:06:11 +00:00
foreach ($data as $dataRow) {
$values_given[] = $dataRow[$colNumber];
}
$values_unique = array_unique($values_given);
if (sizeof($values_given) != sizeof($values_unique)) {
$duplicates = array();
foreach ($values_given as $key => $value) {
if (!isset($values_unique[$key])) {
$duplicates[] = htmlspecialchars($value);
}
}
$duplicates = array_values(array_unique($duplicates));
$errors[] = array(_("This column is defined to include unique entries but duplicates were found:") . ' ' . $columns[$i]['name'], implode(', ', $duplicates));
}
}
}
2004-09-27 19:13:06 +00:00
// if input data is invalid just display error messages (max 50)
if (sizeof($errors) > 0) {
2013-02-10 19:21:56 +00:00
for ($i = 0; $i < sizeof($errors); $i++) {
$container->addElement(new htmlStatusMessage("ERROR", $errors[$i][0], $errors[$i][1]), true);
}
$container->addElement(new htmlSpacer(null, '10px'), true);
massPrintBackButton($scope, $selectedModules, $container);
2004-09-27 19:13:06 +00:00
}
2004-09-21 18:39:11 +00:00
// let modules build accounts
2004-09-27 19:13:06 +00:00
else {
2012-03-18 18:24:25 +00:00
$accounts = buildUploadAccounts($scope, $data, $ids, $selectedModules);
2004-09-21 18:39:11 +00:00
if ($accounts != false) {
2012-03-18 18:24:25 +00:00
$rdnList = getRDNAttributes($scope, $selectedModules);
$suffix = $_SESSION['config']->get_Suffix($scope);
2004-09-21 18:39:11 +00:00
// set DN
2014-09-21 15:06:11 +00:00
foreach ($accounts as $i => $account) {
// check against list of possible RDN attributes
2009-11-27 18:49:56 +00:00
if (!in_array($data[$i][$ids['dn_rdn']], $rdnList)) {
2014-09-21 15:06:11 +00:00
$errors[] = array(_('Account %s:') . ' dn_rdn ' . $account[$data[$i][$ids['dn_rdn']]], _("Invalid RDN attribute!"), array($i));
}
2004-09-21 18:39:11 +00:00
else {
2014-09-21 15:06:11 +00:00
$account_dn = $data[$i][$ids['dn_rdn']] . "=" . $account[$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']];
2014-09-21 15:06:11 +00:00
$account['dn'] = $account_dn;
2004-09-21 18:39:11 +00:00
}
}
// print errors if DN could not be built
if (sizeof($errors) > 0) {
2013-02-10 19:21:56 +00:00
for ($i = 0; $i < sizeof($errors); $i++) {
$container->addElement(new htmlStatusMessage("ERROR", $errors[$i][0], $errors[$i][1], $errors[$i][2]), true);
}
}
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;
2012-03-18 18:24:25 +00:00
$_SESSION['mass_scope'] = $scope;
$_SESSION['mass_selectedModules'] = $selectedModules;
2012-02-05 10:38:59 +00:00
if (isset($_SESSION['mass_pdf'])) {
unset($_SESSION['mass_pdf']);
}
if (isset($_POST['createPDF']) && ($_POST['createPDF'] == 'on')) {
$_SESSION['mass_pdf']['structure'] = $_POST['pdfStructure'];
$_SESSION['mass_pdf']['counter'] = 0;
2013-07-21 11:34:31 +00:00
$_SESSION['mass_pdf']['file'] = '../tmp/lam_pdf' . getRandomNumber() . '.zip';
2012-02-05 10:38:59 +00:00
}
else {
$_SESSION['mass_pdf']['structure'] = null;
}
// show links for upload and LDIF export
2013-02-10 19:21:56 +00:00
$container->addElement(new htmlTitle(_("LAM has checked your input and is now ready to create the accounts.")), true);
$container->addElement(new htmlSpacer(null, '10px'), true);
$buttonContainer = new htmlTable();
$buttonContainer->addElement(new htmlLink(_("Upload accounts to LDAP"), 'massDoUpload.php', '../graphics/up.gif', true));
$buttonContainer->addElement(new htmlLink(_("Show LDIF file"), 'massBuildAccounts.php?showldif=true', '../graphics/edit.png', true));
$buttonContainer->addElement(new htmlSpacer('10px', null));
massPrintBackButton($scope, $selectedModules, $buttonContainer);
$container->addElement($buttonContainer, true);
}
2004-09-21 18:39:11 +00:00
}
2010-11-28 13:29:05 +00:00
else {
2013-02-10 19:21:56 +00:00
$container->addElement(new htmlSpacer(null, '10px'), true);
massPrintBackButton($scope, $selectedModules, $container);
2010-11-28 13:29:05 +00:00
}
2004-09-21 18:39:11 +00:00
}
}
else {
2013-02-10 19:21:56 +00:00
$container->addElement(new htmlStatusMessage('ERROR', _('Please provide a file to upload.')), true);
$container->addElement(new htmlSpacer(null, '10px'), true);
massPrintBackButton($scope, $selectedModules, $container);
}
2004-09-21 18:39:11 +00:00
2013-02-10 19:21:56 +00:00
$tabindex = 1;
parseHtml(null, $container, array(), false, $tabindex, $scope);
2010-10-24 13:53:44 +00:00
echo '</div>';
2013-02-10 19:21:56 +00:00
echo '</form>';
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
2013-02-10 19:21:56 +00:00
* @param htmlTable $container table container
2010-11-28 13:29:05 +00:00
*/
2013-02-10 19:21:56 +00:00
function massPrintBackButton($scope, $selectedModules, &$container) {
$backButton = new htmlButton('submit', _('Back'));
$backButton->setIconClass('backButton');
$container->addElement($backButton);
2010-11-28 13:29:05 +00:00
$container->addElement(new htmlHiddenInput('type', $scope));
2012-02-05 10:38:59 +00:00
$createPDF = 0;
if (isset($_POST['createPDF']) && ($_POST['createPDF'] == 'on')) {
$createPDF = 1;
}
$container->addElement(new htmlHiddenInput('createPDF', $createPDF));
$container->addElement(new htmlHiddenInput('pdfStructure', $_POST['pdfStructure']));
2010-11-28 13:29:05 +00:00
for ($i = 0; $i < sizeof($selectedModules); $i++) {
$container->addElement(new htmlHiddenInput($scope . '_' . $selectedModules[$i], 'on'));
}
}
2004-09-21 18:39:11 +00:00
?>