Logo Search packages:      
Sourcecode: ldap-account-manager version File versions

massdetail.php

<?php
/*
$Id: massdetail.php,v 1.4 2004/05/19 16:56:58 gruberroland Exp $

  This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam)
  Copyright (C) 2003  Tilo Lutz

  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


  LDAP Account Manager displays table for creating or modifying accounts in LDAP
*/

// include all needed files
include_once('../lib/account.inc'); // File with all account-funtions
include_once('../lib/config.inc'); // File with configure-functions
include_once('../lib/profiles.inc'); // functions to load and save profiles
include_once('../lib/status.inc'); // Return error-message
include_once('../lib/pdf.inc'); // Return a pdf-file
include_once('../lib/ldap.inc'); // LDAP-functions

// Start Session
session_save_path('../sess');
@session_start();

// Redirect to startpage if user is not loged in
if (!isset($_SESSION['loggedIn'])) {
      metaRefresh("login.php");
      die;
      }

// Set correct language, codepages, ....
setlanguage();

if (isset($_GET['row'])) {
      // Startcondition massdetail.php was called from masscreate.php
      // $row the the position of the useraccount in an array of account-objects
      $row = $_GET['row'];
      /* $select chooses which kind of page should be displayed
      * detail = Show settings which are individuel for every user. These
      *          settings can be changed
      * info = Show all infos about user
      * warn = Show all warning about user
      * error = Show all errors about user
      */
      $select = $_GET['type'];
      // Get Copy of current account so we can undo all settings
      if ($select=='detail') $_SESSION['mass_accounts_backup'] = $_SESSION['mass_accounts'][$row];
      }

if (isset($_POST['row'])) {
      // massdetail.php was called from itself
      // $row the the position of the useraccount in an array of account-objects
      $row = (int) $_POST['row'];
      }

// Undo-Button was pressed.
if ($_POST['undo']) {
      $_SESSION['mass_accounts'][$row] = $_SESSION['mass_accounts_backup'];
      $errors2[] = array('INFO', _('Undo'), _('All changes were reseted'));
      $select = 'detail';
      }

