0)) $select = 'list'; else if ($_POST['list2']) $select = 'list2'; else if ($_POST['back']) $select = 'main'; else if ($_POST['cancel']) $select = 'cancel'; else if ($_POST['create']) $select = 'create'; else if ($_POST['pdf']) { createUserPDF($_SESSION['accounts']); $select='pdf'; } } if ($select!='pdf') { // Write HTML-Header and part of Table echo $_SESSION['header']; echo ''; echo _('Create new Accounts'); echo ''."\n". ''."\n". ''."\n". ''."\n"; switch ($select) { case 'cancel': if ( isset($_SESSION['accounts'])) unset($_SESSION['accounts']); if ( isset($_SESSION['pointer'])) unset($_SESSION['pointer']); if ( isset($_SESSION['errors'])) unset($_SESSION['errors']); echo ''."\n". ''."\n". '
'."\n". ''; echo _('Please press here if meta-refresh didn\'t work.'); echo "\n"; break; case 'create': if ($_SESSION['pointer'] < sizeof($_SESSION['accounts'])) { $refresh = get_cfg_var('max_execution_time')-5; echo ''."\n"; } echo ''."\n". ''."\n". "
"; echo _('Creating users. Please stand by ....'); echo "\n\n"; $stay=true; while (($_SESSION['pointer'] < sizeof($_SESSION['accounts'])) && $stay) { if ($_SESSION['accounts'][$_SESSION['pointer']]->general_username!='') { if (getgid($_SESSION['accounts'][$_SESSION['pointer']]->general_group)==-1) { $group = new account(); $group->general_username=$_SESSION['accounts'][$_SESSION['pointer']]->general_group; $group->general_uidNumber=checkid($_SESSION['accounts'][$_SESSION['pointer']], 'group'); $group->general_gecos=$_SESSION['accounts'][$_SESSION['pointer']]->general_group; $group->general_dn=$_SESSION['config']->get_GroupSuffix(); creategroup($group); } $_SESSION['accounts'][$_SESSION['pointer']]->general_uidNumber = checkid($_SESSION['accounts'][$_SESSION['pointer']], 'user'); $iv = base64_decode($_COOKIE["IV"]); $key = base64_decode($_COOKIE["Key"]); $_SESSION['accounts'][$_SESSION['pointer']]->unix_password = base64_encode(mcrypt_encrypt( MCRYPT_RIJNDAEL_256, $key, genpasswd(), MCRYPT_MODE_ECB, $iv)); $_SESSION['accounts'][$_SESSION['pointer']]->smb_password = $_SESSION['accounts'][$_SESSION['pointer']]->unix_password; if ( (time()-$time)<(get_cfg_var('max_execution_time')-10)) { $error = createuser($_SESSION['accounts'][$_SESSION['pointer']]); if ($error==1) { $_SESSION['pointer']++; echo ''."\n"; } else { $stay = false; StatusMessage('ERROR', _('Could not create user!'), sprintf (_('Was unable to create %s.'), $_SESSION['accounts'][$row]->general_username)); } } else $stay=false; } else $_SESSION['pointer']++; } if (!$stay) { echo ''."\n"; echo '
'; sprintf (_('Created user %s.'), $_SESSION['accounts'][$_SESSION['pointer']]->general_username); echo '
'; echo _('Please press here if meta-refresh didn\'t work.'); echo '
'; echo "
\n"; } else { echo ''; echo _('All Users have been created'); echo ''."\n".''; echo ''; echo ''; echo ''."\n\n"; if ( isset($_SESSION['pointer'])) unset($_SESSION['pointer']); if ( isset($_SESSION['errors'])) unset($_SESSION['errors']); } break; case 'list': if (!is_array($accounts)) $accounts = array(); $groups = array(); if (loadfile()) { echo ''."\n". ''."\n". ''."\n". ''; echo _('Please press here if meta-refresh didn\'t work.'); echo "\n"; } else { //echo ''."\n". echo ''."\n". ''."\n". ''. ''."\n"; echo '
'; echo _('Max 400 users allowed. Ignored additional users.'); echo '
'; echo _('Cancel'); echo ''; echo _('Contiune'); echo "
\n"; } break; case 'list2': echo ''."\n". ''."\n". ''; for ($i=0; $igeneral_group!='') StatusMessage('INFO', _('Group').' '. $_SESSION['accounts'][$i]->general_group.' '._('not found!'), _('It will be created.')); echo "
\n". "
"; echo _('Confirm List'); echo "\n\n"; echo ''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n"; if (!isset($_SESSION['rowstart'])) $_SESSION['rowstart'] = 0; //if (sizeof($_SESSION['accounts'])<($_SESSION['rowstart']+10)) $end = sizeof($_SESSION['accounts']); // else $end = $_SESSION['rowstart']+10; $end = sizeof($_SESSION['accounts']); for ($row=0; $row<$end; $row++) { // loops for every row echo ''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n"; } $noerrors=true; for ($i=0; $i'; if (!$noerrors) { echo ''."\n"; } if (!$nowarn) { echo ''."\n"; } echo '
'._('row').''. _('Surname'). ''. _('Given name'). ''. _('User name'). ''. _('Primary group'). ''. _('Details'). '' . _('Infos'). '' . _('Warnings'). '' . _('Errors') . '
'.$row.''. $_SESSION['accounts'][$row]->general_surname.''. $_SESSION['accounts'][$row]->general_givenname.''. $_SESSION['accounts'][$row]->general_username.''. $_SESSION['accounts'][$row]->general_group.''. ''._('Show Details.').''; $found=false; for ($i=0; $i'._('Show Infos.').''; echo ''; $found=false; for ($i=0; $i'._('Show Warnings.').''; echo ''; $found=false; for ($i=0; $i'._('Show Errors.').''; echo '
'. _('There are some errors.') . '
'. _('There are some warnings.') . '
'; echo "
"; echo _('Please select page'); echo "\n\n". ''."\n"."
'; if ($noerrors) { echo ''; } echo '
\n
"; break; case 'main': if ( isset($_SESSION['accounts'])) unset($_SESSION['accounts']); if ( isset($_SESSION['pointer'])) unset($_SESSION['pointer']); if ( isset($_SESSION['errors'])) unset($_SESSION['errors']); $_SESSION['pointer']=0; $profilelist = getUserProfiles(); echo ''."\n". ''."\n". "
"; echo _('Mass Creation'); echo "\n\n\n
"; echo _('Please provide a csv-file with the following syntax. Values with * are required:'); echo '
'. ''. ''."\n".''."\n".'\n'."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".''."\n".'
'."\n"; echo _('Surname').'*,'; echo ''; echo _('Given name').'*,'; echo ''; echo _('Username').'*,'; echo ""; echo _('Primary group').','; echo ''; echo _('Title').','; echo ''; echo _('eMail address').','; echo ''; echo _('Telephone number').','; echo '
'; echo _('Mobile number').','; echo ''; echo _('Fax number').','; echo ''; echo _('Street').','; echo ''; echo _('Postal code').','; echo ''; echo _('Postal address').','; echo ''; echo _('Employee type'); echo '<CR>'; echo '
'; echo "
"; echo _('If Primary group is not given it\'ll used from profile.'); echo "
"; echo _('If Primary group does not exist it will be created.'); echo "
\n"; echo "
"; echo _('Select settings'); echo "\n". '\n\n\n'."\n".''."\n". ''."\n"."
'."\n"; echo _('Select Profile:'); echo ''; echo ""; echo _('Help')."
"; echo _('Suffix'); echo ''._('Help').''. '
'."\n". ''; echo _('Select file:'); echo '
'."\n". '
\n
\n"; break; } echo '
'; } function loadfile() { if ($_FILES['userfile']['size']>0) { $handle = fopen($_FILES['userfile']['tmp_name'], 'r'); $profile = loadUserProfile($_POST['f_selectprofile']) ; for ($row=0; $line_array=fgetcsv($handle,2048); $row++) { // loops for every row $iv = base64_decode($_COOKIE["IV"]); $key = base64_decode($_COOKIE["Key"]); $_SESSION['accounts'][$row] = $profile; $_SESSION['accounts'][$row]->general_dn = $_POST['f_general_suffix']; if ($line_array[0]) $_SESSION['accounts'][$row]->general_surname = $line_array[0]; if ($line_array[1]) $_SESSION['accounts'][$row]->general_givenname = $line_array[1]; if ($line_array[2]) $_SESSION['accounts'][$row]->general_username = $line_array[2]; if ($line_array[3]) $_SESSION['accounts'][$row]->general_group = $line_array[3]; if ($line_array[4]) $_SESSION['accounts'][$row]->personal_title = $line_array[4]; if ($line_array[5]) $_SESSION['accounts'][$row]->personal_mail = $line_array[5]; if ($line_array[6]) $_SESSION['accounts'][$row]->personal_telephoneNumber = $line_array[6]; if ($line_array[7]) $_SESSION['accounts'][$row]->personal_mobileTelephoneNumber = $line_array[7]; if ($line_array[8]) $_SESSION['accounts'][$row]->personal_facsimileTelephoneNumber = $line_array[8]; if ($line_array[9]) $_SESSION['accounts'][$row]->personal_street = $line_array[9]; if ($line_array[10]) $_SESSION['accounts'][$row]->personal_postalCode = $line_array[10]; if ($line_array[11]) $_SESSION['accounts'][$row]->personal_postalAddress = $line_array[11]; if ($line_array[12]) $_SESSION['accounts'][$row]->personal_employeeType = $line_array[12]; $_SESSION['accounts'][$row]->unix_password = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, genpasswd(), MCRYPT_MODE_ECB, $iv)); $_SESSION['accounts'][$row]->smb_password=$_SESSION['accounts'][$row]->unix_password; } } for ($row2=0; $row2"; if ($row2<401) { for ($i=$row2+1; $igeneral_username == $_SESSION['accounts'][$i]->general_username) { // Found user with same name print $row2."-".$i."
"; print $_SESSION['accounts'][$row2]->general_username ."-". $_SESSION['accounts'][$i]->general_username ."
"; // Found user with same name // get last character of username if (!is_numeric($_SESSION['accounts'][$i]->general_username{strlen($_SESSION['accounts'][$i]->general_username)-1})) $_SESSION['accounts'][$i]->general_username = $_SESSION['accounts'][$i]->general_username . '2'; else { // Get interger-end of string hello456 -> hello + 456 $start = strlen($_SESSION['accounts'][$i]->general_username)-1; while (is_numeric(substr($_SESSION['accounts'][$i]->general_username, $start))) $start--; // Increse rusultung number $first = substr($_SESSION['accounts'][$i]->general_username, 0, $start+1); $second = intval(substr($_SESSION['accounts'][$i]->general_username, $start+1))+1; $_SESSION['accounts'][$i]->general_username = $first . $second; } while ($temp = ldapexists($_SESSION['accounts'][$i], 'user')) { // Get interger-end of string hello456 -> hello + 456 $start = strlen($_SESSION['accounts'][$i]->general_username)-1; while (is_numeric(substr($_SESSION['accounts'][$i]->general_username, $start))) $start--; // Increse rusultung number $first = substr($_SESSION['accounts'][$i]->general_username, 0, $start+1); $second = intval(substr($_SESSION['accounts'][$i]->general_username, $start+1))+1; $_SESSION['accounts'][$i]->general_username = $first . $second; } } print $_SESSION['accounts'][$row2]->general_username ."-". $_SESSION['accounts'][$i]->general_username ."
"; // Found user with same name } if ($values->general_username != $return->general_username) $error[] = array('WARN', _('Username'), _('Username in use. Selected next free username.')); $_SESSION['errors'][$row2] = array_merge($_SESSION['errors'][$row2], $error); // Check if Homedir is valid $_SESSION['accounts'][$row2]->general_homedir = str_replace('$group', $_SESSION['accounts'][$row2]->general_group, $_SESSION['accounts'][$row2]->general_homedir); if ($_SESSION['accounts'][$row2]->general_username != '') $_SESSION['accounts'][$row2]->general_homedir = str_replace('$user', $_SESSION['accounts'][$row2]->general_username, $_SESSION['accounts'][$row2]->general_homedir); if ( !ereg('^[/]([a-z]|[A-Z])([a-z]|[A-Z]|[0-9]|[.]|[-]|[_])*([/]([a-z]|[A-Z])([a-z]|[A-Z]|[0-9]|[.]|[-]|[_])*)*$', $_SESSION['accounts'][$row2]->general_homedir )) $errors[] = array('ERROR', _('Home directory'), _('Homedirectory contains invalid characters.')); // Check if givenname is valid if ( !ereg('^([a-z]|[A-Z]|[-]|[ ]|[ä]|[Ä]|[ö]|[Ö]|[ü]|[Ü]|[ß])+$', $_SESSION['accounts'][$row2]->general_givenname)) $errors[] = array('ERROR', _('Given name'), _('Given name contains invalid characters')); // Check if surname is valid if ( !ereg('^([a-z]|[A-Z]|[-]|[ ]|[ä]|[Ä]|[ö]|[Ö]|[ü]|[Ü]|[ß])+$', $_SESSION['accounts'][$row2]->general_surname)) $errors[] = array('ERROR', _('Surname'), _('Surname contains invalid characters')); if ( ($_SESSION['accounts'][$row2]->general_gecos=='') || ($_SESSION['accounts'][$row2]->general_gecos==' ')) { $_SESSION['accounts'][$row2]->general_gecos = $_SESSION['accounts'][$row2]->general_givenname . " " . $_SESSION['accounts'][$row2]->general_surname ; $errors[] = array('INFO', _('Gecos'), _('Inserted sur- and given name in gecos-field.')); } if ($_SESSION['accounts'][$row2]->general_group=='') $errors[] = array('ERROR', _('Primary group'), _('No primary group defined!')); // Check if Username contains only valid characters if ( !ereg('^([a-z]|[0-9]|[.]|[-]|[_])*$', $_SESSION['accounts'][$row2]->general_username)) $errors[] = array('ERROR', _('Username'), _('Username contains invalid characters. Valid characters are: a-z, 0-9 and .-_ !')); // Check if user already exists if (isset($_SESSION['accounts'][$row2]->general_groupadd) && in_array($_SESSION['accounts'][$row2]->general_group, $_SESSION['accounts'][$row2]->general_groupadd)) { for ($i=0; $igeneral_groupadd); $i++ ) if ($_SESSION['accounts'][$row2]->general_groupadd[$i] == $_SESSION['accounts'][$row2]->general_group) { unset ($_SESSION['accounts'][$row2]->general_groupadd[$i]); $_SESSION['accounts'][$row2]->general_groupadd = array_values($_SESSION['accounts'][$row2]->general_groupadd); } } // Create automatic useraccount with number if original user already exists // Reset name to original name if new name is in use while ($temp = ldapexists($_SESSION['accounts'][$row2], 'user')) { // get last character of username $lastchar = substr($_SESSION['accounts'][$row2]->general_username, strlen($_SESSION['accounts'][$row2]->general_username)-1, 1); // Last character is no number if ( !ereg('^([0-9])+$', $lastchar)) $_SESSION['accounts'][$row2]->general_username = $_SESSION['accounts'][$row2]->general_username . '2'; else { $i=strlen($_SESSION['accounts'][$row2]->general_username)-1; $mark = false; while (!$mark) { if (ereg('^([0-9])+$',substr($_SESSION['accounts'][$row2]->general_username, $i, strlen($_SESSION['accounts'][$row2]->general_username)-$i))) $i--; else $mark=true; } // increase last number with one $firstchars = substr($_SESSION['accounts'][$row2]->general_username, 0, $i+1); $lastchars = substr($_SESSION['accounts'][$row2]->general_username, $i+1, strlen($_SESSION['accounts'][$row2]->general_username)-$i); $_SESSION['accounts'][$row2]->general_username = $firstchars . (intval($lastchars)+1); } } // Check if UID is valid. If none value was entered, the next useable value will be inserted //$_SESSION['accounts'][$row2]->general_uidNumber = ''; if (is_object($_SESSION['accounts'][$row2-1])) $_SESSION['accounts'][$row2]->general_uidNumber = $_SESSION['accounts'][$row2-1]->general_uidNumber+1; $_SESSION['accounts'][$row2]->general_uidNumber = checkid($_SESSION['accounts'][$row2], 'user'); while (is_string($_SESSION['accounts'][$row2]->general_uidNumber)) { // true if checkid has returned an error $_SESSION['accounts'][$row2]->general_uidNumber = $_SESSION['accounts'][$row2]->general_uidNumber+1; unset($_SESSION['accounts'][$row2]->general_uidNumber); $_SESSION['accounts'][$row2]->general_uidNumber = checkid($_SESSION['accounts'][$row2], 'user'); } // Check if Name-length is OK. minLength=3, maxLength=20 if ( !ereg('.{3,20}', $_SESSION['accounts'][$row2]->general_username)) $errors[] = array('ERROR', _('Name'), _('Name must contain between 3 and 20 characters.')); // Check if Name starts with letter if ( !ereg('^([a-z]|[A-Z]).*$', $_SESSION['accounts'][$row2]->general_username)) $errors[] = array('ERROR', _('Name'), _('Name contains invalid characters. First character must be a letter')); $_SESSION['errors'][$row2] = array_merge($_SESSION['errors'][$row2], $errors); if (isset($errors)) unset ($errors); if ($_SESSION['accounts'][$row2]->unix_password != '') { $iv = base64_decode($_COOKIE["IV"]); $key = base64_decode($_COOKIE["Key"]); $password = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, base64_decode($_SESSION['accounts'][$row2]->unix_password), MCRYPT_MODE_ECB, $iv); $password = str_replace(chr(00), '', $password); } if (!ereg('^([a-z]|[A-Z]|[0-9]|[\|]|[\#]|[\*]|[\,]|[\.]|[\;]|[\:]|[\_]|[\-]|[\+]|[\!]|[\%]|[\&]|[\/]|[\?]|[\{]|[\[]|[\(]|[\)]|[\]]|[\}])*$', $password)) $errors[] = array('ERROR', _('Password'), _('Password contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and #*,.;:_-+!$%&/|?{[()]}= !')); if ( !ereg('^([0-9])*$', $_SESSION['accounts'][$row2]->unix_pwdminage)) $errors[] = array('ERROR', _('Password minage'), _('Password minage must be are natural number.')); if ( $_SESSION['accounts'][$row2]->unix_pwdminage > $_SESSION['accounts'][$row2]->unix_pwdmaxage ) $errors[] = array('ERROR', _('Password maxage'), _('Password maxage must bigger as Password Minage.')); if ( !ereg('^([0-9]*)$', $_SESSION['accounts'][$row2]->unix_pwdmaxage)) $errors[] = array('ERROR', _('Password maxage'), _('Password maxage must be are natural number.')); if ( !ereg('^(([-][1])|([0-9]*))$', $_SESSION['accounts'][$row2]->unix_pwdallowlogin)) $errors[] = array('ERROR', _('Password Expire'), _('Password expire must be are natural number or -1.')); if ( !ereg('^([0-9]*)$', $_SESSION['accounts'][$row2]->unix_pwdwarn)) $errors[] = array('ERROR', _('Password warn'), _('Password warn must be are natural number.')); if ((!$_SESSION['accounts'][$row2]->unix_host=='') && !ereg('^([a-z]|[A-Z]|[0-9]|[.]|[-])+(([,])+([ ])*([a-z]|[A-Z]|[0-9]|[.]|[-])+)*$', $_SESSION['accounts']->unix_host)) $errors[] = array('ERROR', _('Unix workstations'), _('Unix workstations is invalid.')); $_SESSION['errors'][$row2] = array_merge($_SESSION['errors'][$row2], $errors); if (isset($errors)) unset ($errors); $_SESSION['accounts'][$row2]->smb_displayName = $_SESSION['accounts'][$row2]->general_gecos; $i=0; while ($_SESSION['accounts'][$row2]->quota[$i][0]) { // Check if values are OK and set automatic values. if not error-variable will be set if (!ereg('^([0-9])*$', $_SESSION['accounts'][$row2]->quota[$i][2])) $errors[] = array('ERROR', _('Block soft quota'), _('Block soft quota contains invalid characters. Only natural numbers are allowed')); if (!ereg('^([0-9])*$', $_SESSION['accounts'][$row2]->quota[$i][3])) $errors[] = array('ERROR', _('Block hard quota'), _('Block hard quota contains invalid characters. Only natural numbers are allowed')); if (!ereg('^([0-9])*$', $_SESSION['accounts'][$row2]->quota[$i][6])) $errors[] = array('ERROR', _('Inode soft quota'), _('Inode soft quota contains invalid characters. Only natural numbers are allowed')); if (!ereg('^([0-9])*$', $_SESSION['accounts'][$row2]->quota[$i][7])) $errors[] = array('ERROR', _('Inode hard quota'), _('Inode hard quota contains invalid characters. Only natural numbers are allowed')); $i++; } $_SESSION['errors'][$row2] = array_merge($_SESSION['errors'][$row2], $errors); if (isset($errors)) unset ($errors); if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_SESSION['accounts'][$row2]->personal_telephoneNumber)) $errors[] = array('ERROR', _('Telephone number'), _('Please enter a valid telephone number!')); if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_SESSION['accounts'][$row2]->personal_mobileTelephoneNumber)) $errors[] = array('ERROR', _('Mobile number'), _('Please enter a valid mobile number!')); if ( !ereg('^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/])*$', $_SESSION['accounts'][$row2]->personal_facsimileTelephoneNumber)) $errors[] = array('ERROR', _('Fax number'), _('Please enter a valid fax number!')); if ( !ereg('^(([0-9]|[A-Z]|[a-z]|[.]|[-]|[_])+[@]([0-9]|[A-Z]|[a-z]|[-])+([.]([0-9]|[A-Z]|[a-z]|[-])+)*)*$', $_SESSION['accounts'][$row2]->personal_mail)) $errors[] = array('ERROR', _('eMail address'), _('Please enter a valid eMail address!')); if ( !ereg('^([0-9]|[A-Z]|[a-z]|[ ]|[.]|[Ä]|[ä]|[Ö]|[ö]|[Ü]|[ü]|[ß])*$', $_SESSION['accounts'][$row2]->personal_street)) $errors[] = array('ERROR', _('Street'), _('Please enter a valid street name!')); if ( !ereg('^([0-9]|[A-Z]|[a-z]|[ ]|[.]|[Ä]|[ä]|[Ö]|[ö]|[Ü]|[ü]|[ß])*$', $_SESSION['accounts'][$row2]->personal_postalAddress)) $errors[] = array('ERROR', _('Postal address'), _('Please enter a valid postal address!')); if ( !ereg('^([0-9]|[A-Z]|[a-z]|[ ]|[.]|[Ä]|[ä]|[Ö]|[ö]|[Ü]|[ü]|[ß])*$', $_SESSION['accounts'][$row2]->personal_title)) $errors[] = array('ERROR', _('Title'), _('Please enter a valid title!')); if ( !ereg('^([0-9]|[A-Z]|[a-z]|[ ]|[.]|[Ä]|[ä]|[Ö]|[ö]|[Ü]|[ü]|[ß])*$', $_SESSION['accounts'][$row2]->personal_employeeType)) $errors[] = array('ERROR', _('Employee type'), _('Please enter a valid employee type!')); if ( !ereg('^([0-9]|[A-Z]|[a-z])*$', $_SESSION['accounts']->personal_postalCode)) $errors[] = array('ERROR', _('Postal code'), _('Please enter a valid postal code!')); $_SESSION['errors'][$row2] = array_merge($_SESSION['errors'][$row2], $errors); if (isset($errors)) unset ($errors); } } if ($_FILES['userfile']['size']>0) { fclose($handle); unlink($_FILES['userfile']['tmp_name']); } if ($row2>400) return false; else return true; } ?>