general_username = $_POST['f_general_username']; else $_SESSION['account']->general_username = $_POST['f_general_username']; if ($_POST['f_general_surname']) $_SESSION['account']->general_surname = $_POST['f_general_surname']; else $_SESSION['account']->general_surname = ""; if ($_POST['f_general_givenname']) $_SESSION['account']->general_givenname = $_POST['f_general_givenname']; else $_SESSION['account']->general_givenname = ""; if ($_POST['f_general_uidNumber']) $_SESSION['account']->general_uidNumber = $_POST['f_general_uidNumber']; else $_SESSION['account']->general_uidNumber = ""; if ($_POST['f_general_group']) $_SESSION['account']->general_group = $_POST['f_general_group']; if ($_POST['f_general_groupadd']) $_SESSION['account']->general_groupadd = $_POST['f_general_groupadd']; if ($_POST['f_general_homedir']) $_SESSION['account']->general_homedir = $_POST['f_general_homedir']; else $_SESSION['account']->general_homedir = ""; if ($_POST['f_general_shell']) $_SESSION['account']->general_shell = $_POST['f_general_shell']; if ($_POST['f_general_gecos']) $_SESSION['account']->general_gecos = $_POST['f_general_gecos']; else $_SESSION['account']->general_gecos = ""; // Check Values if ($_SESSION['account_old']) $values = checkglobal($_SESSION['account'], $_SESSION['type2'], $_SESSION['account_old']); // account.inc else $values = checkglobal($_SESSION['account'], $_SESSION['type2']); // account.inc if (is_object($values)) { while (list($key, $val) = each($values)) // Set only defined values if ($val) $_SESSION['account']->$key = $val; } else $error = $values; // Check which part Site should be displayd if ($_POST['next'] && ($error=="0")) switch ($_SESSION['type2']) { case 'user': $select_local = 'unix'; break; case 'group': $select_local = 'quota'; break; case 'host': $select_local = 'unix'; break; } } break; case 'unix': // Write all values in temporary object if ($_POST['f_unix_password']) $_SESSION['account']->unix_password = $_POST['f_unix_password']; else $_SESSION['account']->unix_password = ''; if ($_POST['genpass']) { $_SESSION['account']->unix_password = genpasswd(); } if ($_POST['f_unix_password_no']) $_SESSION['account']->unix_password_no = true; else $_SESSION['account']->unix_password_no = false; if ($_POST['f_unix_pwdwarn']) $_SESSION['account']->unix_pwdwarn = $_POST['f_unix_pwdwarn']; else $_SESSION['account']->unix_pwdwarn = ''; if ($_POST['f_unix_pwdallowlogin']) $_SESSION['account']->unix_pwdallowlogin = $_POST['f_unix_pwdallowlogin']; else $_SESSION['account']->unix_pwdallowlogin = ''; if ($_POST['f_unix_pwdmaxage']) $_SESSION['account']->unix_pwdmaxage = $_POST['f_unix_pwdmaxage']; else $_SESSION['account']->unix_pwdmaxage = ''; if ($_POST['f_unix_pwdminage']) $_SESSION['account']->unix_pwdminage = $_POST['f_unix_pwdminage']; else $_SESSION['account']->unix_pwdminage = ''; if ($_POST['f_unix_pwdexpire_day']) $_SESSION['account']->unix_pwdexpire_day = $_POST['f_unix_pwdexpire_day']; if ($_POST['f_unix_pwdexpire_mon']) $_SESSION['account']->unix_pwdexpire_mon = $_POST['f_unix_pwdexpire_mon']; if ($_POST['f_unix_pwdexpire_yea']) $_SESSION['account']->unix_pwdexpire_yea = $_POST['f_unix_pwdexpire_yea']; if ($_POST['f_unix_deactivated']) $_SESSION['account']->unix_deactivated = $_POST['f_unix_deactivated']; else $_SESSION['account']->unix_deactivated = false; // Check Values // Check which part Site should be displayd if ($_POST['genpass']) $select_local = 'unix'; else $error = checkunix($_SESSION['account'], $_SESSION['type2']); // account.inc if ($_POST['respass']) { $_SESSION['account']->unix_password_no=true; $_SESSION['account']->smb_password_no=true; } if (($_POST['next']) && ($error=="0")) $select_local = 'samba'; else $select_local = 'unix'; if ($_POST['back']) $select_local = 'general'; break; case 'samba': // Write all values in temporary object if ($_POST['f_smb_password']) $_SESSION['account']->smb_password = $_POST['f_smb_password']; else $_SESSION['account']->smb_password = ""; if ($_POST['f_smb_password_no']) $_SESSION['account']->smb_password_no = true; else $_SESSION['account']->smb_password_no = false; if ($_POST['f_smb_useunixpwd']) $_SESSION['account']->smb_useunixpwd = $_POST['f_smb_useunixpwd']; else $_SESSION['account']->smb_useunixpwd = false; if ($_POST['f_smb_pwdcanchange']) $_SESSION['account']->smb_pwdcanchange = $_POST['f_smb_pwdcanchange']; else $_SESSION['account']->smb_pwdcanchange = false; if ($_POST['f_smb_pwdmustchange']) $_SESSION['account']->smb_pwdmustchange = $_POST['f_smb_pwdmustchange']; else $_SESSION['account']->smb_pwdmustchange = false; if ($_POST['f_smb_homedrive']) $_SESSION['account']->smb_homedrive = $_POST['f_smb_homedrive']; if ($_POST['f_smb_scriptpath']) $_SESSION['account']->smb_scriptPath = $_POST['f_smb_scriptpath']; else $_SESSION['account']->smb_scriptPath = ''; if ($_POST['f_smb_smbuserworkstations']) $_SESSION['account']->smb_smbuserworkstations = $_POST['f_smb_smbuserworkstations']; else $_SESSION['account']->smb_smbuserworkstations = ""; if ($_POST['f_smb_smbhome']) $_SESSION['account']->smb_smbhome = stripslashes($_POST['f_smb_smbhome']); else $_SESSION['account']->smb_smbhome = ""; if ($_POST['f_smb_profilePath']) $_SESSION['account']->smb_profilePath = stripslashes($_POST['f_smb_profilePath']); else $_SESSION['account']->smb_profilePath = ""; if ($_POST['f_smb_domain']) $_SESSION['account']->smb_domain = $_POST['f_smb_domain']; else $_SESSION['account']->smb_domain = false; if ($_POST['f_smb_flagsW']) $_SESSION['account']->smb_flagsW = $_POST['f_smb_flagsW']; else $_SESSION['account']->smb_flagsW = false; if ($_POST['f_smb_flagsD']) $_SESSION['account']->smb_flagsD = $_POST['f_smb_flagsD']; else $_SESSION['account']->smb_flagsD = false; if ($_POST['f_smb_flagsX']) $_SESSION['account']->smb_flagsX = $_POST['f_smb_flagsX']; else $_SESSION['account']->smb_flagsX = false; // Check Values $values = checksamba($_SESSION['account'], $_SESSION['type2']); // account.inc if (is_object($values)) { while (list($key, $val) = each($values)) // Set only defined values if ($val) $_SESSION['account']->$key = $val; } else $error = $values; // Check which part Site should be displayd if ($_POST['back']) $select_local = 'unix'; if ($_POST['next']) { if ($error=="0") switch ($_SESSION['type2']) { case 'user': $select_local = 'quota'; break; case 'host': $select_local = 'final'; break; } else $select_local = 'samba'; } break; case 'quota': $i=0; while ($_SESSION['account']->quota[$i][0]) { $_SESSION['account']->quota[$i][2] = $_POST['f_quota_'.$i.'_2']; $_SESSION['account']->quota[$i][3] = $_POST['f_quota_'.$i.'_3']; $_SESSION['account']->quota[$i][6] = $_POST['f_quota_'.$i.'_6']; $_SESSION['account']->quota[$i][7] = $_POST['f_quota_'.$i.'_7']; $i++; } $values = checkquota($_SESSION['account'], $_SESSION['type2']); // account.inc if (is_object($values)) { while (list($key, $val) = each($values)) // Set only defined values if ($val) $_SESSION['account']->$key = $val; } else $error = $values; // Check which part Site should be displayd if ($_POST['back']) switch ($_SESSION['type2']) { case 'user': $select_local = 'samba'; break; case 'group': $select_local = 'general'; break; } if ($_POST['next']) { if ($error=="0") switch ($_SESSION['type2']) { case 'user': $select_local = 'personal'; break; case 'group': $select_local = 'final'; break; } else $select_local = 'quota'; } break; case 'personal': if ($_POST['f_personal_title']) $_SESSION['account']->personal_title = $_POST['f_personal_title']; else $_SESSION['account']->personal_title = ""; if ($_POST['f_personal_mail']) $_SESSION['account']->personal_mail = $_POST['f_personal_mail']; else $_SESSION['account']->personal_mail = ""; if ($_POST['f_personal_telephoneNumber']) $_SESSION['account']->personal_telephoneNumber = $_POST['f_personal_telephoneNumber']; else $_SESSION['account']->personal_telephoneNumber = ""; if ($_POST['f_personal_mobileTelephoneNumber']) $_SESSION['account']->personal_mobileTelephoneNumber = $_POST['f_personal_mobileTelephoneNumber']; else $_SESSION['account']->personal_mobileTelephoneNumber = ""; if ($_POST['f_personal_facsimileTelephoneNumber']) $_SESSION['account']->personal_facsimileTelephoneNumber = $_POST['f_personal_facsimileTelephoneNumber']; else $_SESSION['account']->personal_facsimileTelephoneNumber = ""; if ($_POST['f_personal_street']) $_SESSION['account']->personal_street = $_POST['f_personal_street']; else $_SESSION['account']->personal_street = ""; if ($_POST['f_personal_postalCode']) $_SESSION['account']->personal_postalCode = $_POST['f_personal_postalCode']; else $_SESSION['account']->personal_postalCode = ""; if ($_POST['f_personal_postalAddress']) $_SESSION['account']->personal_postalAddress = $_POST['f_personal_postalAddress']; else $_SESSION['account']->personal_postalAddress = ""; if ($_POST['f_personal_employeeType']) $_SESSION['account']->personal_employeeType = $_POST['f_personal_employeeType']; else $_SESSION['account']->personal_employeeType = ""; // Check which part Site should be displayd $values = checkpersonal($_SESSION['account'], $_SESSION['type2']); // account.inc if (is_object($values)) { while (list($key, $val) = each($values)) // Set only defined values if ($val) $_SESSION['account']->$key = $val; } else $error = $values; if ($_POST['back'] && ($error=="0")) $select_local = 'quota'; if ($_POST['next'] && ($error=="0")) $select_local = 'final'; break; case 'final': if ($_POST['f_final_changegids']) $_SESSION['final_changegids'] = $_POST['f_final_changegids'] ; if ($_POST['back'] && ($error=="0")) switch ($_SESSION['type2']) { case 'user': $select_local = 'personal'; break; case 'group': $select_local = 'quota'; break; case 'host': $select_local = 'samba'; break; } break; case 'finish': if ($_POST['outputpdf']) createpdf($_SESSION['account']); break; } if ( $_POST['create'] ) { // Create-Button was pressed switch ($_SESSION['type2']) { case 'user': if ($_SESSION['account_old']) $result = modifyuser($_SESSION['account'],$_SESSION['account_old']); else $result = createuser($_SESSION['account']); // account.inc if ( $result==1 || $result==3 ) $select_local = 'finish'; break; case 'group': if ($_SESSION['account_old']) $result = modifygroup($_SESSION['account'],$_SESSION['account_old']); else $result = creategroup($_SESSION['account']); // account.inc if ( $result==1 || $result==3 ) $select_local = 'finish'; break; case 'host': if ($_SESSION['account_old']) $result = modifyhost($_SESSION['account'],$_SESSION['account_old']); else $result = createhost($_SESSION['account']); // account.inc if ( $result==1 || $result==3 ) $select_local = 'finish'; break; } } if (!$select_local) $select_local='general'; if ($_POST['createagain']) { $select_local='general'; $_SESSION['account']=""; } if ($_POST['backmain']) { $select_local='backmain'; } if ($_POST['load']) $select_local='load'; if ($_POST['save']) $select_local='save'; // Write HTML-Header and part of Table echo ''; echo ''; echo _('Create new Account'); echo ' '; switch ($select_local) { case 'backmain': if (session_is_registered("shelllist")) session_unregister("shelllist"); if (session_is_registered("account")) session_unregister("account"); if (session_is_registered("account_old")) session_unregister("account_old"); switch ( $_SESSION['type2'] ) { case 'user' : if (session_is_registered("type2")) session_unregister("type2"); echo ''; break; case 'group' : if (session_is_registered("type2")) session_unregister("type2"); echo ''; break; case 'host' : if (session_is_registered("type2")) session_unregister("type2"); echo ''; break; } break; case 'load': switch ( $_SESSION['type2'] ) { case 'user': $_SESSION['account'] = loadUserProfile($_POST['f_general_selectprofile']); break; case 'host': $_SESSION['account'] = loadHostProfile($_POST['f_general_selectprofile']); break; case 'group': $_SESSION['account'] = loadGroupProfile($_POST['f_general_selectprofile']); break; } $select_local='general'; break; case 'save': switch ( $_SESSION['type2'] ) { case 'user': saveUserProfile($_SESSION['account'], $_POST['f_finish_safeProfile']); break; case 'host': saveHostProfile($_SESSION['account'], $_POST['f_finish_safeProfile']); break; case 'group': saveGroupProfile($_SESSION['account'], $_POST['f_finish_safeProfile']); break; } $select_local='final'; break; } echo '
'; if ($error != "0") StatusMessage('ERROR', _('Invalid Value!'), $error); echo ''; switch ($select_local) { case 'general': // General Account Settings $groups = findgroups(); echo ''; switch ( $_SESSION['type2'] ) { case 'user': $profilelist = getUserProfiles(); echo ''; break; case 'unix': // Unix Password Settings echo ''; switch ( $_SESSION['type2'] ) { case 'user' : echo ''; break; case 'host' : echo ''; echo ''; break; } echo ''; break; case 'samba': // Samba Settings echo ''; switch ( $_SESSION['type2'] ) { case 'user': echo ''; break; case 'host': echo ''; echo ''; break; } echo ''; break; case 'quota': // Quota Settings echo ''; $i=0; while ($_SESSION['account']->quota[$i][0]) { echo ''; // used blocks echo ''; // blocks soft limit echo ''; // blocks hard limit echo ''; // block grace period echo ''; // used inodes echo ''; // inodes soft limit echo ''; // inodes hard limit echo ''; // inodes grace period $i++; } echo ''; break; case 'personal': // Personal Settings echo ''; break; case 'final': // Final Settings echo ''; switch ( $_SESSION['type2'] ) { case 'user' : if (($_SESSION['account_old']) && ($_SESSION['account']->general_uidNumber != $_SESSION['account_old']->general_uidNumber)) { echo ''; StatusMessage ('INFO', _('UID-number has changed. You have to run the following command as root in order to change existing file-permissions:'), 'find / -gid ' . $_SESSION['account_old' ]->general_uidNumber . ' -exec chown ' . $_SESSION['account']->general_uidNumber . ' {} \;'); echo ''; } if (($_SESSION['account_old']) && ($_SESSION['account']->general_homedir != $_SESSION['account_old']->general_homedir)) { echo ''; StatusMessage ('INFO', _('Home Directory has changed. You have to run the following command as root in order to change the existing homedirectory:'), 'mv ' . $_SESSION['account_old' ]->general_homedir . ' ' . $_SESSION['account']->general_homedir); echo ''; } break; case 'group' : if (($_SESSION['account_old']) && ($_SESSION['account']->general_uidNumber != $_SESSION['account_old']->general_uidNumber)) { echo ''; StatusMessage ('INFO', _('GID-number has changed. You have to run the following command as root in order to change existing file-permissions:'), 'find / -gid ' . $_SESSION['account_old' ]->general_uidNumber . ' -exec chgrp ' . $_SESSION['account']->general_uidNumber . ' {} \;'); echo ''; echo ''; } break; case 'host': if (($_SESSION['account_old']) && ($_SESSION['account']->general_uidNumber != $_SESSION['account_old']->general_uidNumber)) { echo ''; StatusMessage ('INFO', _('UID-number has changed. You have to run the following command as root in order to change existing file-permissions:'), 'find / -gid ' . $_SESSION['account_old' ]->general_uidNumber . ' -exec chown ' . $_SESSION['account']->general_uidNumber . ' {} \;'); echo ''; } break; } echo ''; break; case 'finish': // Final Settings echo ''; switch ( $_SESSION['type2'] ) { case 'user' : echo ''; break; case 'group' : echo ''; break; case 'host' : echo ''; break; } break; } // Print end of HTML-Page echo '
'; echo _('General Properties'); echo '
'; echo _('Username'); echo '
'; echo _('UID Number'); echo ' '; echo _('If empty UID Number will be generated automaticly.'); echo '
'; echo _('Surname'); echo '
'; echo _('Given name'); echo '
'; echo _('Primary Group'); echo '
'; echo _('Additional Groupmembership'); echo ''; echo _('Can be left empty. Hold the CTRL-key to select multiple groups.'); echo '
'; echo _('Home Directory'); echo ' '; echo _('$user and $group are replaced with username or primary groupname.'); echo '
'; echo _('Gecos'); echo ' '; echo _('User descriptopn. If left empty sur- and givename will be used.'); echo '
'; echo _('Login Shell'); echo ''; echo _('To disable login use /bin/false.'); echo '
'; break; case 'group': $profilelist = getGroupProfiles(); echo '
'; echo _('Groupname'); echo '
'; echo _('GID Number'); echo ' '; echo _('If empty GID Number will be generated automaticly.'); echo '
'; echo _('Gecos'); echo ' '; echo _('User descriptopn. If left empty groupname will be used.'); echo '
'; break; case 'host': $profilelist = getHostProfiles(); echo '
'; echo _('Hostname'); echo '
'; echo _('UID Number'); echo ' '; echo _('If empty UID Number will be generated automaticly.'); echo '
'; echo _('Primary Group'); echo '
'; echo _('Additional Groupmembership'); echo ''; echo _('Can be left empty. Hold the CTRL-key to select multiple groups.'); echo '
'; echo _('Gecos'); echo ' '; echo _('Host descriptopn. If left empty hostname will be used.'); echo '
'; break; } echo '
'; echo _('Unix Properties'); echo '
'; echo _('Password'); echo '
'; echo _('Use no Password.'); echo 'unix_password_no) echo ' checked '; echo '>
'; echo _('Password Warn'); echo ' '; echo _('Number of days a user will be warned when password will expire. Value must be 0<.'); echo '
'; echo _('Password Expire'); echo ' '; echo _('Number of days a user can login even his password has expired. -1=always'); echo '
'; echo _('Maximum Passwordage'); echo ' '; echo _('Number of days after a user has to change his password again Value must be 0<.'); echo '
'; echo _('Minimum Passwordage'); echo ' '; echo _('Number of days a user has to wait until he\'s allowed to change his password again. Value must be 0<.'); echo '
'; echo _('Expire Date'); echo ''; echo _('Account expire date.'); echo '
'; echo _('Account deactivated'); echo 'unix_deactivated) echo ' checked '; echo '>
'; echo _('Password'); echo ''; if ($_SESSION['account_old']) { echo ''; } echo '
'; echo _('Password Warn'); echo ' '; echo _('Number of host a user will be warned when password will expire. Value must be 0<.'); echo '
'; echo _('Password Expire'); echo ' '; echo _('Number of days a host can login even his password has expired. -1=always'); echo '
'; echo _('Maximum Passwordage'); echo ' '; echo _('Number of days after a host has to change his password again Value must be 0< and should be higher as the value on client-side.'); echo '
'; echo _('Minimum Passwordage'); echo ' '; echo _('Number of days a user has to wait until he\'s allowed to change his password again. Value must be 0<.'); echo '
'; echo _('Expire Date'); echo ''; echo _('Account expire date.'); echo '
'; echo _('Account deactivated'); echo 'unix_deactivated) echo ' checked '; echo '>
'; echo _('Samba Properties'); echo '
'; echo _('Samba Password'); echo ' smb_useunixpwd) echo ' checked '; echo '>'; echo _('Use Unix-Password'); echo '
'; echo _('Use no Password.'); echo 'smb_password_no) echo ' checked '; echo '>
'; echo _('Password doesn\'t expire.'); echo 'smb_flagsX) echo ' checked '; echo '>
'; echo _('User can change Password'); echo 'smb_pwdcanchange) echo ' checked '; echo '>
'; echo _('User must change Password'); echo 'smb_pwdmustchange) echo ' checked '; echo '>
'; echo _('Accout is deactivated'); echo 'smb_flagsD) echo ' checked '; echo '>
'; $_SESSION['account']->smb_flagsW = 0; echo _('Home Drive'); echo ''; echo _('Driveletter assigned on Windows-Workstations as Homedirectory.'); echo '
'; echo _('Script Path'); echo ' '; echo _('Filename and -path relative to netlogon-share which should be executed on logon. $user and $group are replaced with user- and groupname. Can be left empty.'); echo '
'; echo _('Profile Path'); echo ' '; echo _('Path of the userprofile. Can be a local absolute path or a UNC-path (\\\\server\\share). $user and $group are replaced with user- and groupname. Can be left empty.'); echo '
'; echo _('User Workstations'); echo ' '; echo _('Komma-separated list of workstations the user is allowed to login. Empty means every workstation. Can be left empty.'); echo '
'; echo _('smb Home'); echo ' '; echo _('UNC-path (\\\\server\\share) of homedirectory. $user and $group are replaced with user- and groupname. Can be left empty.'); echo '
'; echo _('Domain'); echo ' '; echo _('Windows-Domain of user. Can be left empty.'); echo '
'; echo _('Password doesn\'t expire.'); echo 'smb_flagsX) echo ' checked '; echo '>
'; echo _('Host can change Password'); echo 'smb_pwdcanchange) echo ' checked '; echo '>
'; echo _('Host must change Password'); echo 'smb_pwdmustchange) echo ' checked '; echo '>
'; echo _('Accout is deactivated'); echo 'smb_flagsD) echo ' checked '; echo '>
'; $_SESSION['account']->smb_flagsW = 1; echo '
'; echo _('Domain'); echo ' '; echo _('Windows-Domain of user. Can be left empty.'); echo '
'; echo _('Quota Properties'); echo '
'; echo _('Mointpoint'); echo ''; echo _('used blocks'); echo ''; echo _('soft block limit'); echo ''; echo _('hard block limit'); echo ''; echo _('grace block period'); echo ''; echo _('used inodes'); echo ''; echo _('soft inode limit'); echo ''; echo _('hard inode limit'); echo ''; echo _('grace inode period'); echo '
'.$_SESSION['account']->quota[$i][0].''.$_SESSION['account']->quota[$i][1].''.$_SESSION['account']->quota[$i][4].''.$_SESSION['account']->quota[$i][5].''.$_SESSION['account']->quota[$i][8].'
'; echo _('Personal Properties'); echo '
'; echo _('Title'); echo ' '; echo $_SESSION['account']->general_surname . ' ' . $_SESSION['account']->general_givenname . ''; echo _('Every value on this page can be left empty.'); echo '
'; echo _('Employee Type'); echo '
'; echo _('Street'); echo '
'; echo _('Postal code'); echo '
'; echo _('Postal address'); echo '
'; echo _('Telephone Number'); echo '
'; echo _('Mobile Phonenumber'); echo '
'; echo _('Facsimile Number'); echo '
'; echo _('eMail Address'); echo '
'; if ($_SESSION['account_old']) echo _('Modify'); else echo _('Create'); echo '
'; echo ''; echo _('Change GID-Number of all users in group to new value'); echo '
'; echo ' '; echo ' '; echo '
'; echo _('Success'); echo '
'; echo _('User '); echo $_SESSION['account']->general_username; if ($_SESSION['account_old']) echo _(' has been modified. '); else echo _(' has been created. '); if (!$_SESSION['account_old']) { echo ''; } echo '
'; echo _('Group '); echo $_SESSION['account']->general_username; if ($_SESSION['account_old']) echo _(' has been modified. '); else echo _(' has been created. '); echo '
'; if (!$_SESSION['account_old']) { echo' '; } echo '
'; echo _('Host '); echo $_SESSION['account']->general_username; if ($_SESSION['account_old']) echo _(' has been modified. '); else echo _(' has been created. '); echo '
'; if (!$_SESSION['account_old']) { echo ''; } echo '
'; ?>