// Apply-Button was pressed.
if ($_POST['apply']) {
      // Show Detail-page
      $select = 'detail';
      // Check if surname is valid
      if ( !eregi('^([a-z φόδί-])+$', $_POST['f_general_surname'])) $errors2[] = array('ERROR', _('Surname'), _('Surname contains invalid characters'));
            else $_SESSION['mass_accounts'][$row]->general_surname = $_POST['f_general_surname'];
      // Check if givenname is valid
      if ( !eregi('^([a-z φόδί-])+$', $_POST['f_general_givenname'])) $errors2[] = array('ERROR', _('Given name'), _('Given name contains invalid characters'));
            else $_SESSION['mass_accounts'][$row]->general_givenname = $_POST['f_general_givenname'];
      // Check if username is valid
      if ( !eregi('^([a-z]|[0-9]|[.]|[-]|[_])*$', $_POST['f_general_username']))
            $errors2[] = array('ERROR', _('Username'), _('Username contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !'));
      else if ( !ereg('^([a-z]|[A-Z]).*$', $_POST['f_general_username']))
            $errors2[] = array('ERROR', _('Name'), _('Name contains invalid characters. First character must be a letter.'));
      else {
            // Create Array with all users in ldap and in array
            // Validate cache-array
            ldapreload('user');
            // Get List with all existing usernames
            foreach ($_SESSION['userDN'] as $user_array) $users[] = $user_array['uid'];
            // Get List with all users in array
            foreach ($_SESSION['mass_accounts'] as $user_array) $users[] = $user_array->general_username;
            // unset old username in user-array
            $users = @array_flip($users);
            unset ($users[$_SESSION['mass_accounts'][$row]->general_username]);
            $users = array_flip($users);
            // Store new username
            $_SESSION['mass_accounts'][$row]->general_username = $_POST['f_general_username'];
                  // Set all usernames to unique usernames
            while (in_array($_SESSION['mass_accounts'][$row2]->general_username, $users)) {
                  // get last character of username
                  $lastchar = substr($_SESSION['mass_accounts'][$row2]->general_username, strlen($_SESSION['mass_accounts'][$row2]->general_username)-1, 1);
                  // Last character is no number
                  if ( !ereg('^([0-9])+$', $lastchar))
                        /* Last character is no number. Therefore we only have to
                        * add "2" to it.
                        */
                        $_SESSION['mass_accounts'][$row2]->general_username = $_SESSION['mass_accounts'][$row2]->general_username . '2';
                   else {
                        /* Last character is a number -> we have to increase the number until we've
                        * found a groupname with trailing number which is not in use.
                        *
                        * $i will show us were we have to split groupname so we get a part
                        * with the groupname and a part with the trailing number
                        */
                        $i=strlen($_SESSION['mass_accounts'][$row2]->general_username)-1;
                        $mark = false;
                        // Set $i to the last character which is a number in $account_new->general_username
                        while (!$mark) {
                              if (ereg('^([0-9])+$',substr($_SESSION['mass_accounts'][$row2]->general_username, $i, strlen($_SESSION['mass_accounts'][$row2]->general_username)-$i))) $i--;
                                    else $mark=true;
                              }
                        // increase last number with one
                        $firstchars = substr($_SESSION['mass_accounts'][$row2]->general_username, 0, $i+1);
                        $lastchars = substr($_SESSION['mass_accounts'][$row2]->general_username, $i+1, strlen($_SESSION['mass_accounts'][$row2]->general_username)-$i);
                        // Put username together
                        $_SESSION['mass_accounts'][$row2]->general_username = $firstchars . (intval($lastchars)+1);
                        }
                        // Show warning if lam has changed username
                        $errors2[] = array('WARN', _('Username'), _('Username in use. Selected next free username.'));
                  }
            }
      // Check personal settings
      if ( !eregi('^([a-z φόδί\\.-])*$', $_POST['f_personal_title']))  $errors2[] = array('ERROR', _('Job title'), _('Please enter a valid job title!'));
            else $_SESSION['mass_accounts'][$row]->personal_title = $_POST['f_personal_title'];
      if ( !eregi('^([a-z0-9 φόδί\\.-])*$', $_POST['f_personal_employeeType']))  $errors2[] = array('ERROR', _('Employee type'), _('Please enter a valid employee type!'));
            else $_SESSION['mass_accounts'][$row]->personal_employeeType = $_POST['f_personal_employeeType'];
      if ( !eregi('^([a-z0-9 φόδί\\.-])*$', $_POST['f_personal_street']))  $errors2[] = array('ERROR', _('Street'), _('Please enter a valid street name!'));
            else $_SESSION['mass_accounts'][$row]->personal_street = $_POST['f_personal_street'];
      if ( !ereg('^([0-9]|[A-Z]|[a-z])*$', $_POST['f_personal_postalCode']))  $errors2[] = array('ERROR', _('Postal code'), _('Please enter a valid postal code!'));
            else $_SESSION['mass_accounts'][$row]->personal_postalCode = $_POST['f_personal_postalCode'];
      if ( !eregi('^([a-z φόδί\\.-])*$', $_POST['f_personal_postalAddress']))  $errors2[] = array('ERROR', _('Postal address'), _('Please enter a valid postal address!'));
            else $_SESSION['mass_accounts'][$row]->personal_postalAddress = $_POST['f_personal_postalAddress'];
      if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_POST['f_personal_telephoneNumber']))  $errors2[] = array('ERROR', _('Telephone number'), _('Please enter a valid telephone number!'));
            else $_SESSION['mass_accounts'][$row]->personal_telephoneNumber = $_POST['f_personal_telephoneNumber'];
      if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_POST['f_personal_mobileTelephoneNumber']))  $errors2[] = array('ERROR', _('Mobile number'), _('Please enter a valid mobile number!'));
            else $_SESSION['mass_accounts'][$row]->personal_mobileTelephoneNumber = $_POST['f_personal_mobileTelephoneNumber'];
      if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_POST['f_personal_facsimileTelephoneNumber']))  $errors2[] = array('ERROR', _('Fax number'), _('Please enter a valid fax number!'));
            else $_SESSION['mass_accounts'][$row]->personal_facsimileTelephoneNumber = $_POST['f_personal_facsimileTelephoneNumber'];
      if ( !ereg('^(([0-9]|[A-Z]|[a-z]|[.]|[-]|[_])+[@]([0-9]|[A-Z]|[a-z]|[-])+([.]([0-9]|[A-Z]|[a-z]|[-])+)*)*$', $_POST['f_personal_mail']))  $errors2[] = array('ERROR', _('eMail address'), _('Please enter a valid eMail address!'));
            else $_SESSION['mass_accounts'][$row]->personal_mail = $_POST['f_personal_mail'];
      }

// Print header and part of body
echo $_SESSION['header'];
echo  '<title>';
echo _('Create new accounts');
echo '</title>'.
      '<link rel="stylesheet" type="text/css" href="../style/layout.css">'.
      '</head><body>'.
      '<form enctype="multipart/form-data" action="massdetail.php" method="post">';
// Display errir-messages
if (is_array($errors2))
      for ($i=0; $i<sizeof($errors2); $i++) StatusMessage($errors2[$i][0], $errors2[$i][1], $errors2[$i][2]);


switch ($select) {
      /* $select chooses which kind of page should be displayed
      * detail = Show settings which are individuel for every user. These
      *          settings can be changed
      * info = Show all infos about user
      * warn = Show all warning about user
      * error = Show all errors about user
      */
      case 'error':
            for ($i=0; $i<sizeof($_SESSION['mass_errors'][$row]); $i++)
                  if ($_SESSION['mass_errors'][$row][$i][0] == 'ERROR')
                        StatusMessage('ERROR', _('Invalid Value!'), $_SESSION['mass_errors'][$row][$i][2]);
            break;
      case 'info':
            for ($i=0; $i<sizeof($_SESSION['mass_errors'][$row]); $i++)
                  if ($_SESSION['mass_errors'][$row][$i][0] == 'INFO')
                        StatusMessage('INFO', _('Check values.'), $_SESSION['mass_errors'][$row][$i][2]);
            break;
      case 'warn':
            for ($i=0; $i<sizeof($_SESSION['mass_errors'][$row]); $i++)
                  if ($_SESSION['mass_errors'][$row][$i][0] == 'WARN')
                        StatusMessage('WARN', _('Check values.'), $_SESSION['mass_errors'][$row][$i][2]);
            break;
      case 'detail':
            echo '<table class="massdetail" width="100%">';
            // Store variabled in $_POST
            echo '<tr><td><input name="type" type="hidden" value="'.$select.'"></td></tr>';
            echo '<tr><td><input name="row" type="hidden" value="'.$row.'"></td></tr>';
            echo '<tr><td>';
            echo _('Surname').'*';
            echo '</td>'."\n".'<td>'.
                  '<input name="f_general_surname" type="text" size="20" maxlength="20" value="' . $_SESSION['mass_accounts'][$row]->general_surname . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=424" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Given name').'*';
            echo '</td>'."\n".'<td>'.
                  '<input name="f_general_givenname" type="text" size="20" maxlength="20" value="' . $_SESSION['mass_accounts'][$row]->general_givenname . '">'.
                  '</td>'."\n".'<td>'.
                  '<a href="help.php?HelpNumber=425" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Username').'*';
            echo "</td>\n<td>".
                  '<input name="f_general_username" type="text" size="20" maxlength="20" value="' . $_SESSION['mass_accounts'][$row]->general_username . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=400" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Job title');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_title" type="text" size="10" maxlength="10" value="' . $_SESSION['mass_accounts'][$row]->personal_title . '"> ';
            echo $_SESSION['mass_accounts']->general_surname . ' ' . $_SESSION['mass_accounts']->general_givenname . '</td><td>'.
                  '<a href="help.php?HelpNumber=448" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Employee type');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_employeeType" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_employeeType . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=449" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Street');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_street" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_street . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=450" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Postal code');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_postalCode" type="text" size="5" maxlength="5" value="' . $_SESSION['mass_accounts'][$row]->personal_postalCode . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=451" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Postal address');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_postalAddress" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_postalAddress . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=452" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Telephone number');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_telephoneNumber" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_telephoneNumber . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=453" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Mobile number');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_mobileTelephoneNumber" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_mobileTelephoneNumber . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=454" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('Fax number');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_facsimileTelephoneNumber" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_facsimileTelephoneNumber . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=455" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr>'."\n".'<tr><td>';
            echo _('eMail address');
            echo '</td>'."\n".'<td>'.
                  '<input name="f_personal_mail" type="text" size="30" maxlength="30" value="' . $_SESSION['mass_accounts'][$row]->personal_mail . '">'.
                  '</td><td>'.
                  '<a href="help.php?HelpNumber=456" target="lamhelp">'._('Help').'</a>'.
                  '</td></tr></table>';
            echo '<p><input name="apply" type="submit" value="'; echo _('Apply'); echo '">';
            echo '&nbsp;<input name="undo" type="submit" value="'; echo _('Undo'); echo '">';
            break;
      }

// Print end of HTML-Page
echo '</form></body></html>';
?>

Generated by  Doxygen 1.6.0   Back to index