2013-04-06 15:00:53 +00:00
< ? php
/*
$Id $
This code is part of LDAP Account Manager ( http :// www . ldap - account - manager . org / )
2016-01-03 15:43:28 +00:00
Copyright ( C ) 2013 - 2016 Roland Gruber
2013-04-06 15:00:53 +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
*/
/**
* Manages Windows AD ( e . g . Samba 4 ) users .
*
* @ package modules
* @ author Roland Gruber
*/
/**
* Manages Windows AD ( e . g . Samba 4 ) users .
*
* @ package modules
*/
2013-04-07 17:28:09 +00:00
class windowsUser extends baseModule implements passwordService {
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
/** initial account flags */
const DEFAULT_ACCOUNT_CONTROL = 0x00000200 ;
/** password never expires */
const AC_PWD_NEVER_EXPIRES = 0x00010000 ;
/** login requires smartcard */
const AC_SMARTCARD_REQUIRED = 0x00040000 ;
/** account is disabled */
const AC_ACCOUNT_DISABLED = 0x00000002 ;
/** currently locked out, read only flag */
const AC_LOCKED_OUT = 0x00000010 ;
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
/** current group of names list */
private $groupList = array ();
/** original group of names list */
private $groupList_orig = array ();
/** cache for groups */
private $groupCache = null ;
2013-04-21 16:41:19 +00:00
/** option for forcing password change, used in postModifyActions */
private $pwdLastSet = null ;
2013-04-21 18:53:39 +00:00
/** clear text password */
private $clearTextPassword ;
2015-11-08 09:59:20 +00:00
/** cache for departments */
private $departmentCache = null ;
/** organization cache */
private $oCache = null ;
/** organizational unit cache */
private $ouCache = null ;
/** title cache */
private $titleCache = null ;
/** employee type cache */
private $employeeTypeCache = null ;
/** business category cache */
private $businessCategoryCache = null ;
2015-08-04 18:41:12 +00:00
2014-04-20 13:00:42 +00:00
/**
* Returns true if this module can manage accounts of the current type , otherwise false .
2015-08-04 18:41:12 +00:00
*
2014-04-20 13:00:42 +00:00
* @ return boolean true if module fits
*/
public function can_manage () {
return in_array ( $this -> get_scope (), array ( 'user' ));
}
2013-04-06 15:00:53 +00:00
/**
* Returns meta data that is interpreted by parent class
*
* @ return array array with meta data
2015-08-04 18:41:12 +00:00
*
2013-04-06 15:00:53 +00:00
* @ see baseModule :: get_metaData ()
*/
public function get_metaData () {
$return = array ();
// icon
$return [ 'icon' ] = 'samba.png' ;
// this is a base module
$return [ " is_base " ] = true ;
2013-04-07 17:28:09 +00:00
// PHP extensions
$return [ 'extensions' ] = array ( 'iconv' );
2013-04-06 15:00:53 +00:00
// RDN attribute
$return [ " RDN " ] = array ( " cn " => " high " );
// LDAP filter
2013-04-13 15:57:32 +00:00
$return [ " ldap_filter " ] = array ( 'and' => '(!(objectClass=computer))' , 'or' => " (objectClass=user) " );
2013-04-06 15:00:53 +00:00
// alias name
$return [ " alias " ] = _ ( " Windows " );
// module dependencies
$return [ 'dependencies' ] = array ( 'depends' => array (), 'conflicts' => array ());
// managed object classes
2013-04-20 08:32:12 +00:00
$return [ 'objectClasses' ] = array ( 'user' , 'securityPrincipal' );
2013-04-06 15:00:53 +00:00
// managed attributes
2013-11-09 13:26:31 +00:00
$return [ 'attributes' ] = array ( 'userPrincipalName' , 'cn' , 'sAMAccountName' , 'description' , 'displayName' , 'givenName' , 'initials' ,
2013-04-06 15:00:53 +00:00
'l' , 'mail' , 'otherTelephone' , 'physicalDeliveryOfficeName' , 'postalCode' , 'postOfficeBox' , 'sn' , 'st' ,
2013-04-13 15:57:32 +00:00
'streetAddress' , 'telephoneNumber' , 'url' , 'wWWHomePage' , 'userAccountControl' , 'profilePath' , 'scriptPath' ,
2015-09-02 16:39:30 +00:00
'pwdLastSet' , 'otherMailbox' , 'homeDirectory' , 'homeDrive' , 'msSFU30Name' , 'msSFU30NisDomain' , 'pwdLastSet' ,
2015-11-07 14:44:34 +00:00
'lastLogonTimestamp' , 'accountExpires' , 'jpegPhoto' , 'title' , 'carLicense' , 'employeeNumber' , 'employeeType' ,
2016-01-03 15:43:28 +00:00
'businessCategory' , 'departmentNumber' , 'ou' , 'o' , 'manager' , 'facsimileTelephoneNumber'
2015-09-02 16:39:30 +00:00
);
2013-04-06 15:00:53 +00:00
// help Entries
$return [ 'help' ] = array (
'cn' => array (
2013-11-09 13:26:31 +00:00
" Headline " => _ ( 'Common name' ), 'attr' => 'cn' ,
" Text " => _ ( 'This is the natural name of the user. If empty, the first and last name or user name is used.' )
2013-12-28 10:47:50 +00:00
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
2013-11-09 13:26:31 +00:00
),
'userPrincipalName' => array (
" Headline " => _ ( 'User name' ), 'attr' => 'userPrincipalName' ,
2013-04-06 15:00:53 +00:00
" Text " => _ ( 'Please enter the user\'s name.' )
),
2013-11-09 13:26:31 +00:00
'userPrincipalNameDomain' => array (
" Headline " => _ ( 'Domain' ), 'attr' => 'userPrincipalName' ,
" Text " => _ ( 'Windows domain name of account.' )
),
'sAMAccountName' => array (
" Headline " => _ ( 'User name (pre W2K)' ), 'attr' => 'sAMAccountName' ,
" Text " => _ ( 'Please enter the user\'s name.' ) . ' ' . _ ( 'This user name is only used for old Windows versions (e.g. NT4, W98).' )
),
2013-04-06 15:00:53 +00:00
'description' => array (
" Headline " => _ ( 'Description' ), 'attr' => 'description' ,
" Text " => _ ( 'Please enter a descriptive text for this user.' )
),
'displayName' => array (
" Headline " => _ ( 'Display name' ), 'attr' => 'displayName' ,
" Text " => _ ( 'This is the account\'s full name on Windows systems.' )
2013-12-28 10:47:50 +00:00
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
2013-04-06 15:00:53 +00:00
),
'givenName' => array (
" Headline " => _ ( 'First name' ), 'attr' => 'givenName' ,
" Text " => _ ( 'First name of user. Only letters, - and spaces are allowed.' )
),
'initials' => array (
" Headline " => _ ( 'Initials' ), 'attr' => 'initials' ,
" Text " => _ ( 'The initials of the user\'s first names.' )
),
'l' => array (
" Headline " => _ ( 'Location' ), 'attr' => 'l' ,
" Text " => _ ( 'This describes the location of the user.' )
),
'mail' => array (
" Headline " => _ ( 'Email address' ), 'attr' => 'mail' ,
2013-12-28 10:47:50 +00:00
" Text " => _ ( 'The user\'s email address.' ) . ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
2013-04-06 15:00:53 +00:00
),
'otherTelephone' => array (
" Headline " => _ ( 'Other telephone numbers' ), 'attr' => 'otherTelephone' ,
" Text " => _ ( 'If the user has multiple telephone numbers then please enter it here.' )
),
2013-04-14 19:19:33 +00:00
'otherTelephoneList' => array (
" Headline " => _ ( 'Other telephone numbers' ), 'attr' => 'otherTelephone' ,
" Text " => _ ( 'If the user has multiple telephone numbers then please enter it here.' ) . ' ' . _ ( " Multiple values are separated by semicolon. " )
),
2013-04-06 15:00:53 +00:00
'physicalDeliveryOfficeName' => array (
" Headline " => _ ( 'Office name' ), 'attr' => 'physicalDeliveryOfficeName' ,
" Text " => _ ( 'The office name of the user (e.g. YourCompany, Human Resources).' )
),
'postalCode' => array (
" Headline " => _ ( 'Postal code' ), 'attr' => 'postalCode' ,
" Text " => _ ( 'The postal code of the user\'s address.' )
),
'postOfficeBox' => array (
" Headline " => _ ( 'Post office box' ), 'attr' => 'postOfficeBox' ,
" Text " => _ ( 'The post office box of the user\'s address.' )
),
'sn' => array (
" Headline " => _ ( 'Last name' ), 'attr' => 'sn' ,
" Text " => _ ( 'Last name of user. Only letters, - and spaces are allowed.' )
),
'st' => array (
" Headline " => _ ( 'State' ), 'attr' => 'st' ,
" Text " => _ ( 'The state where the user resides or works.' )
),
'streetAddress' => array (
" Headline " => _ ( 'Street' ), 'attr' => 'streetAddress' ,
" Text " => _ ( 'The street name of the user\'s address.' )
),
'telephoneNumber' => array (
" Headline " => _ ( 'Telephone number' ), 'attr' => 'telephoneNumber' ,
" Text " => _ ( 'The user\'s telephone number.' )
),
2016-01-03 15:43:28 +00:00
'facsimileTelephoneNumber' => array (
" Headline " => _ ( " Fax number " ), 'attr' => 'facsimileTelephoneNumber' ,
" Text " => _ ( " The user's fax number. " )
),
2013-04-06 15:00:53 +00:00
'url' => array (
" Headline " => _ ( 'Other web sites' ), 'attr' => 'url' ,
" Text " => _ ( 'Here you can enter additional web sites for the user.' )
),
2013-04-14 19:19:33 +00:00
'urlList' => array (
" Headline " => _ ( 'Other web sites' ), 'attr' => 'url' ,
" Text " => _ ( 'Here you can enter additional web sites for the user.' ) . ' ' . _ ( " Multiple values are separated by semicolon. " )
),
2013-04-06 15:00:53 +00:00
'wWWHomePage' => array (
" Headline " => _ ( 'Web site' ), 'attr' => 'wWWHomePage' ,
" Text " => _ ( 'The user\'s web site (e.g. http://www.company.com).' )
),
2013-04-13 15:57:32 +00:00
" deactivated " => array (
" Headline " => _ ( " Account is deactivated " ),
" Text " => _ ( " If checked then the account will be deactivated. " )),
" locked " => array (
" Headline " => _ ( " Account is locked " ),
" Text " => _ ( " If checked then the account is locked. You may only unlock accounts but not lock them. " )),
" noExpire " => array (
" Headline " => _ ( " Password does not expire " ),
" Text " => _ ( " If checked password does not expire. " )),
" requireCard " => array (
" Headline " => _ ( " Require smartcard " ),
" Text " => _ ( " The user must log on using a smart card. " )),
" profilePath " => array (
" Headline " => _ ( " Profile path " ), 'attr' => 'profilePath' ,
2013-12-28 10:47:50 +00:00
" Text " => _ ( 'Path of the user profile (UNC-path, e.g. \\\\server\\share\\user). $user is replaced with user name.' ) . ' ' . _ ( " Can be left empty. " )
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
),
2013-04-13 15:57:32 +00:00
" scriptPath " => array (
" Headline " => _ ( " Logon script " ), 'attr' => 'scriptPath' ,
2013-12-28 10:47:50 +00:00
" Text " => _ ( 'File name and path relative to netlogon-share which should be executed on logon. $user is replaced with user name.' ) . ' ' . _ ( " Can be left empty. " )
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
),
2013-04-14 19:19:33 +00:00
" pwdMustChange " => array (
" Headline " => _ ( " Password change at next login " ),
2013-04-13 15:57:32 +00:00
" Text " => _ ( " If you set this option then the user has to change his password at the next login. " )),
2013-04-14 19:19:33 +00:00
" groups " => array (
" Headline " => _ ( " Groups " ),
" Text " => _ ( " Hold the CTRL-key to (de)select multiple groups. " )),
" groupsUpload " => array (
" Headline " => _ ( " Groups " ),
" Text " => _ ( " The groups for this account. You can insert a group name or DN. " ) . ' ' . _ ( " Multiple values are separated by semicolon. " )),
'password' => array (
" Headline " => _ ( " Password " ),
" Text " => _ ( " Please enter the password which you want to set for this account. " )
2013-04-27 17:38:01 +00:00
),
'otherMailbox' => array (
" Headline " => _ ( " Email alias " ), 'attr' => 'otherMailbox' ,
2013-12-28 10:47:50 +00:00
" Text " => _ ( " Email alias for this account. " ) . ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
2013-04-27 17:38:01 +00:00
),
'otherMailboxList' => array (
" Headline " => _ ( " Email alias " ), 'attr' => 'otherMailbox' ,
" Text " => _ ( " Email alias for this account. " ) . ' ' . _ ( " Multiple values are separated by semicolon. " )
2013-12-28 10:47:50 +00:00
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
2013-04-27 17:38:01 +00:00
),
2013-11-09 13:26:31 +00:00
'hiddenOptions' => array (
" Headline " => _ ( " Hidden options " ),
" Text " => _ ( " The selected options will not be managed inside LAM. You can use this to reduce the number of displayed input fields. " )
),
'domains' => array (
" Headline " => _ ( 'Domains' ),
" Text " => _ ( 'Please enter a list of Windows domains that can be selected for your user accounts.' )
),
2013-11-23 14:40:06 +00:00
" homeDrive " => array (
" Headline " => _ ( " Home drive " ), 'attr' => 'homeDrive' ,
" Text " => _ ( " The home directory will be connected under this drive letter. " )),
" homeDirectory " => array (
" Headline " => _ ( " Home directory " ), 'attr' => 'homeDirectory' ,
2013-12-28 10:47:50 +00:00
" Text " => _ ( 'UNC-path (\\\\server\\share\) of home directory. If no home drive is set then this directory must start with a drive letter (e.g. "c:\dir\user").' )
. ' ' . _ ( 'You can use "$user", "$firstname" and "$lastname" as wildcards for user name, first and last name.' )
),
2014-02-12 19:39:51 +00:00
'msSFU30Name' => array (
" Headline " => _ ( 'NIS name' ), 'attr' => 'msSFU30Name' ,
" Text " => _ ( 'User name for NIS.' )
),
'msSFU30NisDomain' => array (
" Headline " => _ ( 'NIS domain' ), 'attr' => 'msSFU30NisDomain' ,
" Text " => _ ( 'NIS domain name.' )
),
2015-09-02 16:39:30 +00:00
'pwdLastSet' => array (
" Headline " => _ ( 'Last password change' ), 'attr' => 'pwdLastSet' ,
" Text " => _ ( 'Time of user\'s last password change.' )
),
'lastLogonTimestamp' => array (
" Headline " => _ ( 'Last login' ), 'attr' => 'lastLogonTimestamp' ,
" Text " => _ ( 'Time of user\'s last login.' )
),
2015-11-02 20:53:20 +00:00
'accountExpires' => array (
" Headline " => _ ( 'Account expiration date' ), 'attr' => 'accountExpires' ,
" Text " => _ ( 'This is the date when the account will expire.' )
),
'accountExpiresUpload' => array (
" Headline " => _ ( 'Account expiration date' ), 'attr' => 'accountExpires' ,
" Text " => _ ( 'This is the date when the account will expire. Format: DD-MM-YYYY' )
),
'accountExpiresProfile' => array (
" Headline " => _ ( 'Account expiration' ), 'attr' => 'accountExpires' ,
" Text " => _ ( 'Number of days after which the account will expire.' )
),
2015-11-07 14:44:34 +00:00
'jpegPhoto' => array (
" Headline " => _ ( " Add photo " ), 'attr' => 'jpegPhoto' ,
" Text " => _ ( " Please select an image file to upload. It must be in JPG format (.jpg/.jpeg). " )
),
'title' => array (
" Headline " => _ ( " Job title " ), 'attr' => 'title' ,
" Text " => _ ( " Job title of user: President, department manager, ... " )
),
'carLicense' => array (
" Headline " => _ ( " Car license " ), 'attr' => 'carLicense' ,
" Text " => _ ( " This can be used to specify if the user has a car license. " )
),
'employeeNumber' => array (
" Headline " => _ ( " Employee number " ), 'attr' => 'employeeNumber' ,
" Text " => _ ( " The user's unique employee number. " )
),
'employeeType' => array (
" Headline " => _ ( " Employee type " ), 'attr' => 'employeeType' ,
" Text " => _ ( " Employee type: Contractor, Employee, Intern, Temp, External, ... " )
),
'businessCategory' => array (
" Headline " => _ ( " Business category " ), 'attr' => 'businessCategory' ,
" Text " => _ ( " Business category (e.g. Administration, IT-Services, Manangement, ...) " )
),
'businessCategoryList' => array (
" Headline " => _ ( " Business category " ), 'attr' => 'businessCategory' ,
" Text " => _ ( " Business category (e.g. Administration, IT-Services, Manangement, ...) " ) . '. ' . _ ( " Multiple values are separated by semicolon. " )
),
'departmentNumber' => array (
" Headline " => _ ( " Department " ), 'attr' => 'departmentNumber' ,
" Text " => _ ( " Here you can enter the user's department. " )
),
'departmentNumberList' => array (
" Headline " => _ ( " Department " ), 'attr' => 'departmentNumber' ,
" Text " => _ ( " Here you can enter the user's department. " ) . ' ' . _ ( " Multiple values are separated by semicolon. " )
),
'ou' => array (
" Headline " => _ ( " Organisational unit " ), 'attr' => 'ou' ,
" Text " => _ ( " The user's organisational unit. " )
),
'ouList' => array (
" Headline " => _ ( " Organisational unit " ), 'attr' => 'ou' ,
" Text " => _ ( " The user's organisational unit. " ) . ' ' . _ ( 'Multiple values are separated by semicolon.' )
),
'o' => array (
" Headline " => _ ( " Organisation " ), 'attr' => 'o' ,
" Text " => _ ( " The user's organisation name. " )
),
'oList' => array (
" Headline " => _ ( " Organisation " ), 'attr' => 'o' ,
" Text " => _ ( " The user's organisation name. " ) . ' ' . _ ( 'Multiple values are separated by semicolon.' )
),
'manager' => array (
" Headline " => _ ( " Manager " ), 'attr' => 'manager' ,
" Text " => _ ( " This is the LDAP DN of the user's manager. Use this property to represent hierarchies in your company. " )
),
2015-11-07 15:43:43 +00:00
'crop' => array (
" Headline " => _ ( 'Image cropping' ),
" Text " => _ ( 'Uploaded images will be cropped to these maximum values.' )
),
'photoUpload' => array (
" Headline " => _ ( " Add photo " ), 'attr' => 'jpegPhoto' ,
" Text " => _ ( " Please select an image file to upload. It must be in JPG format (.jpg/.jpeg). " )
),
2013-04-27 17:38:01 +00:00
);
2013-04-06 15:00:53 +00:00
// upload fields
$return [ 'upload_columns' ] = array (
array (
2013-11-09 13:26:31 +00:00
'name' => 'windowsUser_userPrincipalName' ,
2013-04-07 17:28:09 +00:00
'description' => _ ( 'User name' ),
2013-11-09 13:26:31 +00:00
'help' => 'userPrincipalName' ,
2013-04-07 17:28:09 +00:00
'example' => _ ( 'smiller' ),
2013-04-14 19:19:33 +00:00
'required' => true ,
'unique' => true ,
),
array (
'name' => 'windowsUser_password' ,
'description' => _ ( 'Password' ),
'help' => 'password' ,
'example' => _ ( 'secret' ),
),
array (
'name' => 'windowsUser_firstName' ,
'description' => _ ( 'First name' ),
'help' => 'givenName' ,
'example' => _ ( 'Steve' ),
),
array (
'name' => 'windowsUser_lastName' ,
'description' => _ ( 'Last name' ),
'help' => 'sn' ,
'example' => _ ( 'Miller' ),
),
2013-11-09 13:26:31 +00:00
array (
'name' => 'windowsUser_cn' ,
'description' => _ ( 'Common name' ),
'help' => 'cn' ,
'example' => _ ( 'Steve Miller' ),
),
2013-04-14 19:19:33 +00:00
array (
'name' => 'windowsUser_displayName' ,
'description' => _ ( 'Display name' ),
'help' => 'displayName' ,
'example' => _ ( 'Steve Miller' ),
),
array (
'name' => 'windowsUser_initials' ,
'description' => _ ( 'Initials' ),
'help' => 'initials' ,
'example' => _ ( 'S.M.' ),
2013-04-06 15:00:53 +00:00
),
array (
2013-04-07 17:28:09 +00:00
'name' => 'windowsUser_description' ,
2013-04-06 15:00:53 +00:00
'description' => _ ( 'Description' ),
'help' => 'description' ,
2013-08-20 18:56:52 +00:00
'example' => _ ( 'Temp, contract till December' ),
2013-04-14 19:19:33 +00:00
),
array (
'name' => 'windowsUser_streetAddress' ,
'description' => _ ( 'Street' ),
'help' => 'streetAddress' ,
'example' => _ ( 'Mystreetname 42' ),
),
array (
'name' => 'windowsUser_postOfficeBox' ,
'description' => _ ( 'Post office box' ),
'help' => 'postOfficeBox' ,
'example' => _ ( '12345' ),
),
array (
'name' => 'windowsUser_postalCode' ,
'description' => _ ( 'Postal code' ),
'help' => 'postalCode' ,
'example' => _ ( 'GB-12345' ),
2013-04-06 15:00:53 +00:00
),
array (
2013-04-07 17:28:09 +00:00
'name' => 'windowsUser_l' ,
2013-04-06 15:00:53 +00:00
'description' => _ ( 'Location' ),
2013-04-07 17:28:09 +00:00
'help' => 'l' ,
2013-04-06 15:00:53 +00:00
'example' => _ ( 'MyCity' ),
),
2013-04-14 19:19:33 +00:00
array (
'name' => 'windowsUser_state' ,
'description' => _ ( 'State' ),
'help' => 'st' ,
'example' => _ ( 'New York' ),
),
array (
'name' => 'windowsUser_officeName' ,
'description' => _ ( 'Office name' ),
'help' => 'physicalDeliveryOfficeName' ,
'example' => _ ( 'YourCompany' ),
),
array (
'name' => 'windowsUser_mail' ,
'description' => _ ( 'Email address' ),
'help' => 'mail' ,
'example' => _ ( 'user@company.com' ),
),
2013-04-27 17:38:01 +00:00
array (
'name' => 'windowsUser_otherMailbox' ,
'description' => _ ( 'Email alias' ),
'help' => 'otherMailboxList' ,
'example' => _ ( 'user@company.com' ),
),
2013-04-14 19:19:33 +00:00
array (
'name' => 'windowsUser_telephoneNumber' ,
'description' => _ ( 'Telephone number' ),
'help' => 'telephoneNumber' ,
'example' => _ ( '123-124-1234' ),
),
array (
'name' => 'windowsUser_otherTelephone' ,
'description' => _ ( 'Other telephone numbers' ),
'help' => 'otherTelephoneList' ,
'example' => _ ( '123-124-1234' ),
),
array (
'name' => 'windowsUser_webSite' ,
'description' => _ ( 'Web site' ),
'help' => 'wWWHomePage' ,
'example' => _ ( 'http://www.company.com' ),
),
array (
'name' => 'windowsUser_otherWebSites' ,
'description' => _ ( 'Other web sites' ),
'help' => 'urlList' ,
'example' => _ ( 'http://www.company.com' ),
),
array (
'name' => 'windowsUser_deactivated' ,
'description' => _ ( 'Account is deactivated' ),
'help' => 'deactivated' ,
'example' => _ ( 'no' ),
'default' => _ ( 'no' ),
'values' => _ ( 'yes' ) . ', ' . _ ( 'no' )
),
array (
'name' => 'windowsUser_noExpire' ,
'description' => _ ( 'Password does not expire' ),
'help' => 'noExpire' ,
'example' => _ ( 'no' ),
'default' => _ ( 'no' ),
'values' => _ ( 'yes' ) . ', ' . _ ( 'no' )
),
2015-11-02 20:53:20 +00:00
array (
'name' => 'windowsUser_accountExpires' ,
'description' => _ ( 'Account expiration date' ),
'help' => 'accountExpiresUpload' ,
2015-11-30 18:26:26 +00:00
'example' => '21-11-2030' ,
2015-11-02 20:53:20 +00:00
),
2013-04-14 19:19:33 +00:00
array (
'name' => 'windowsUser_requireCard' ,
'description' => _ ( 'Require smartcard' ),
'help' => 'requireCard' ,
'example' => _ ( 'no' ),
'default' => _ ( 'no' ),
'values' => _ ( 'yes' ) . ', ' . _ ( 'no' )
),
array (
'name' => 'windowsUser_pwdMustChange' ,
'description' => _ ( 'Password change at next login' ),
'help' => 'pwdMustChange' ,
'example' => _ ( 'no' ),
'default' => _ ( 'no' ),
'values' => _ ( 'yes' ) . ', ' . _ ( 'no' )
),
array (
'name' => 'windowsUser_profilePath' ,
'description' => _ ( 'Profile path' ),
'help' => 'profilePath' ,
'example' => _ ( '\\\\server\\profiles\\smiller' ),
),
array (
'name' => 'windowsUser_scriptPath' ,
'description' => _ ( 'Logon script' ),
'help' => 'scriptPath' ,
'example' => 'logon.bat' ,
),
2013-11-23 14:40:06 +00:00
array (
'name' => 'windowsUser_homeDrive' ,
'description' => _ ( 'Home drive' ),
'help' => 'homeDrive' ,
'example' => 'K:'
),
array (
'name' => 'windowsUser_homeDirectory' ,
'description' => _ ( 'Home directory' ),
'help' => 'homeDirectory' ,
'example' => _ ( '\\\\server\\homes\\smiller' )
),
2013-04-14 19:19:33 +00:00
array (
'name' => 'windowsUser_groups' ,
'description' => _ ( 'Groups' ),
'help' => 'groupsUpload' ,
),
2013-04-06 15:00:53 +00:00
);
2016-01-03 15:43:28 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidefacsimileTelephoneNumber' )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_facsimileTelephoneNumber' ,
'description' => _ ( 'Fax number' ),
'help' => 'facsimileTelephoneNumber' ,
'example' => _ ( '123-123-1236' )
);
}
2013-11-09 13:26:31 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidesAMAccountName' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_sAMAccountName' ,
'description' => _ ( 'User name (pre W2K)' ),
'help' => 'sAMAccountName' ,
'example' => _ ( 'smiller' ),
'unique' => true ,
);
}
2014-02-12 19:39:51 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_msSFU30Name' ,
'description' => _ ( 'NIS name' ),
'help' => 'msSFU30Name' ,
'example' => _ ( 'smiller' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_msSFU30NisDomain' ,
'description' => _ ( 'NIS domain' ),
'help' => 'msSFU30NisDomain' ,
'example' => _ ( 'domain' ),
);
}
2015-11-07 14:44:34 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_title' ,
'description' => _ ( 'Job title' ),
'help' => 'title' ,
'example' => _ ( 'President' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_carLicense' ,
'description' => _ ( 'Car license' ),
'help' => 'carLicense' ,
'example' => _ ( 'yes' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_employeeNumber' ,
'description' => _ ( 'Employee number' ),
'help' => 'employeeNumber' ,
'example' => '123456' ,
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_employeeType' ,
'description' => _ ( 'Employee type' ),
'help' => 'employeeType' ,
'example' => _ ( 'Temp' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_businessCategory' ,
'description' => _ ( 'Business category' ),
'help' => 'businessCategoryList' ,
'example' => _ ( 'Administration' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_departmentNumber' ,
'description' => _ ( 'Department' ),
'help' => 'departmentNumberList' ,
'example' => _ ( 'Administration' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_ou' ,
'description' => _ ( 'Organisational unit' ),
'help' => 'ouList' ,
'example' => _ ( 'Administration' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_o' ,
'description' => _ ( 'Organisation' ),
'help' => 'oList' ,
'example' => _ ( 'YourCompany' ),
);
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemanager' , true )) {
$return [ 'upload_columns' ][] = array (
'name' => 'windowsUser_manager' ,
'description' => _ ( 'Manager' ),
'help' => 'manager' ,
'example' => _ ( 'uid=smiller,ou=People,dc=company,dc=com' ),
);
}
2013-12-28 10:47:50 +00:00
// profile options
$profileContainer = new htmlTable ();
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Common name' ), 'windowsUser_cn' , null , 'cn' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Display name' ), 'windowsUser_displayName' , null , 'displayName' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Email address' ), 'windowsUser_mail' , null , 'mail' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Email alias' ), 'windowsUser_otherMailbox' , null , 'otherMailboxList' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Logon script' ), 'windowsUser_scriptPath' , null , 'scriptPath' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Profile path' ), 'windowsUser_profilePath' , null , 'profilePath' ), true );
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Home directory' ), 'windowsUser_homeDirectory' , null , 'homeDirectory' ), true );
2014-02-12 19:39:51 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'NIS domain' ), 'windowsUser_msSFU30NisDomain' , null , 'msSFU30NisDomain' ), true );
}
2015-11-02 20:53:20 +00:00
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Account expiration' ), 'windowsUser_accountExpires' , null , 'accountExpiresProfile' ), true );
2015-11-07 14:44:34 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Department' ), 'windowsUser_departmentNumber' , null , 'departmentNumberList' ), true );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Organisational unit' ), 'windowsUser_ou' , null , 'ouList' ), true );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Organisation' ), 'windowsUser_o' , null , 'oList' ), true );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Job title' ), 'windowsUser_title' , null , 'title' ), true );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Employee type' ), 'windowsUser_employeeType' , null , 'employeeType' ), true );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$profileContainer -> addElement ( new htmlTableExtendedInputField ( _ ( 'Business category' ), 'windowsUser_businessCategory' , null , 'businessCategory' ), true );
}
2013-12-28 10:47:50 +00:00
$return [ 'profile_options' ] = $profileContainer ;
2015-11-08 16:33:08 +00:00
// profile mappings
$return [ 'profile_mappings' ] = array (
'windowsUser_displayName' => 'displayName' ,
'windowsUser_cn' => 'cn' ,
'windowsUser_mail' => 'mail' ,
'windowsUser_scriptPath' => 'scriptPath' ,
'windowsUser_profilePath' => 'profilePath' ,
'windowsUser_homeDirectory' => 'homeDirectory' ,
);
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$return [ 'profile_mappings' ][ 'windowsUser_msSFU30NisDomain' ] = 'msSFU30NisDomain' ;
}
2015-11-02 20:53:20 +00:00
// profile checks
$return [ 'profile_checks' ][ 'windowsUser_accountExpires' ] = array (
'type' => 'ext_preg' ,
'regex' => 'digit' ,
'error_message' => $this -> messages [ 'accountExpires' ][ 0 ]);
2015-11-07 14:44:34 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$return [ 'profile_checks' ][ 'windowsUser_title' ] = array (
'type' => 'ext_preg' ,
'regex' => 'title' ,
'error_message' => $this -> messages [ 'title' ][ 0 ]);
$return [ 'profile_mappings' ][ 'windowsUser_title' ] = 'title' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$return [ 'profile_checks' ][ 'windowsUser_employeeType' ] = array (
'type' => 'ext_preg' ,
'regex' => 'employeeType' ,
'error_message' => $this -> messages [ 'employeeType' ][ 0 ]);
$return [ 'profile_mappings' ][ 'windowsUser_employeeType' ] = 'employeeType' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$return [ 'profile_checks' ][ 'windowsUser_businessCategory' ] = array (
'type' => 'ext_preg' ,
'regex' => 'businessCategory' ,
'error_message' => $this -> messages [ 'businessCategory' ][ 0 ]);
$return [ 'profile_mappings' ][ 'windowsUser_businessCategory' ] = 'businessCategory' ;
}
2013-04-06 15:00:53 +00:00
// available PDF fields
$return [ 'PDF_fields' ] = array (
2013-11-09 13:26:31 +00:00
'userPrincipalName' => _ ( 'User name' ),
'cn' => _ ( 'Common name' ),
2013-04-06 15:00:53 +00:00
'description' => _ ( 'Description' ),
'displayName' => _ ( 'Display name' ),
'givenName' => _ ( 'First name' ),
'initials' => _ ( 'Initials' ),
'l' => _ ( 'Location' ),
'mail' => _ ( 'Email address' ),
2013-04-27 17:38:01 +00:00
'otherMailbox' => _ ( 'Email alias' ),
2013-04-06 15:00:53 +00:00
'otherTelephone' => _ ( 'Other telephone numbers' ),
'physicalDeliveryOfficeName' => _ ( 'Office name' ),
'postalCode' => _ ( 'Postal code' ),
'postOfficeBox' => _ ( 'Post office box' ),
'sn' => _ ( 'Last name' ),
'st' => _ ( 'State' ),
'streetAddress' => _ ( 'Street' ),
'telephoneNumber' => _ ( 'Telephone number' ),
'url' => _ ( 'Other web sites' ),
'wWWHomePage' => _ ( 'Web site' ),
2013-04-14 19:19:33 +00:00
'deactivated' => _ ( 'Account is deactivated' ),
'noExpire' => _ ( 'Password does not expire' ),
'requireCard' => _ ( 'Require smartcard' ),
'profilePath' => _ ( 'Profile path' ),
'scriptPath' => _ ( 'Logon script' ),
'pwdMustChange' => _ ( 'Password change at next login' ),
'groups' => _ ( 'Groups' ),
2013-04-21 18:53:39 +00:00
'password' => _ ( 'Password' ),
2013-11-23 14:40:06 +00:00
'homeDrive' => _ ( 'Home drive' ),
'homeDirectory' => _ ( 'Home directory' ),
2015-11-02 20:53:20 +00:00
'accountExpires' => _ ( 'Account expiration date' ),
2013-04-06 15:00:53 +00:00
);
2016-01-03 15:43:28 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidefacsimileTelephoneNumber' )) {
$return [ 'PDF_fields' ][ 'facsimileTelephoneNumber' ] = _ ( 'Fax number' );
}
2013-11-09 13:26:31 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidesAMAccountName' , true )) {
$return [ 'PDF_fields' ][ 'sAMAccountName' ] = _ ( 'User name (pre W2K)' );
}
2014-02-12 19:39:51 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
$return [ 'PDF_fields' ][ 'msSFU30Name' ] = _ ( 'NIS name' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$return [ 'PDF_fields' ][ 'msSFU30NisDomain' ] = _ ( 'NIS domain' );
}
2015-09-02 16:39:30 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidepwdLastSet' )) {
$return [ 'PDF_fields' ][ 'pwdLastSet' ] = _ ( 'Last password change' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidelastLogonTimestamp' )) {
$return [ 'PDF_fields' ][ 'lastLogonTimestamp' ] = _ ( 'Last login' );
}
2015-11-07 14:44:34 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$return [ 'PDF_fields' ][ 'title' ] = _ ( 'Job title' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )) {
$return [ 'PDF_fields' ][ 'carLicense' ] = _ ( 'Car license' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )) {
$return [ 'PDF_fields' ][ 'employeeNumber' ] = _ ( 'Employee number' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$return [ 'PDF_fields' ][ 'employeeType' ] = _ ( 'Employee type' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$return [ 'PDF_fields' ][ 'businessCategory' ] = _ ( 'Business category' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
$return [ 'PDF_fields' ][ 'departmentNumber' ] = _ ( 'Department' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
$return [ 'PDF_fields' ][ 'ou' ] = _ ( 'Organisational unit' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
$return [ 'PDF_fields' ][ 'o' ] = _ ( 'Organisation' );
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemanager' , true )) {
$return [ 'PDF_fields' ][ 'manager' ] = _ ( 'Manager' );
}
2013-04-20 12:52:30 +00:00
// self service search attributes
2015-11-07 14:44:34 +00:00
$return [ 'selfServiceSearchAttributes' ] = array ( 'sAMAccountName' , 'userPrincipalName' ,
'employeeNumber'
);
2013-04-20 12:52:30 +00:00
// self service field settings
$return [ 'selfServiceFieldSettings' ] = array (
'physicalDeliveryOfficeName' => _ ( 'Office name' ),
'telephoneNumber' => _ ( 'Telephone number' ),
2016-01-03 15:43:28 +00:00
'facsimileTelephoneNumber' => _ ( 'Fax number' ),
2013-04-20 12:52:30 +00:00
'wWWHomePage' => _ ( 'Web site' ),
'streetAddress' => _ ( 'Street' ),
'st' => _ ( 'State' ),
'l' => _ ( 'Location' ),
'postOfficeBox' => _ ( 'Post office box' ),
'postalCode' => _ ( 'Postal code' ),
2015-09-02 16:39:30 +00:00
'unicodePwd' => _ ( 'Password' ),
2015-11-02 20:53:20 +00:00
'pwdLastSet' => _ ( 'Last password change (read-only)' ),
'accountExpires' => _ ( 'Account expiration date (read-only)' ),
2013-04-20 12:52:30 +00:00
);
// possible self service read-only fields
$return [ 'selfServiceReadOnlyFields' ] = array ( 'physicalDeliveryOfficeName' , 'telephoneNumber' ,
2016-01-03 15:43:28 +00:00
'facsimileTelephoneNumber' , 'wWWHomePage' , 'streetAddress' , 'st' , 'l' , 'postOfficeBox' , 'postalCode' );
2013-04-06 15:00:53 +00:00
return $return ;
}
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
/**
* Initializes the module after it became part of an accountContainer
*
* @ param string $base the name of the accountContainer object ( $_SESSION [ $base ])
*/
function init ( $base ) {
// call parent init
parent :: init ( $base );
$this -> groupList = array ();
$this -> groupList_orig = array ();
}
2013-04-06 15:00:53 +00:00
/**
* This function fills the $messages variable with output messages from this module .
*/
public function load_Messages () {
2013-11-09 13:26:31 +00:00
$this -> messages [ 'userPrincipalName' ][ 0 ] = array ( 'ERROR' , _ ( 'User name' ), _ ( 'User name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
$this -> messages [ 'userPrincipalName' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_userPrincipalName' , _ ( 'User name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
$this -> messages [ 'cn' ][ 0 ] = array ( 'ERROR' , _ ( 'Common name' ), _ ( 'Please enter a valid common name!' ));
$this -> messages [ 'cn' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_cn' , _ ( 'Please enter a valid common name!' ));
$this -> messages [ 'sAMAccountName' ][ 0 ] = array ( 'ERROR' , _ ( 'User name (pre W2K)' ), _ ( 'User name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
$this -> messages [ 'sAMAccountName' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_sAMAccountName' , _ ( 'User name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
2013-04-06 15:00:53 +00:00
$this -> messages [ 'displayName' ][ 0 ] = array ( 'ERROR' , _ ( 'Display name' ), _ ( 'Please enter a valid display name!' ));
$this -> messages [ 'displayName' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_displayName' , _ ( 'Please enter a valid display name!' ));
$this -> messages [ 'givenName' ][ 0 ] = array ( 'ERROR' , _ ( 'First name' ), _ ( 'First name contains invalid characters!' ));
$this -> messages [ 'givenName' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_givenName' , _ ( 'First name contains invalid characters!' ));
$this -> messages [ 'sn' ][ 0 ] = array ( 'ERROR' , _ ( 'Last name' ), _ ( 'Last name contains invalid characters or is empty!' ));
$this -> messages [ 'sn' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_sn' , _ ( 'Last name contains invalid characters or is empty!' ));
$this -> messages [ 'telephoneNumber' ][ 0 ] = array ( 'ERROR' , _ ( 'Telephone number' ), _ ( 'Please enter a valid telephone number!' ));
$this -> messages [ 'telephoneNumber' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_telephone' , _ ( 'Please enter a valid telephone number!' ));
2016-01-03 15:43:28 +00:00
$this -> messages [ 'facsimileTelephoneNumber' ][ 0 ] = array ( 'ERROR' , _ ( 'Fax number' ), _ ( 'Please enter a valid fax number!' ));
$this -> messages [ 'facsimileTelephoneNumber' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_facsimileTelephoneNumber' , _ ( 'Please enter a valid fax number!' ));
2013-04-06 15:00:53 +00:00
$this -> messages [ 'otherTelephone' ][ 0 ] = array ( 'ERROR' , _ ( 'Other telephone numbers' ), _ ( 'Please enter a valid telephone number!' ));
$this -> messages [ 'otherTelephone' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_otherTelephone' , _ ( 'Please enter a valid telephone number!' ));
$this -> messages [ 'postalCode' ][ 0 ] = array ( 'ERROR' , _ ( 'Postal code' ), _ ( 'Please enter a valid postal code!' ));
$this -> messages [ 'postalCode' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_postalCode' , _ ( 'Please enter a valid postal code!' ));
$this -> messages [ 'mail' ][ 0 ] = array ( 'ERROR' , _ ( 'Email address' ), _ ( 'Please enter a valid email address!' ));
$this -> messages [ 'mail' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_mail' , _ ( 'Please enter a valid email address!' ));
2013-04-27 17:38:01 +00:00
$this -> messages [ 'otherMailbox' ][ 0 ] = array ( 'ERROR' , _ ( 'Email alias' ), _ ( 'Email alias is invalid!' ));
$this -> messages [ 'otherMailbox' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_otherMailbox' , _ ( 'Email alias is invalid!' ));
2013-04-13 15:57:32 +00:00
$this -> messages [ 'profilePath' ][ 0 ] = array ( 'ERROR' , _ ( 'Profile path' ), _ ( 'Profile path is invalid!' ));
$this -> messages [ 'profilePath' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_profilePath' , _ ( 'Profile path is invalid!' ));
$this -> messages [ 'scriptPath' ][ 0 ] = array ( 'ERROR' , _ ( 'Logon script' ), _ ( 'Logon script is invalid!' ));
$this -> messages [ 'scriptPath' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_scriptPath' , _ ( 'Logon script is invalid!' ));
2013-04-20 12:52:30 +00:00
$this -> messages [ 'unicodePwd' ][ 0 ] = array ( 'ERROR' , _ ( 'Password' ), _ ( 'Please enter the same password in both password fields.' ));
$this -> messages [ 'unicodePwd' ][ 1 ] = array ( 'ERROR' , _ ( 'Password' ), _ ( 'Password contains invalid characters. Valid characters are:' ) . ' a-z, A-Z, 0-9 and #*,.;:_-+!%&/|?{[()]}=@$ §°!' );
2013-11-23 14:40:06 +00:00
$this -> messages [ 'homeDrive' ][ 0 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_homeDrive' , _ ( 'Please enter a valid drive letter.' ));
$this -> messages [ 'homeDirectory' ][ 0 ] = array ( 'ERROR' , _ ( 'Home directory' ), _ ( 'Homedirectory contains invalid characters.' ));
$this -> messages [ 'homeDirectory' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_homeDirectory' , _ ( 'Homedirectory contains invalid characters.' ));
2014-02-12 19:39:51 +00:00
$this -> messages [ 'msSFU30Name' ][ 0 ] = array ( 'ERROR' , _ ( 'NIS name' ), _ ( 'NIS name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
$this -> messages [ 'msSFU30Name' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_msSFU30Name' , _ ( 'NIS name contains invalid characters. Valid characters are: a-z, A-Z, 0-9 and .-_ !' ));
2015-11-02 20:53:20 +00:00
$this -> messages [ 'accountExpires' ][ 0 ] = array ( 'ERROR' , _ ( 'Account expiration' ), _ ( 'Please enter a number.' ));
$this -> messages [ 'accountExpires' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_accountExpires' , _ ( 'Please enter a valid date in format DD-MM-YYYY.' ));
2015-11-07 14:44:34 +00:00
$this -> messages [ 'title' ][ 0 ] = array ( 'ERROR' , _ ( 'Job title' ), _ ( 'Please enter a valid job title!' ));
$this -> messages [ 'title' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_title' , _ ( 'Please enter a valid job title!' ));
$this -> messages [ 'employeeType' ][ 0 ] = array ( 'ERROR' , _ ( 'Employee type' ), _ ( 'Please enter a valid employee type!' ));
$this -> messages [ 'employeeType' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_employeeType' , _ ( 'Please enter a valid employee type!' ));
$this -> messages [ 'businessCategory' ][ 0 ] = array ( 'ERROR' , _ ( 'Business category' ), _ ( 'Please enter a valid business category!' ));
$this -> messages [ 'businessCategory' ][ 1 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_businessCategory' , _ ( 'Please enter a valid business category!' ));
2015-11-08 16:33:08 +00:00
$this -> messages [ 'manager' ][ 0 ] = array ( 'ERROR' , _ ( 'Account %s:' ) . ' windowsUser_manager' , _ ( 'This is not a valid DN!' ));
2015-11-07 15:43:43 +00:00
$this -> messages [ 'file' ][ 0 ] = array ( 'ERROR' , _ ( 'No file selected.' ));
$this -> messages [ 'file' ][ 1 ] = array ( 'ERROR' , _ ( 'Please upload a .jpg/.jpeg file.' ));
$this -> messages [ 'file' ][ 2 ] = array ( 'ERROR' , _ ( 'Unable to process this file.' ));
$this -> messages [ 'file' ][ 3 ] = array ( 'ERROR' , _ ( 'File is too large. Maximum allowed size is %s kB.' ));
2013-04-13 15:57:32 +00:00
}
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
/**
* This function loads all needed LDAP attributes .
*
* @ param array $attr list of attributes
*/
function load_attributes ( $attr ) {
parent :: load_attributes ( $attr );
// get group memberships
$groupList = searchLDAPByAttribute ( 'member' , $this -> getAccountContainer () -> dn_orig , 'group' , array ( 'dn' ), array ( 'group' ));
$this -> groupList_orig = array ();
for ( $i = 0 ; $i < sizeof ( $groupList ); $i ++ ) {
$this -> groupList_orig [] = $groupList [ $i ][ 'dn' ];
}
$this -> groupList_orig = array_values ( array_unique ( $this -> groupList_orig ));
$this -> groupList = $this -> groupList_orig ;
2013-04-06 15:00:53 +00:00
}
2015-08-04 18:41:12 +00:00
2013-04-21 18:53:39 +00:00
/**
* Returns a list of modifications which have to be made to the LDAP account .
*
* @ return array list of modifications
* < br > This function returns an array with 3 entries :
* < br > array ( DN1 ( 'add' => array ( $attr ), 'remove' => array ( $attr ), 'modify' => array ( $attr )), DN2 .... )
* < br > DN is the DN to change . It may be possible to change several DNs ( e . g . create a new user and add him to some groups via attribute memberUid )
* < br > " add " are attributes which have to be added to LDAP entry
* < br > " remove " are attributes which have to be removed from LDAP entry
* < br > " modify " are attributes which have to been modified in LDAP entry
* < br > " info " are values with informational value ( e . g . to be used later by pre / postModify actions )
*/
public function save_attributes () {
$return = parent :: save_attributes ();
// add information about clear text password and password status change
$return [ $this -> getAccountContainer () -> dn_orig ][ 'info' ][ 'userPasswordClearText' ][ 0 ] = $this -> clearTextPassword ;
return $return ;
}
2013-04-06 15:00:53 +00:00
/**
* Returns the HTML meta data for the main account page .
2015-08-04 18:41:12 +00:00
*
2013-04-06 15:00:53 +00:00
* @ return htmlElement HTML meta data
*/
public function display_html_attributes () {
2015-11-08 09:59:20 +00:00
$this -> initCache ();
2013-04-13 15:57:32 +00:00
$containerLeft = new htmlTable ();
$containerLeft -> alignment = htmlElement :: ALIGN_TOP ;
if ( $this -> getAccountContainer () -> isNewAccount && ! isset ( $this -> attributes [ 'userAccountControl' ][ 0 ])) {
$this -> attributes [ 'userAccountControl' ][ 0 ] = windowsUser :: DEFAULT_ACCOUNT_CONTROL ;
}
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'General' )), true );
2013-11-09 13:26:31 +00:00
// user name
$userPrincipalName = '' ;
$userPrincipalNameDomain = '' ;
$domains = $this -> getDomains ();
$domains [] = '' ;
if ( ! empty ( $this -> attributes [ 'userPrincipalName' ][ 0 ])) {
$parts = explode ( '@' , $this -> attributes [ 'userPrincipalName' ][ 0 ]);
$userPrincipalName = $parts [ 0 ];
if ( ! empty ( $parts [ 1 ])) {
$userPrincipalNameDomain = $parts [ 1 ];
if ( ! in_array ( $userPrincipalNameDomain , $domains )) {
$domains [] = $userPrincipalNameDomain ;
}
}
}
$userPrincipalNameLabel = new htmlOutputText ( _ ( 'User name' ));
$userPrincipalNameLabel -> setMarkAsRequired ( true );
$containerLeft -> addElement ( $userPrincipalNameLabel );
$userPrincipalNameGroup = new htmlGroup ();
$userPrincipalNameGroup -> addElement ( new htmlInputField ( 'userPrincipalName' , $userPrincipalName , '15' ));
$userPrincipalNameGroup -> addElement ( new htmlSelect ( 'userPrincipalNameDomain' , $domains , array ( $userPrincipalNameDomain )));
$containerLeft -> addElement ( $userPrincipalNameGroup );
$containerLeft -> addElement ( new htmlHelpLink ( 'userPrincipalName' ), true );
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidesAMAccountName' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'sAMAccountName' , _ ( 'User name (pre W2K)' ));
}
2013-04-13 15:57:32 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'givenName' , _ ( 'First name' ));
$this -> addSimpleInputTextField ( $containerLeft , 'sn' , _ ( 'Last name' ));
2013-11-09 13:26:31 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'cn' , _ ( 'Common name' ), true );
2013-04-13 15:57:32 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'displayName' , _ ( 'Display name' ));
$this -> addSimpleInputTextField ( $containerLeft , 'initials' , _ ( 'Initials' ));
$this -> addSimpleInputTextField ( $containerLeft , 'description' , _ ( 'Description' ));
2015-11-08 09:59:20 +00:00
// address area
2013-04-13 15:57:32 +00:00
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'Address' )), true );
$this -> addSimpleInputTextField ( $containerLeft , 'streetAddress' , _ ( 'Street' ), false , 20 , true );
$this -> addSimpleInputTextField ( $containerLeft , 'postOfficeBox' , _ ( 'Post office box' ));
$this -> addSimpleInputTextField ( $containerLeft , 'postalCode' , _ ( 'Postal code' ));
$this -> addSimpleInputTextField ( $containerLeft , 'l' , _ ( 'Location' ));
$this -> addSimpleInputTextField ( $containerLeft , 'st' , _ ( 'State' ));
$this -> addSimpleInputTextField ( $containerLeft , 'physicalDeliveryOfficeName' , _ ( 'Office name' ));
2015-11-08 09:59:20 +00:00
// contact data area
2013-04-13 15:57:32 +00:00
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'Contact data' )), true );
$this -> addSimpleInputTextField ( $containerLeft , 'mail' , _ ( 'Email address' ));
2013-04-27 17:38:01 +00:00
$this -> addMultiValueInputTextField ( $containerLeft , 'otherMailbox' , _ ( 'Email alias' ));
2013-04-13 15:57:32 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'telephoneNumber' , _ ( 'Telephone number' ));
$this -> addMultiValueInputTextField ( $containerLeft , 'otherTelephone' , _ ( 'Other telephone numbers' ));
2016-01-03 15:43:28 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidefacsimileTelephoneNumber' )) {
$this -> addSimpleInputTextField ( $containerLeft , 'facsimileTelephoneNumber' , _ ( 'Fax number' ));
}
2013-04-13 15:57:32 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'wWWHomePage' , _ ( 'Web site' ));
$this -> addMultiValueInputTextField ( $containerLeft , 'url' , _ ( 'Other web sites' ));
2015-11-08 09:59:20 +00:00
// work details area
if ( $this -> manageWorkDetails ()) {
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'Work details' )), true );
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'title' , _ ( 'Job title' ), false , null , false , array_slice ( $this -> titleCache , 0 , 300 ));
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'carLicense' , _ ( 'Car license' ));
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'employeeNumber' , _ ( 'Employee number' ));
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'employeeType' , _ ( 'Employee type' ), false , null , false , array_slice ( $this -> employeeTypeCache , 0 , 300 ));
}
2015-11-08 10:00:40 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
2015-11-08 09:59:20 +00:00
$this -> addMultiValueInputTextField ( $containerLeft , 'businessCategory' , _ ( 'Business category' ), false , null , false , array_slice ( $this -> businessCategoryCache , 0 , 300 ));
}
2015-11-08 10:00:40 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
2015-11-08 09:59:20 +00:00
$this -> addMultiValueInputTextField ( $containerLeft , 'departmentNumber' , _ ( 'Department' ), false , null , false , array_slice ( $this -> departmentCache , 0 , 300 ));
}
2015-11-08 10:00:40 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
2015-11-08 09:59:20 +00:00
$this -> addMultiValueInputTextField ( $containerLeft , 'ou' , _ ( 'Organisational unit' ), false , null , false , array_slice ( $this -> ouCache , 0 , 300 ));
}
2015-11-08 10:00:40 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
2015-11-08 09:59:20 +00:00
$this -> addMultiValueInputTextField ( $containerLeft , 'o' , _ ( 'Organisation' ), false , null , false , array_slice ( $this -> oCache , 0 , 300 ));
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemanager' , true )) {
$containerLeft -> addElement ( new htmlOutputText ( _ ( 'Manager' )));
$managerGroup = new htmlGroup ();
$managerVal = ( empty ( $this -> attributes [ 'manager' ][ 0 ])) ? '-' : getAbstractDN ( $this -> attributes [ 'manager' ][ 0 ]);
$managerGroup -> addElement ( new htmlOutputText ( $managerVal ));
$managerGroup -> addElement ( new htmlSpacer ( '5px' , null ));
$managerGroup -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'manager' , 'change' , _ ( " Change " )));
$containerLeft -> addElement ( $managerGroup );
$containerLeft -> addElement ( new htmlHelpLink ( 'manager' ), true );
}
}
// account area
2015-09-02 16:39:30 +00:00
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'Account' )), true );
2013-04-13 15:57:32 +00:00
// locked out
$containerLeft -> addElement ( new htmlOutputText ( _ ( " Account is locked " )));
$lockedOut = windowsUser :: isLockedOut ( $this -> attributes );
$lockedOutCheckbox = new htmlInputCheckbox ( 'lockedOut' , $lockedOut );
$lockedOutCheckbox -> setIsEnabled ( false );
$lockedOutGroup = new htmlGroup ();
$lockedOutGroup -> addElement ( $lockedOutCheckbox );
if ( $lockedOut ) {
$lockedOutGroup -> addElement ( new htmlButton ( 'unlock' , _ ( 'Unlock' )));
}
$containerLeft -> addElement ( $lockedOutGroup );
$containerLeft -> addElement ( new htmlHelpLink ( 'locked' ), true );
// password change required
$pwdMustChange = false ;
if ( isset ( $this -> attributes [ 'pwdLastSet' ][ 0 ]) && ( $this -> attributes [ 'pwdLastSet' ][ 0 ] === '0' )) {
$pwdMustChange = true ;
}
2013-04-21 16:41:19 +00:00
$containerLeft -> addElement ( new htmlTableExtendedInputCheckbox ( 'forcePasswordChangeOption' , $pwdMustChange , _ ( " User must change password " ), 'pwdMustChange' ), true );
2013-04-13 15:57:32 +00:00
// deactivated
$deactivated = windowsUser :: isDeactivated ( $this -> attributes );
$containerLeft -> addElement ( new htmlTableExtendedInputCheckbox ( 'deactivated' , $deactivated , _ ( " Account is deactivated " ), 'deactivated' ), true );
// password does not expire
$noExpire = windowsUser :: isNeverExpiring ( $this -> attributes );
$containerLeft -> addElement ( new htmlTableExtendedInputCheckbox ( 'noExpire' , $noExpire , _ ( " Password does not expire " ), 'noExpire' ), true );
// require smartcard
$requireCard = windowsUser :: isSmartCardRequired ( $this -> attributes );
$containerLeft -> addElement ( new htmlTableExtendedInputCheckbox ( 'requireCard' , $requireCard , _ ( " Require smartcard " ), 'requireCard' ), true );
2015-11-02 20:53:20 +00:00
// account expiration
$containerLeft -> addElement ( new htmlOutputText ( _ ( 'Account expiration date' )));
$accountExpiresGroup = new htmlGroup ();
$accountExpiresGroup -> addElement ( new htmlOutputText ( $this -> formatAccountExpires ()));
$accountExpiresGroup -> addElement ( new htmlSpacer ( '5px' , null ));
$accountExpiresGroup -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'accountExpires' , 'edit' , _ ( 'Change' )));
$containerLeft -> addElement ( $accountExpiresGroup );
$containerLeft -> addElement ( new htmlHelpLink ( 'accountExpires' ), true );
2015-09-02 16:39:30 +00:00
// last password change
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidepwdLastSet' )) {
$containerLeft -> addElement ( new htmlOutputText ( _ ( 'Last password change' )));
$containerLeft -> addElement ( new htmlOutputText ( $this -> formatPwdLastSet ()));
$containerLeft -> addElement ( new htmlHelpLink ( 'pwdLastSet' ), true );
}
// last login
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidelastLogonTimestamp' )) {
$containerLeft -> addElement ( new htmlOutputText ( _ ( 'Last login' )));
$containerLeft -> addElement ( new htmlOutputText ( $this -> formatLastLogonTimestamp ()));
$containerLeft -> addElement ( new htmlHelpLink ( 'lastLogonTimestamp' ), true );
}
2015-11-08 09:59:20 +00:00
// user profile area
2013-04-13 15:57:32 +00:00
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'User profile' )), true );
// profile path
$this -> addSimpleInputTextField ( $containerLeft , 'profilePath' , _ ( 'Profile path' ));
// logon script
$this -> addSimpleInputTextField ( $containerLeft , 'scriptPath' , _ ( 'Logon script' ));
2013-11-23 14:40:06 +00:00
// home drive
$drives = array ( '-' );
for ( $i = 90 ; $i > 67 ; $i -- ) $drives [] = chr ( $i ) . ':' ;
if ( ! empty ( $this -> attributes [ 'homeDrive' ][ 0 ])) {
$selected = array ( strtoupper ( $this -> attributes [ 'homeDrive' ][ 0 ]));
}
else {
$selected = array ( '-' );
}
$containerLeft -> addElement ( new htmlTableExtendedSelect ( 'homeDrive' , $drives , $selected , _ ( 'Home drive' ), 'homeDrive' ), true );
// home directory
2014-07-26 12:44:32 +00:00
$this -> addSimpleInputTextField ( $containerLeft , 'homeDirectory' , _ ( 'Home directory' ));
2015-08-04 18:41:12 +00:00
2014-02-12 19:39:51 +00:00
// NIS attributes
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true ) || ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$containerLeft -> addElement ( new htmlSubTitle ( _ ( 'NIS' )), true );
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'msSFU30Name' , _ ( 'NIS name' ));
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
$this -> addSimpleInputTextField ( $containerLeft , 'msSFU30NisDomain' , _ ( 'NIS domain' ));
}
}
2015-08-04 18:41:12 +00:00
2014-02-12 19:39:51 +00:00
$containerLeft -> addElement ( new htmlEqualWidth ( array ( 'streetAddress' , 'cn' )), true );
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
$containerRight = new htmlTable ();
$containerRight -> alignment = htmlElement :: ALIGN_TOP ;
2015-11-07 15:43:43 +00:00
// photo
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidejpegPhoto' , true )) {
$imageContainer = new htmlTable ();
$imageContainer -> alignment = htmlElement :: ALIGN_TOP ;
$photoFile = '../../graphics/userDefault.png' ;
$noPhoto = true ;
if ( isset ( $this -> attributes [ 'jpegPhoto' ][ 0 ])) {
$jpeg_filename = 'jpg' . getRandomNumber () . '.jpg' ;
$outjpeg = @ fopen ( dirname ( __FILE__ ) . '/../../tmp/' . $jpeg_filename , " wb " );
fwrite ( $outjpeg , $this -> attributes [ 'jpegPhoto' ][ 0 ]);
fclose ( $outjpeg );
$photoFile = '../../tmp/' . $jpeg_filename ;
$noPhoto = false ;
}
$img = new htmlImage ( $photoFile );
$img -> setCSSClasses ( array ( 'photo' ));
$imageContainer -> addElement ( $img , true );
if ( $noPhoto ) {
$imageContainer -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'photo' , 'open' , _ ( 'Add photo' )));
}
else {
$imageContainer -> addElement ( new htmlButton ( 'delPhoto' , _ ( 'Delete photo' )));
}
$containerRight -> addElement ( $imageContainer , true );
$containerRight -> addElement ( new htmlSpacer ( null , '20px' ), true );
}
// groups
2013-04-13 15:57:32 +00:00
$containerRight -> addElement ( new htmlSubTitle ( _ ( 'Groups' )), true );
$containerRight -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'group' , 'edit' , _ ( 'Edit groups' )), true );
$containerRight -> addElement ( new htmlSpacer ( null , '10px' ), true );
$groupsList = new htmlGroup ();
$groupCNs = array ();
for ( $i = 0 ; $i < sizeof ( $this -> groupList ); $i ++ ) {
$groupCNs [] = extractRDNValue ( $this -> groupList [ $i ]);
}
natcasesort ( $groupCNs );
foreach ( $groupCNs as $cn ) {
$groupsList -> addElement ( new htmlOutputText ( $cn ));
$groupsList -> addElement ( new htmlOutputText ( '<br>' , false ));
}
$containerRight -> addElement ( $groupsList );
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
$container = new htmlTable ();
$container -> addElement ( $containerLeft );
$container -> addElement ( new htmlSpacer ( '40px' , null ));
$container -> addElement ( $containerRight );
2013-04-06 15:00:53 +00:00
return $container ;
}
2015-11-08 09:59:20 +00:00
/**
* Returns if any of the work details attributes should be managed .
*
* @ return boolean has any work attributes to manage
*/
private function manageWorkDetails () {
$allHidden = $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )
&& $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemanager' , true );
return ! $allHidden ;
}
2013-04-06 15:00:53 +00:00
/**
* Processes user input of the primary module page .
* It checks if all input values are correct and updates the associated LDAP attributes .
*
* @ return array list of info / error messages
*/
public function process_attributes () {
$return = array ();
2013-12-28 10:47:50 +00:00
$replacements = array ( '$user' => 'userPrincipalName' , '$lastname' => 'sn' , '$firstname' => 'givenName' );
2013-11-09 13:26:31 +00:00
// user name
$userPrincipalName = $_POST [ 'userPrincipalName' ];
if ( ! get_preg ( $userPrincipalName , 'username' )) {
$return [] = $this -> messages [ 'userPrincipalName' ][ 0 ];
}
if ( ! empty ( $_POST [ 'userPrincipalNameDomain' ])) {
$userPrincipalName .= '@' . $_POST [ 'userPrincipalNameDomain' ];
}
$this -> attributes [ 'userPrincipalName' ][ 0 ] = $userPrincipalName ;
2013-04-06 15:00:53 +00:00
// cn
$this -> attributes [ 'cn' ][ 0 ] = $_POST [ 'cn' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'cn' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'cn' ][ 0 ]);
}
}
2013-11-09 13:26:31 +00:00
if ( empty ( $this -> attributes [ 'cn' ][ 0 ])) {
$cn = '' ;
if ( ! empty ( $_POST [ 'givenName' ])) {
$cn = $_POST [ 'givenName' ];
}
if ( ! empty ( $_POST [ 'sn' ])) {
$cn .= ' ' . $_POST [ 'sn' ];
}
$this -> attributes [ 'cn' ][ 0 ] = trim ( $cn );
}
if ( ! get_preg ( $this -> attributes [ 'cn' ][ 0 ], 'cn' )) {
2013-04-06 15:00:53 +00:00
$return [] = $this -> messages [ 'cn' ][ 0 ];
}
2013-11-09 13:26:31 +00:00
// sAMAccountName
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidesAMAccountName' , true )) {
if ( $this -> getAccountContainer () -> isNewAccount && ! isset ( $this -> attributes [ 'sAMAccountName' ]) && empty ( $_POST [ 'sAMAccountName' ])) {
$this -> attributes [ 'sAMAccountName' ][ 0 ] = $_POST [ 'userPrincipalName' ];
}
else {
$this -> attributes [ 'sAMAccountName' ][ 0 ] = $_POST [ 'sAMAccountName' ];
}
if ( ! empty ( $this -> attributes [ 'sAMAccountName' ][ 0 ]) && ! get_preg ( $this -> attributes [ 'sAMAccountName' ][ 0 ], 'username' )) {
$return [] = $this -> messages [ 'sAMAccountName' ][ 0 ];
}
}
2014-07-26 12:44:32 +00:00
elseif ( $this -> getAccountContainer () -> isNewAccount && ! empty ( $_POST [ 'userPrincipalName' ])) {
// set sAMAccountName to user name if attribute input field is not visible (W2012 requires this attribute)
$this -> attributes [ 'sAMAccountName' ][ 0 ] = $_POST [ 'userPrincipalName' ];
}
2013-04-06 15:00:53 +00:00
// description
$this -> attributes [ 'description' ][ 0 ] = $_POST [ 'description' ];
// display name
$this -> attributes [ 'displayName' ][ 0 ] = $_POST [ 'displayName' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'displayName' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'displayName' ][ 0 ]);
}
}
if ( ! empty ( $this -> attributes [ 'displayName' ][ 0 ]) && ! get_preg ( $this -> attributes [ 'displayName' ][ 0 ], 'realname' )) {
2013-04-06 15:00:53 +00:00
$return [] = $this -> messages [ 'displayName' ][ 0 ];
}
2013-11-09 13:26:31 +00:00
if ( empty ( $this -> attributes [ 'displayName' ][ 0 ]) && ! empty ( $this -> attributes [ 'cn' ][ 0 ])) {
$this -> attributes [ 'displayName' ][ 0 ] = $this -> attributes [ 'cn' ][ 0 ];
}
2013-04-06 15:00:53 +00:00
// first name
$this -> attributes [ 'givenName' ][ 0 ] = $_POST [ 'givenName' ];
if ( ! empty ( $this -> attributes [ 'givenName' ][ 0 ]) && ! get_preg ( $_POST [ 'givenName' ], 'realname' )) {
$return [] = $this -> messages [ 'givenName' ][ 0 ];
}
// initials
$this -> attributes [ 'initials' ][ 0 ] = $_POST [ 'initials' ];
// location
$this -> attributes [ 'l' ][ 0 ] = $_POST [ 'l' ];
// email
$this -> attributes [ 'mail' ][ 0 ] = $_POST [ 'mail' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'mail' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'mail' ][ 0 ]);
}
}
if ( ! empty ( $this -> attributes [ 'mail' ][ 0 ]) && ! get_preg ( $this -> attributes [ 'mail' ][ 0 ], 'email' )) {
2013-04-06 15:00:53 +00:00
$return [] = $this -> messages [ 'mail' ][ 0 ];
}
2013-04-27 17:38:01 +00:00
// email aliases
$this -> processMultiValueInputTextField ( 'otherMailbox' , $return , 'email' );
2013-12-28 10:47:50 +00:00
if ( ! empty ( $this -> attributes [ 'otherMailbox' ])) {
foreach ( $this -> attributes [ 'otherMailbox' ] as & $otherMailbox ) {
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$otherMailbox = str_replace ( $wildcard , $_POST [ $postKey ], $otherMailbox );
}
}
2015-08-04 18:41:12 +00:00
}
2013-12-28 10:47:50 +00:00
}
2013-04-06 15:00:53 +00:00
// other telephones
$this -> processMultiValueInputTextField ( 'otherTelephone' , $return , 'telephone' );
2016-01-03 15:43:28 +00:00
// fax number
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidefacsimileTelephoneNumber' )) {
$this -> attributes [ 'facsimileTelephoneNumber' ][ 0 ] = $_POST [ 'facsimileTelephoneNumber' ];
if ( ! get_preg ( $_POST [ 'facsimileTelephoneNumber' ], 'telephone' )) {
$return [] = $this -> messages [ 'facsimileTelephoneNumber' ][ 0 ];
}
}
2013-04-06 15:00:53 +00:00
// office name
$this -> attributes [ 'physicalDeliveryOfficeName' ][ 0 ] = $_POST [ 'physicalDeliveryOfficeName' ];
// postal code
$this -> attributes [ 'postalCode' ][ 0 ] = $_POST [ 'postalCode' ];
if ( ! get_preg ( $_POST [ 'postalCode' ], 'postalCode' )) {
$return [] = $this -> messages [ 'postalCode' ][ 0 ];
}
// post office box
$this -> attributes [ 'postOfficeBox' ][ 0 ] = $_POST [ 'postOfficeBox' ];
// last name
$this -> attributes [ 'sn' ][ 0 ] = $_POST [ 'sn' ];
if ( ! empty ( $this -> attributes [ 'sn' ][ 0 ]) && ! get_preg ( $_POST [ 'sn' ], 'realname' )) {
$return [] = $this -> messages [ 'sn' ][ 0 ];
}
// state
$this -> attributes [ 'st' ][ 0 ] = $_POST [ 'st' ];
// street
$this -> attributes [ 'streetAddress' ][ 0 ] = $_POST [ 'streetAddress' ];
// telephone
$this -> attributes [ 'telephoneNumber' ][ 0 ] = $_POST [ 'telephoneNumber' ];
if ( ! get_preg ( $_POST [ 'telephoneNumber' ], 'telephone' )) {
$return [] = $this -> messages [ 'telephoneNumber' ][ 0 ];
}
// other web sites
$this -> processMultiValueInputTextField ( 'url' , $return );
// web site
$this -> attributes [ 'wWWHomePage' ][ 0 ] = $_POST [ 'wWWHomePage' ];
2013-04-13 15:57:32 +00:00
// password must be changed
2013-04-21 16:41:19 +00:00
if ( isset ( $_POST [ 'forcePasswordChangeOption' ]) && ( $_POST [ 'forcePasswordChangeOption' ] == 'on' )) {
2013-04-13 15:57:32 +00:00
$this -> attributes [ 'pwdLastSet' ][ 0 ] = '0' ;
}
else {
if ( isset ( $this -> orig [ 'pwdLastSet' ][ 0 ]) && ( $this -> orig [ 'pwdLastSet' ][ 0 ] !== '0' )) {
$this -> attributes [ 'pwdLastSet' ][ 0 ] = $this -> orig [ 'pwdLastSet' ][ 0 ];
}
else {
$this -> attributes [ 'pwdLastSet' ][ 0 ] = '-1' ;
}
}
2013-04-21 16:41:19 +00:00
// save pwdLastSet for postModifyActions
$this -> pwdLastSet = null ;
if ( isset ( $this -> attributes [ 'pwdLastSet' ][ 0 ])) {
if ( ! isset ( $this -> orig [ 'pwdLastSet' ][ 0 ]) || ( $this -> orig [ 'pwdLastSet' ][ 0 ] != $this -> attributes [ 'pwdLastSet' ][ 0 ])) {
$this -> pwdLastSet = $this -> attributes [ 'pwdLastSet' ][ 0 ];
}
}
2013-04-13 15:57:32 +00:00
// deactivated
$deactivated = isset ( $_POST [ 'deactivated' ]) && ( $_POST [ 'deactivated' ] == 'on' );
2013-04-20 08:32:12 +00:00
windowsUser :: setIsDeactivated ( $deactivated );
2013-04-13 15:57:32 +00:00
// no expire
$noExpire = isset ( $_POST [ 'noExpire' ]) && ( $_POST [ 'noExpire' ] == 'on' );
windowsUser :: setIsNeverExpiring ( $this -> attributes , $noExpire );
// smartcard required
$requireCard = isset ( $_POST [ 'requireCard' ]) && ( $_POST [ 'requireCard' ] == 'on' );
windowsUser :: setIsSmartCardRequired ( $this -> attributes , $requireCard );
// profile path
$this -> attributes [ 'profilePath' ][ 0 ] = $_POST [ 'profilePath' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'profilePath' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'profilePath' ][ 0 ]);
}
}
2013-04-13 15:57:32 +00:00
if ( ! ( $this -> attributes [ 'profilePath' ][ 0 ] == '' ) && ! get_preg ( $this -> attributes [ 'profilePath' ][ 0 ], 'UNC' )) {
$return [] = $this -> messages [ 'profilePath' ][ 0 ];
}
// logon script
$this -> attributes [ 'scriptPath' ][ 0 ] = $_POST [ 'scriptPath' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'scriptPath' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'scriptPath' ][ 0 ]);
}
}
2013-04-13 15:57:32 +00:00
if (( $this -> attributes [ 'scriptPath' ][ 0 ] != '' ) && ( ! get_preg ( $this -> attributes [ 'scriptPath' ][ 0 ], 'logonscript' ))) {
$return [] = $this -> messages [ 'scriptPath' ][ 0 ];
2013-04-07 17:28:09 +00:00
}
2013-11-23 14:40:06 +00:00
// home drive
if ( $_POST [ 'homeDrive' ] == " - " ) {
$this -> attributes [ 'homeDrive' ][ 0 ] = '' ;
}
else {
$this -> attributes [ 'homeDrive' ][ 0 ] = $_POST [ 'homeDrive' ];
}
// home directory
$this -> attributes [ 'homeDirectory' ][ 0 ] = $_POST [ 'homeDirectory' ];
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $postKey ) {
if ( ! empty ( $_POST [ $postKey ])) {
$this -> attributes [ 'homeDirectory' ][ 0 ] = str_replace ( $wildcard , $_POST [ $postKey ], $this -> attributes [ 'homeDirectory' ][ 0 ]);
}
}
2013-11-23 14:40:06 +00:00
if ( ! empty ( $this -> attributes [ 'homeDrive' ][ 0 ]) && ! get_preg ( $this -> attributes [ 'homeDirectory' ][ 0 ], 'UNC' )) {
$return [] = $this -> messages [ 'homeDirectory' ][ 0 ];
}
2014-02-12 19:39:51 +00:00
// NIS name
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
if ( $this -> getAccountContainer () -> isNewAccount && ! isset ( $this -> attributes [ 'msSFU30Name' ]) && empty ( $_POST [ 'msSFU30Name' ])) {
$this -> attributes [ 'msSFU30Name' ][ 0 ] = $_POST [ 'userPrincipalName' ];
}
else {
$this -> attributes [ 'msSFU30Name' ][ 0 ] = $_POST [ 'msSFU30Name' ];
}
if ( ! empty ( $this -> attributes [ 'msSFU30Name' ][ 0 ]) && ! get_preg ( $this -> attributes [ 'msSFU30Name' ][ 0 ], 'username' )) {
$return [] = $this -> messages [ 'msSFU30Name' ][ 0 ];
}
}
// NIS domain
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
$this -> attributes [ 'msSFU30NisDomain' ][ 0 ] = $_POST [ 'msSFU30NisDomain' ];
}
2015-11-08 09:59:20 +00:00
// title
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
2015-11-08 09:59:20 +00:00
$this -> attributes [ 'title' ][ 0 ] = $_POST [ 'title' ];
}
// car license
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )) {
2015-11-08 09:59:20 +00:00
$this -> attributes [ 'carLicense' ][ 0 ] = $_POST [ 'carLicense' ];
}
// employee number
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )) {
2015-11-08 09:59:20 +00:00
$this -> attributes [ 'employeeNumber' ][ 0 ] = $_POST [ 'employeeNumber' ];
}
// employee type
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
2015-11-08 09:59:20 +00:00
$this -> attributes [ 'employeeType' ][ 0 ] = $_POST [ 'employeeType' ];
}
// business category
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
2015-11-08 09:59:20 +00:00
$this -> processMultiValueInputTextField ( 'businessCategory' , $return , 'businessCategory' );
}
// department
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
2015-11-08 09:59:20 +00:00
$this -> processMultiValueInputTextField ( 'departmentNumber' , $return );
}
// organizational unit
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
2015-11-08 09:59:20 +00:00
$this -> processMultiValueInputTextField ( 'ou' , $return );
}
// organisation
2015-11-08 16:33:08 +00:00
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
2015-11-08 09:59:20 +00:00
$this -> processMultiValueInputTextField ( 'o' , $return );
}
2013-04-06 15:00:53 +00:00
return $return ;
}
2015-08-04 18:41:12 +00:00
2015-11-02 20:53:20 +00:00
/**
* This function will create the meta HTML code to show a page to change account expiration .
*
* @ return htmlElement meta HTML code
*/
function display_html_accountExpires () {
$return = new htmlTable ();
$attr = 'accountExpires' ;
$text = _ ( 'Account expiration date' );
$help = " accountExpires " ;
$datetime = new DateTime ( 'now' , getTimeZone ());
if ( ! empty ( $this -> attributes [ $attr ][ 0 ]) && ! ( $this -> attributes [ $attr ][ 0 ] == '0' )) {
2015-11-27 21:03:27 +00:00
$datetime = windowsUser :: getFileTime ( $this -> attributes [ $attr ][ 0 ]);
2015-11-02 20:53:20 +00:00
}
for ( $i = 1 ; $i <= 31 ; $i ++ ) $mday [] = $i ;
for ( $i = 1 ; $i <= 12 ; $i ++ ) $mon [] = $i ;
for ( $i = 2003 ; $i <= 2050 ; $i ++ ) $year [] = $i ;
$return -> addElement ( new htmlOutputText ( $text ));
$return -> addElement ( new htmlSelect ( 'expire_day' , $mday , array ( $datetime -> format ( 'd' ))));
$return -> addElement ( new htmlSelect ( 'expire_mon' , $mon , array ( $datetime -> format ( 'm' ))));
$return -> addElement ( new htmlSelect ( 'expire_yea' , $year , array ( $datetime -> format ( 'Y' ))));
$return -> addElement ( new htmlHelpLink ( $help ), true );
if ( $this -> getAccountContainer () -> getAccountModule ( 'shadowAccount' ) != null ) {
$return -> addElement ( new htmlTableExtendedInputCheckbox ( 'syncShadow' , false , _ ( 'Set also for Shadow' )), true );
}
if ( $this -> getAccountContainer () -> getAccountModule ( 'heimdalKerberos' ) != null ) {
$return -> addElement ( new htmlTableExtendedInputCheckbox ( 'syncHeimdal' , false , _ ( 'Set also for Kerberos' )), true );
}
if ( $this -> getAccountContainer () -> getAccountModule ( 'mitKerberos' ) != null ) {
$return -> addElement ( new htmlTableExtendedInputCheckbox ( 'syncMIT' , false , _ ( 'Set also for Kerberos' )), true );
}
if ( $this -> getAccountContainer () -> getAccountModule ( 'mitKerberosStructural' ) != null ) {
$return -> addElement ( new htmlTableExtendedInputCheckbox ( 'syncMITStructural' , false , _ ( 'Set also for Kerberos' )), true );
}
$return -> addElement ( new htmlSpacer ( null , '10px' ), true );
$buttons = new htmlTable ();
$buttons -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'change' . $attr , _ ( 'Change' )));
if ( isset ( $this -> attributes [ $attr ][ 0 ])) {
$buttons -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'del' . $attr , _ ( 'Remove' )));
}
$buttons -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'back' . $attr , _ ( 'Cancel' )));
$buttons -> colspan = 6 ;
$return -> addElement ( $buttons );
return $return ;
}
/**
* Processes user input of the account expiration page .
*
* @ return array list of info / error messages
*/
function process_accountExpires () {
$return = array ();
// find button name
$buttonName = '' ;
$postKeys = array_keys ( $_POST );
for ( $i = 0 ; $i < sizeof ( $postKeys ); $i ++ ) {
if ( strpos ( $postKeys [ $i ], 'form_subpage_windowsUser_attributes_' ) !== false ) {
$buttonName = $postKeys [ $i ];
}
}
if (( $buttonName == '' ) || ( strpos ( $buttonName , '_back' ) !== false )) return array ();
$attr = 'accountExpires' ;
// determine action
if ( strpos ( $buttonName , '_change' ) !== false ) {
// set new time
$this -> setExpirationDate ( $_POST [ 'expire_yea' ], $_POST [ 'expire_mon' ], $_POST [ 'expire_day' ]);
// sync other modules
if ( isset ( $_POST [ 'syncShadow' ]) && ( $_POST [ 'syncShadow' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'shadowAccount' ) -> setExpirationDate (
$_POST [ 'expire_yea' ], $_POST [ 'expire_mon' ], $_POST [ 'expire_day' ]);
}
if ( isset ( $_POST [ 'syncHeimdal' ]) && ( $_POST [ 'syncHeimdal' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'heimdalKerberos' ) -> setExpirationDate (
$_POST [ 'expire_yea' ], $_POST [ 'expire_mon' ], $_POST [ 'expire_day' ]);
}
if ( isset ( $_POST [ 'syncMIT' ]) && ( $_POST [ 'syncMIT' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'mitKerberos' ) -> setExpirationDate (
$_POST [ 'expire_yea' ], $_POST [ 'expire_mon' ], $_POST [ 'expire_day' ]);
}
if ( isset ( $_POST [ 'syncMITStructural' ]) && ( $_POST [ 'syncMITStructural' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'mitKerberosStructural' ) -> setExpirationDate (
$_POST [ 'expire_yea' ], $_POST [ 'expire_mon' ], $_POST [ 'expire_day' ]);
}
}
elseif ( strpos ( $buttonName , '_del' ) !== false ) {
// remove attribute value
unset ( $this -> attributes [ $attr ]);
// sync other modules
if ( isset ( $_POST [ 'syncShadow' ]) && ( $_POST [ 'syncShadow' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'shadowAccount' ) -> setExpirationDate (
null , null , null );
}
if ( isset ( $_POST [ 'syncHeimdal' ]) && ( $_POST [ 'syncHeimdal' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'heimdalKerberos' ) -> setExpirationDate (
null , null , null );
}
if ( isset ( $_POST [ 'syncMIT' ]) && ( $_POST [ 'syncMIT' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'mitKerberos' ) -> setExpirationDate (
null , null , null );
}
if ( isset ( $_POST [ 'syncMITStructural' ]) && ( $_POST [ 'syncMITStructural' ] == 'on' )) {
$this -> getAccountContainer () -> getAccountModule ( 'mitKerberosStructural' ) -> setExpirationDate (
null , null , null );
}
}
return $return ;
}
2013-04-13 15:57:32 +00:00
/**
* Displays the group selection .
*
* @ return htmlElement meta HTML code
*/
function display_html_group () {
$return = new htmlTable ();
$groups = $this -> findGroups ();
// sort by DN
usort ( $groups , 'compareDN' );
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
$groupContainer = new htmlTable ();
$groupContainer -> alignment = htmlElement :: ALIGN_TOP ;
2015-06-07 07:38:49 +00:00
$groupContainer -> addElement ( new htmlSubTitle ( _ ( " Groups " )), true );
2013-04-13 15:57:32 +00:00
$groupContainer -> addElement ( new htmlOutputText ( _ ( " Selected groups " )));
$groupContainer -> addElement ( new htmlOutputText ( '' ));
$groupContainer -> addElement ( new htmlOutputText ( _ ( " Available groups " )));
$groupContainer -> addNewLine ();
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
$selectedGroups = array ();
// sort by DN
usort ( $this -> groupList , 'compareDN' );
for ( $i = 0 ; $i < sizeof ( $this -> groupList ); $i ++ ) {
if ( in_array ( $this -> groupList [ $i ], $groups )) {
$selectedGroups [ getAbstractDN ( $this -> groupList [ $i ])] = $this -> groupList [ $i ];
}
}
$availableGroups = array ();
foreach ( $groups as $dn ) {
if ( ! in_array ( $dn , $this -> groupList )) {
$availableGroups [ getAbstractDN ( $dn )] = $dn ;
}
}
2015-08-04 18:41:12 +00:00
2013-04-13 15:57:32 +00:00
$remGroupSelect = new htmlSelect ( 'removegroups' , $selectedGroups , null , 15 );
$remGroupSelect -> setMultiSelect ( true );
$remGroupSelect -> setTransformSingleSelect ( false );
$remGroupSelect -> setHasDescriptiveElements ( true );
$remGroupSelect -> setRightToLeftTextDirection ( true );
$remGroupSelect -> setSortElements ( false );
$groupContainer -> addElement ( $remGroupSelect );
$buttonGroupContainer = new htmlTable ();
$buttonGroupContainer -> addElement ( new htmlButton ( 'addgroups_button' , 'back.gif' , true ), true );
$buttonGroupContainer -> addElement ( new htmlButton ( 'removegroups_button' , 'forward.gif' , true ), true );
$groupContainer -> addElement ( $buttonGroupContainer );
$addGroupSelect = new htmlSelect ( 'addgroups' , $availableGroups , null , 15 );
$addGroupSelect -> setMultiSelect ( true );
$addGroupSelect -> setHasDescriptiveElements ( true );
$addGroupSelect -> setTransformSingleSelect ( false );
$addGroupSelect -> setRightToLeftTextDirection ( true );
$addGroupSelect -> setSortElements ( false );
$groupContainer -> addElement ( $addGroupSelect );
$groupContainer -> addNewLine ();
$return -> addElement ( $groupContainer );
$return -> addNewLine ();
$backGroup = new htmlGroup ();
$backGroup -> colspan = 10 ;
$backGroup -> addElement ( new htmlSpacer ( null , '10px' ), true );
$backButton = new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'back' , _ ( 'Back' ));
$backGroup -> addElement ( $backButton );
$return -> addElement ( $backGroup );
return $return ;
}
/**
* Processes user input of the group selection page .
* It checks if all input values are correct and updates the associated LDAP attributes .
*
* @ return array list of info / error messages
*/
function process_group () {
if ( isset ( $_POST [ 'addgroups' ]) && isset ( $_POST [ 'addgroups_button' ])) { // Add groups to list
// add new group
$this -> groupList = @ array_merge ( $this -> groupList , $_POST [ 'addgroups' ]);
}
elseif ( isset ( $_POST [ 'removegroups' ]) && isset ( $_POST [ 'removegroups_button' ])) { // remove groups from list
$this -> groupList = array_delete ( $_POST [ 'removegroups' ], $this -> groupList );
}
return array ();
}
2015-11-07 15:43:43 +00:00
/**
* Displays the photo upload page .
*
* @ return array meta HTML code
*/
function display_html_photo () {
$container = new htmlTable ();
$label = _ ( 'Photo file (JPG format)' );
if ( extension_loaded ( 'imagick' )) {
$label = _ ( 'Photo file' );
}
$container -> addElement ( new htmlTableExtendedInputFileUpload ( 'photoFile' , $label , 'photoUpload' ), true );
$buttonContainer = new htmlTable ();
$buttonContainer -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'submit' , _ ( 'Add photo' )));
$buttonContainer -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'back' , _ ( 'Back' )));
$container -> addElement ( $buttonContainer );
return $container ;
}
/**
* Sets a new photo .
*/
function process_photo () {
if ( ! isset ( $_POST [ 'form_subpage_' . get_class ( $this ) . '_attributes_submit' ])) {
return array ();
}
$messages = array ();
if ( $_FILES [ 'photoFile' ] && ( $_FILES [ 'photoFile' ][ 'size' ] > 0 )) {
$name = $_FILES [ 'photoFile' ][ 'name' ];
$extension = strtolower ( substr ( $name , strpos ( $name , '.' ) + 1 ));
if ( ! extension_loaded ( 'imagick' ) && ! ( $extension == 'jpg' ) && ! ( $extension == 'jpeg' )) {
$messages [] = $this -> messages [ 'file' ][ 1 ];
return $messages ;
}
$handle = fopen ( $_FILES [ 'photoFile' ][ 'tmp_name' ], " r " );
$data = fread ( $handle , 10000000 );
if ( ! empty ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxSize' ][ 0 ]) && ( strlen ( $data ) > ( 1024 * $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxSize' ][ 0 ]))) {
$errMsg = $this -> messages [ 'file' ][ 3 ];
$errMsg [] = null ;
$errMsg [] = array ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxSize' ][ 0 ]);
return array ( $errMsg );
}
fclose ( $handle );
if ( extension_loaded ( 'imagick' )) {
// convert to JPG if imagick extension is available
$image = new Imagick ();
try {
$image -> readImageBlob ( $data );
// resize if maximum values specified
if ( ! empty ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxWidth' ][ 0 ]) || ! empty ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxHeight' ][ 0 ])) {
$maxWidth = empty ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxWidth' ][ 0 ]) ? $image -> getimagewidth () : $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxWidth' ][ 0 ];
$maxHeight = empty ( $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxHeight' ][ 0 ]) ? $image -> getimageheight () : $this -> moduleSettings [ 'windowsUser_jpegPhoto_maxHeight' ][ 0 ];
$image -> thumbnailimage ( $maxWidth , $maxHeight , true );
}
$image -> setImageCompression ( Imagick :: COMPRESSION_JPEG );
$image -> setImageFormat ( 'jpeg' );
$data = $image -> getimageblob ();
}
catch ( Exception $e ) {
$msg = $this -> messages [ 'file' ][ 2 ];
$msg [] = htmlspecialchars ( $e -> getMessage ());
$messages [] = $msg ;
return $messages ;
}
}
$this -> attributes [ 'jpegPhoto' ][ 0 ] = $data ;
}
else {
$messages [] = $this -> messages [ 'file' ][ 0 ];
}
return $messages ;
}
2015-11-08 09:59:20 +00:00
/**
* This function will create the meta HTML code to show a page to change the manager attribute .
*
* @ return htmlElement HTML meta data
*/
function display_html_manager () {
$return = new htmlTable ();
if ( ! isset ( $this -> attributes [ 'manager' ])) {
$this -> attributes [ 'manager' ] = array ();
}
// show list of possible new managers
$options = array ();
$filter = get_ldap_filter ( 'user' );
$entries = searchLDAPByFilter ( '(|' . $filter . '(objectclass=organizationalRole))' , array ( 'dn' ), array ( 'user' ));
for ( $i = 0 ; $i < sizeof ( $entries ); $i ++ ) {
$entries [ $i ] = $entries [ $i ][ 'dn' ];
}
// sort by DN
usort ( $entries , 'compareDN' );
for ( $i = 0 ; $i < sizeof ( $entries ); $i ++ ) {
$options [ getAbstractDN ( $entries [ $i ])] = $entries [ $i ];
}
$selectedManager = array ();
if ( ! empty ( $this -> attributes [ 'manager' ][ 0 ])) {
$selectedManager [] = $this -> attributes [ 'manager' ][ 0 ];
}
$size = 20 ;
if ( sizeof ( $options ) < 20 ) $size = sizeof ( $options );
$managerSelect = new htmlSelect ( 'manager' , $options , $selectedManager , $size );
$managerSelect -> setHasDescriptiveElements ( true );
$managerSelect -> setRightToLeftTextDirection ( true );
$managerSelect -> setSortElements ( false );
$managerSelect -> setTransformSingleSelect ( false );
$return -> addElement ( $managerSelect , true );
$buttonTable = new htmlTable ();
$buttonTable -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'setManager' , _ ( 'Change' )));
$buttonTable -> addSpace ( '5px' );
$buttonTable -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'removeManager' , _ ( 'Remove' )));
$buttonTable -> addSpace ( '20px' );
$buttonTable -> addElement ( new htmlAccountPageButton ( get_class ( $this ), 'attributes' , 'cancelManager' , _ ( 'Cancel' )));
$return -> addElement ( $buttonTable );
return $return ;
}
/**
* Processes user input of the manager page .
* It checks if all input values are correct and updates the associated LDAP attributes .
*
* @ return array list of info / error messages
*/
function process_manager () {
$return = array ();
if ( isset ( $_POST [ 'form_subpage_' . get_class ( $this ) . '_attributes_removeManager' ])) {
if ( ! empty ( $this -> attributes [ 'manager' ])) {
unset ( $this -> attributes [ 'manager' ]);
}
}
elseif ( isset ( $_POST [ 'form_subpage_' . get_class ( $this ) . '_attributes_setManager' ]) && isset ( $_POST [ 'manager' ])) {
$this -> attributes [ 'manager' ][ 0 ] = $_POST [ 'manager' ];
}
return $return ;
}
2013-04-13 15:57:32 +00:00
/**
* Runs the postmodify actions .
2015-08-04 18:41:12 +00:00
*
2013-04-13 15:57:32 +00:00
* @ see baseModule :: postModifyActions ()
*
* @ param boolean $newAccount
* @ param array $attributes LDAP attributes of this entry
* @ return array array which contains status messages . Each entry is an array containing the status message parameters .
*/
public function postModifyActions ( $newAccount , $attributes ) {
$messages = array ();
// set groups
$groups = $this -> findGroups ();
$toAdd = array_values ( array_diff ( $this -> groupList , $this -> groupList_orig ));
$toRem = array_values ( array_diff ( $this -> groupList_orig , $this -> groupList ));
$toUpdate = array_values ( array_intersect ( $this -> groupList , $this -> groupList_orig ));
$ldapUser = $_SESSION [ 'ldap' ] -> decrypt_login ();
$ldapUser = $ldapUser [ 0 ];
// add groups
for ( $i = 0 ; $i < sizeof ( $toAdd ); $i ++ ) {
if ( in_array ( $toAdd [ $i ], $groups )) {
$success = @ ldap_mod_add ( $_SESSION [ 'ldap' ] -> server (), $toAdd [ $i ], array ( 'member' => array ( $this -> getAccountContainer () -> finalDN )));
if ( ! $success ) {
2013-10-16 17:37:17 +00:00
logNewMessage ( LOG_ERR , '[' . $ldapUser . '] Unable to add user ' . $this -> getAccountContainer () -> finalDN . ' to group: ' . $toAdd [ $i ] . ' (' . ldap_error ( $_SESSION [ 'ldap' ] -> server ()) . ').' );
$messages [] = array ( 'ERROR' , sprintf ( _ ( 'Was unable to add attributes to DN: %s.' ), $toAdd [ $i ]), getDefaultLDAPErrorString ( $_SESSION [ 'ldap' ] -> server ()));
2013-04-13 15:57:32 +00:00
}
else {
logNewMessage ( LOG_NOTICE , '[' . $ldapUser . '] Added user ' . $this -> getAccountContainer () -> finalDN . ' to group: ' . $toAdd [ $i ]);
}
}
}
// remove groups
for ( $i = 0 ; $i < sizeof ( $toRem ); $i ++ ) {
if ( in_array ( $toRem [ $i ], $groups )) {
$success = @ ldap_mod_del ( $_SESSION [ 'ldap' ] -> server (), $toRem [ $i ], array ( 'member' => array ( $this -> getAccountContainer () -> dn_orig )));
if ( ! $success ) {
2013-10-16 17:37:17 +00:00
logNewMessage ( LOG_ERR , '[' . $ldapUser . '] Unable to delete user ' . $this -> getAccountContainer () -> finalDN . ' from group: ' . $toRem [ $i ] . ' (' . ldap_error ( $_SESSION [ 'ldap' ] -> server ()) . ').' );
$messages [] = array ( 'ERROR' , sprintf ( _ ( 'Was unable to remove attributes from DN: %s.' ), $toRem [ $i ]), getDefaultLDAPErrorString ( $_SESSION [ 'ldap' ] -> server ()));
2013-04-13 15:57:32 +00:00
}
else {
logNewMessage ( LOG_NOTICE , '[' . $ldapUser . '] Removed user ' . $this -> getAccountContainer () -> finalDN . ' from group: ' . $toRem [ $i ]);
}
}
}
2013-04-21 16:41:19 +00:00
// force password change if needed
if ( $this -> pwdLastSet != null ) {
$attrs = array ( 'pwdLastSet' => array ( $this -> pwdLastSet ));
$success = @ ldap_modify ( $_SESSION [ 'ldap' ] -> server (), $this -> getAccountContainer () -> finalDN , $attrs );
if ( ! $success ) {
2013-10-16 17:37:17 +00:00
logNewMessage ( LOG_ERR , '[' . $ldapUser . '] Unable to change pwdLastSet for ' . $this -> getAccountContainer () -> finalDN . ' (' . ldap_error ( $_SESSION [ 'ldap' ] -> server ()) . ').' );
$messages [] = array ( 'ERROR' , sprintf ( _ ( 'Was unable to modify attributes of DN: %s.' ), $this -> getAccountContainer () -> finalDN ), getDefaultLDAPErrorString ( $_SESSION [ 'ldap' ] -> server ()));
2013-04-21 16:41:19 +00:00
}
}
2013-04-13 15:57:32 +00:00
return $messages ;
}
2015-08-04 18:41:12 +00:00
2013-04-06 15:00:53 +00:00
/**
* In this function the LDAP account is built up .
*
* @ param array $rawAccounts list of hash arrays ( name => value ) from user input
* @ param array $ids list of IDs for column position ( e . g . " posixAccount_uid " => 5 )
* @ param array $partialAccounts list of hash arrays ( name => value ) which are later added to LDAP
* @ param array $selectedModules list of selected account modules
* @ return array list of error messages if any
*/
public function build_uploadAccounts ( $rawAccounts , $ids , & $partialAccounts , $selectedModules ) {
$errors = array ();
2013-12-28 10:47:50 +00:00
$replacements = array ();
2013-04-14 19:19:33 +00:00
// get list of existing groups
$groupList = $this -> findGroups ();
$groupMap = array ();
foreach ( $groupList as $dn ) {
$groupMap [ extractRDNValue ( $dn )] = $dn ;
}
$booleanOptions = array ( _ ( 'yes' ) => true , _ ( 'no' ) => false );
2013-04-06 15:00:53 +00:00
for ( $i = 0 ; $i < sizeof ( $rawAccounts ); $i ++ ) {
// add object class
2013-04-07 17:28:09 +00:00
if ( ! in_array ( 'user' , $partialAccounts [ $i ][ 'objectClass' ])) $partialAccounts [ $i ][ 'objectClass' ][] = 'user' ;
2013-11-09 13:26:31 +00:00
// userPrincipalName
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_userPrincipalName' ]], 'username' )) {
$partialAccounts [ $i ][ 'userPrincipalName' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_userPrincipalName' ]];
2013-12-28 10:47:50 +00:00
$parts = explode ( '@' , $partialAccounts [ $i ][ 'userPrincipalName' ]);
$replacements [ '$user' ] = $parts [ 0 ];
2013-11-09 13:26:31 +00:00
}
else {
$errMsg = $this -> messages [ 'userPrincipalName' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
2013-12-28 10:47:50 +00:00
// first name
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_firstName' ]] != " " ) {
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_firstName' ]], 'realname' )) {
$partialAccounts [ $i ][ 'givenName' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_firstName' ]];
$replacements [ '$firstname' ] = $partialAccounts [ $i ][ 'givenName' ];
}
else {
$errMsg = $this -> messages [ 'givenName' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
// last name
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_lastName' ]] != " " ) {
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_lastName' ]], 'realname' )) {
$partialAccounts [ $i ][ 'sn' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_lastName' ]];
$replacements [ '$lastname' ] = $partialAccounts [ $i ][ 'sn' ];
}
else {
$errMsg = $this -> messages [ 'sn' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-11-09 13:26:31 +00:00
// cn
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_cn' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_cn' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_cn' ]]);
}
2013-11-09 13:26:31 +00:00
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_cn' ]], 'cn' )) {
$partialAccounts [ $i ][ 'cn' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_cn' ]];
2013-04-06 15:00:53 +00:00
}
else {
$errMsg = $this -> messages [ 'cn' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-11-09 13:26:31 +00:00
else {
$cn = '' ;
if ( ! empty ( $rawAccounts [ $i ][ $ids [ 'windowsUser_firstName' ]])) {
$cn = $rawAccounts [ $i ][ $ids [ 'windowsUser_firstName' ]];
}
if ( ! empty ( $rawAccounts [ $i ][ $ids [ 'windowsUser_lastName' ]])) {
$cn .= ' ' . $rawAccounts [ $i ][ $ids [ 'windowsUser_lastName' ]];
}
$cn = trim ( $cn );
if ( ! empty ( $cn )) {
$partialAccounts [ $i ][ 'cn' ] = $cn ;
}
}
// sAMAccountName
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidesAMAccountName' , true )) {
if ( ! empty ( $rawAccounts [ $i ][ $ids [ 'windowsUser_sAMAccountName' ]])) {
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_sAMAccountName' ]], 'username' )) {
$partialAccounts [ $i ][ 'sAMAccountName' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_sAMAccountName' ]];
}
else {
$errMsg = $this -> messages [ 'sAMAccountName' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
else {
$samUser = explode ( '@' , $partialAccounts [ $i ][ 'userPrincipalName' ]);
$partialAccounts [ $i ][ 'sAMAccountName' ] = $samUser [ 0 ];
}
}
2014-07-26 12:44:32 +00:00
else {
// set sAMAccountName to user name if not managed (W2012 requires it)
$partialAccounts [ $i ][ 'sAMAccountName' ] = $replacements [ '$user' ];
}
2013-04-14 19:19:33 +00:00
// password
if (( $rawAccounts [ $i ][ $ids [ 'windowsUser_password' ]] != " " ) && ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_password' ]], 'password' ))) {
2013-04-20 08:54:29 +00:00
$partialAccounts [ $i ][ 'unicodePwd' ] = self :: pwdAttributeValue ( $rawAccounts [ $i ][ $ids [ 'windowsUser_password' ]]);
2013-04-14 19:19:33 +00:00
$partialAccounts [ $i ][ 'INFO.userPasswordClearText' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_password' ]]; // for custom scripts etc.
}
2013-04-23 18:30:08 +00:00
elseif ( $rawAccounts [ $i ][ $ids [ 'windowsUser_password' ]] != " " ) {
2013-04-14 19:19:33 +00:00
$errMsg = $this -> messages [ 'userPassword' ][ 4 ];
$errMsg [ 2 ] = str_replace ( '%' , '%%' , $errMsg [ 2 ]); // double "%" because of later sprintf
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
// display name
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_displayName' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_displayName' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_displayName' ]]);
}
2013-04-14 19:19:33 +00:00
$partialAccounts [ $i ][ 'displayName' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_displayName' ]];
}
2013-11-09 13:26:31 +00:00
elseif ( ! empty ( $partialAccounts [ $i ][ 'cn' ])) {
$partialAccounts [ $i ][ 'displayName' ] = $partialAccounts [ $i ][ 'cn' ];
}
2013-04-14 19:19:33 +00:00
// initials
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_initials' , 'initials' );
2013-04-06 15:00:53 +00:00
// description
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_description' , 'description' );
2013-04-14 19:19:33 +00:00
// street
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_streetAddress' , 'streetAddress' );
2013-04-14 19:19:33 +00:00
// post office box
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_postOfficeBox' , 'postOfficeBox' );
2013-04-14 19:19:33 +00:00
// postal code
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_postalCode' , 'postalCode' ,
'postalCode' , $this -> messages [ 'postalCode' ][ 1 ], $errors );
2013-04-06 15:00:53 +00:00
// location
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_l' , 'l' );
2013-04-14 19:19:33 +00:00
// state
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_state' , 'st' );
2013-04-14 19:19:33 +00:00
// office name
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_officeName' , 'physicalDeliveryOfficeName' );
2013-04-14 19:19:33 +00:00
// mail
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_mail' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_mail' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_mail' ]]);
}
2013-04-14 19:19:33 +00:00
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_mail' ]], 'email' )) {
$partialAccounts [ $i ][ 'mail' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_mail' ]];
}
else {
$errMsg = $this -> messages [ 'mail' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-04-27 17:38:01 +00:00
// mail aliases
if ( isset ( $ids [ 'windowsUser_otherMailbox' ]) && ( $rawAccounts [ $i ][ $ids [ 'windowsUser_otherMailbox' ]] != " " )) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_otherMailbox' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_otherMailbox' ]]);
}
2013-04-27 17:38:01 +00:00
$valueList = preg_split ( '/;[ ]*/' , $rawAccounts [ $i ][ $ids [ 'windowsUser_otherMailbox' ]]);
$partialAccounts [ $i ][ 'otherMailbox' ] = $valueList ;
for ( $x = 0 ; $x < sizeof ( $valueList ); $x ++ ) {
if ( ! get_preg ( $valueList [ $x ], 'email' )) {
$errMsg = $this -> messages [ 'otherMailbox' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
break ;
}
}
}
2013-04-14 19:19:33 +00:00
// telephone
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_telephoneNumber' , 'telephoneNumber' ,
'telephone' , $this -> messages [ 'telephoneNumber' ][ 1 ], $errors );
2013-04-14 19:19:33 +00:00
// other telephone
2015-08-16 16:43:42 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_otherTelephone' , 'otherTelephone' , 'telephone' , $this -> messages [ 'otherTelephone' ][ 1 ], $errors , '/;[ ]*/' );
2016-01-03 15:43:28 +00:00
// fax number
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidefacsimileTelephoneNumber' )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_facsimileTelephoneNumber' , 'facsimileTelephoneNumber' ,
'telephone' , $this -> messages [ 'facsimileTelephoneNumber' ][ 1 ], $errors );
}
2013-04-14 19:19:33 +00:00
// website
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_webSite' , 'wWWHomePage' );
2013-04-14 19:19:33 +00:00
// other websites
2015-08-16 16:43:42 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_otherWebSites' , 'url' , null , null , $errors , '/;[ ]*/' );
2013-04-14 19:19:33 +00:00
// user account control
$userAccountControlAttr [ 'userAccountControl' ][ 0 ] = windowsUser :: DEFAULT_ACCOUNT_CONTROL ;
// deactivated
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_deactivated' ]] != " " ) {
if ( ! isset ( $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_deactivated' ]]])) {
$errors [] = array ( 'ERROR' , sprintf ( _ ( 'Account %s:' ), $i ) . ' windowsUser_deactivated' , _ ( 'Please enter either yes or no.' ));
}
else {
2013-04-20 08:32:12 +00:00
$this -> setIsDeactivated ( $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_deactivated' ]]], $userAccountControlAttr );
2013-04-14 19:19:33 +00:00
}
}
// password does not expire
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_noExpire' ]] != " " ) {
if ( ! isset ( $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_noExpire' ]]])) {
$errors [] = array ( 'ERROR' , sprintf ( _ ( 'Account %s:' ), $i ) . ' windowsUser_noExpire' , _ ( 'Please enter either yes or no.' ));
}
else {
$this -> setIsNeverExpiring ( $userAccountControlAttr , $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_noExpire' ]]]);
}
}
2015-11-02 20:53:20 +00:00
// account expiration
if ( ! empty ( $rawAccounts [ $i ][ $ids [ 'windowsUser_accountExpires' ]])) {
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_accountExpires' ]], 'date' )) {
$dateParts = explode ( '-' , $rawAccounts [ $i ][ $ids [ 'windowsUser_accountExpires' ]]);
$partialAccounts [ $i ][ 'accountExpires' ] = $this -> buildExpirationDate ( $dateParts [ 2 ], $dateParts [ 1 ], $dateParts [ 0 ]);
}
else {
$errMsg = $this -> messages [ 'accountExpires' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-04-14 19:19:33 +00:00
// require smartcard
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_requireCard' ]] != " " ) {
if ( ! isset ( $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_requireCard' ]]])) {
$errors [] = array ( 'ERROR' , sprintf ( _ ( 'Account %s:' ), $i ) . ' windowsUser_requireCard' , _ ( 'Please enter either yes or no.' ));
}
else {
$this -> setIsSmartCardRequired ( $userAccountControlAttr , $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_requireCard' ]]]);
}
}
$partialAccounts [ $i ][ 'userAccountControl' ][ 0 ] = $userAccountControlAttr [ 'userAccountControl' ][ 0 ];
// end user account control
// password change at next login
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_pwdMustChange' ]] != " " ) {
if ( ! isset ( $booleanOptions [ $rawAccounts [ $i ][ $ids [ 'windowsUser_pwdMustChange' ]]])) {
$errors [] = array ( 'ERROR' , sprintf ( _ ( 'Account %s:' ), $i ) . ' windowsUser_pwdMustChange' , _ ( 'Please enter either yes or no.' ));
}
// attribute must be set in postModify
}
// profile path
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_profilePath' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_profilePath' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_profilePath' ]]);
}
2013-04-14 19:19:33 +00:00
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_profilePath' ]], 'UNC' )) {
$partialAccounts [ $i ][ 'profilePath' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_profilePath' ]];
}
else {
$errMsg = $this -> messages [ 'profilePath' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
// logon script
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_scriptPath' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_scriptPath' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_scriptPath' ]]);
}
2013-04-14 19:19:33 +00:00
if ( get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_scriptPath' ]], 'logonscript' )) {
$partialAccounts [ $i ][ 'scriptPath' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_scriptPath' ]];
}
else {
$errMsg = $this -> messages [ 'scriptPath' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-11-23 14:40:06 +00:00
// home drive
if ( ! empty ( $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDrive' ]])) {
if ( preg_match ( " /[d-z]:/i " , $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDrive' ]])) {
$partialAccounts [ $i ][ 'homeDrive' ] = strtoupper ( $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDrive' ]]);
}
else {
$errMsg = $this -> messages [ 'homeDrive' ][ 0 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
// home directory
if ( $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDirectory' ]] != " " ) {
2013-12-28 10:47:50 +00:00
foreach ( $replacements as $wildcard => $value ) {
$rawAccounts [ $i ][ $ids [ 'windowsUser_homeDirectory' ]] = str_replace ( $wildcard , $value , $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDirectory' ]]);
}
2013-11-23 14:40:06 +00:00
if ( empty ( $partialAccounts [ $i ][ 'homeDrive' ]) || get_preg ( $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDirectory' ]], 'UNC' )) {
$partialAccounts [ $i ][ 'homeDirectory' ] = $rawAccounts [ $i ][ $ids [ 'windowsUser_homeDirectory' ]];
}
else {
$errMsg = $this -> messages [ 'homeDirectory' ][ 1 ];
array_push ( $errMsg , array ( $i ));
$errors [] = $errMsg ;
}
}
2013-04-14 19:19:33 +00:00
// groups
if ( isset ( $ids [ 'windowsUser_groups' ]) && ( $rawAccounts [ $i ][ $ids [ 'windowsUser_groups' ]] != " " )) {
$valueList = preg_split ( '/;[ ]*/' , $rawAccounts [ $i ][ $ids [ 'windowsUser_groups' ]]);
$invalidGroups = array ();
foreach ( $valueList as $group ) {
if ( ! in_array ( $group , $groupList ) && ! isset ( $groupMap [ $group ])) {
$invalidGroups [] = $group ;
}
}
if ( sizeof ( $invalidGroups ) > 0 ) {
$errors [] = array ( 'ERROR' , sprintf ( _ ( 'Account %s:' ), $i ) . ' windowsUser_groups' ,
_ ( 'LAM was unable to find a group with this name!' ) . '<br>' . htmlspecialchars ( implode ( '; ' , $invalidGroups )));
}
}
2014-02-12 19:39:51 +00:00
// NIS name
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30Name' , true )) {
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_msSFU30Name' , 'msSFU30Name' ,
'username' , $this -> messages [ 'msSFU30Name' ][ 1 ], $errors );
2014-02-12 19:39:51 +00:00
}
// NIS domain
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemsSFU30NisDomain' , true )) {
2014-04-18 18:29:51 +00:00
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_msSFU30NisDomain' , 'msSFU30NisDomain' );
2014-02-12 19:39:51 +00:00
}
2015-11-08 16:33:08 +00:00
// title
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_title' , 'title' , 'title' , $this -> messages [ 'title' ][ 1 ], $errors );
}
// carLicense
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidecarLicense' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_carLicense' , 'carLicense' );
}
// employee number
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeNumber' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_employeeNumber' , 'employeeNumber' );
}
// employee type
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_employeeType' , 'employeeType' ,
'employeeType' , $this -> messages [ 'employeeType' ][ 1 ], $errors );
}
// business category
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_businessCategory' , 'businessCategory' , 'businessCategory' , $this -> messages [ 'businessCategory' ][ 1 ], $errors , '/;[ ]*/' );
}
// departments
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_departmentNumber' , 'departmentNumber' , null , null , $errors , '/;[ ]*/' );
}
// organisational unit
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_ou' , 'ou' , null , null , $errors , '/;[ ]*/' );
}
// organisation
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_o' , 'o' , null , null , $errors , '/;[ ]*/' );
}
// manager
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidemanager' , true )) {
$this -> mapSimpleUploadField ( $rawAccounts , $ids , $partialAccounts , $i , 'windowsUser_manager' , 'manager' , 'dn' , $this -> messages [ 'manager' ][ 0 ], $errors );
}
2013-04-06 15:00:53 +00:00
}
return $errors ;
}
2015-08-04 18:41:12 +00:00
2013-04-14 19:19:33 +00:00
/**
* This function executes one post upload action .
*
* @ param array $data array containing one account in each element
* @ param array $ids array ( < column_name > => < column number > )
* @ param array $failed list of accounts which were not created successfully
* @ param array $temp variable to store temporary data between two post actions
* @ param array $accounts list of LDAP entries
* @ return array current status
* < br > array (
* < br > 'status' => 'finished' | 'inProgress'
* < br > 'progress' => 0. . 100
* < br > 'errors' => array ( < array of parameters for StatusMessage > )
* < br > )
*/
function doUploadPostActions ( & $data , $ids , $failed , & $temp , & $accounts ) {
2014-01-15 20:48:52 +00:00
if ( ! checkIfWriteAccessIsAllowed ( $this -> get_scope ())) {
2013-04-14 19:19:33 +00:00
die ();
}
// on first call generate list of ldap operations
if ( ! isset ( $temp [ 'counter' ])) {
$groupList = $this -> findGroups ();
$groupMap = array ();
foreach ( $groupList as $dn ) {
$groupMap [ extractRDNValue ( $dn )] = $dn ;
}
$temp [ 'groups' ] = & $groupList ;
$temp [ 'groupMap' ] = & $groupMap ;
$temp [ 'members' ] = array ();
$temp [ 'memberCount' ] = 0 ;
$temp [ 'pwdChange' ] = array ();
$temp [ 'pwdChangeCount' ] = 0 ;
$groupCol = $ids [ 'windowsUser_groups' ];
$passwordChangeRequiredCol = $ids [ 'windowsUser_pwdMustChange' ];
for ( $i = 0 ; $i < sizeof ( $data ); $i ++ ) {
if ( in_array ( $i , $failed )) continue ; // ignore failed accounts
if ( $data [ $i ][ $groupCol ] != " " ) {
$groups = preg_split ( '/;[ ]*/' , $data [ $i ][ $groupCol ]);
for ( $g = 0 ; $g < sizeof ( $groups ); $g ++ ) {
if ( in_array ( $groups [ $g ], $temp [ 'groups' ])) {
$temp [ 'members' ][ $groups [ $g ]][] = $accounts [ $i ][ 'dn' ];
}
elseif ( isset ( $temp [ 'groupMap' ][ $groups [ $g ]])) {
$temp [ 'members' ][ $temp [ 'groupMap' ][ $groups [ $g ]]][] = $accounts [ $i ][ 'dn' ];
}
}
}
if ( isset ( $data [ $i ][ $passwordChangeRequiredCol ]) && ( $data [ $i ][ $passwordChangeRequiredCol ] == _ ( 'yes' ))) {
$temp [ 'pwdChange' ][] = $accounts [ $i ][ 'dn' ];
}
}
$temp [ 'memberCount' ] = sizeof ( $temp [ 'members' ]);
$temp [ 'pwdChangeCount' ] = sizeof ( $temp [ 'pwdChange' ]);
$temp [ 'counter' ] = $temp [ 'memberCount' ] + $temp [ 'pwdChangeCount' ];
return array (
'status' => 'inProgress' ,
'progress' => 0 ,
'errors' => array ()
);
}
// add users to groups
elseif ( sizeof ( $temp [ 'members' ]) > 0 ) {
$keys = array_keys ( $temp [ 'members' ]);
$group = $keys [ 0 ];
$member = array_pop ( $temp [ 'members' ][ $group ]);
$success = @ ldap_mod_add ( $_SESSION [ 'ldap' ] -> server (), $group , array ( 'member' => $member ));
$errors = array ();
if ( ! $success ) {
$errors [] = array (
" ERROR " ,
_ ( " LAM was unable to modify group memberships for group: %s " ),
2013-10-16 17:37:17 +00:00
getDefaultLDAPErrorString ( $_SESSION [ 'ldap' ] -> server ()),
2013-04-14 19:19:33 +00:00
array ( $group )
);
}
if ( sizeof ( $temp [ 'members' ][ $group ]) == 0 ) {
unset ( $temp [ 'members' ][ $group ]);
}
$memberPercentage = ( 100 * ( $temp [ 'memberCount' ] - sizeof ( $temp [ 'members' ]))) / $temp [ 'counter' ];
return array (
'status' => 'inProgress' ,
'progress' => $memberPercentage ,
'errors' => $errors
);
}
// force password change
elseif ( sizeof ( $temp [ 'pwdChange' ]) > 0 ) {
$dn = array_pop ( $temp [ 'pwdChange' ]);
$success = @ ldap_mod_replace ( $_SESSION [ 'ldap' ] -> server (), $dn , array ( 'pwdLastSet' => '0' ));
$errors = array ();
if ( ! $success ) {
$errors [] = array (
" ERROR " ,
_ ( " Was unable to modify attributes of DN: %s. " ),
2013-10-16 17:37:17 +00:00
getDefaultLDAPErrorString ( $_SESSION [ 'ldap' ] -> server ()),
2013-04-14 19:19:33 +00:00
array ( $dn )
);
}
$pwdPercentage = ( 100 * ( $temp [ 'memberCount' ] + ( $temp [ 'pwdChangeCount' ] - sizeof ( $temp [ 'pwdChange' ])))) / $temp [ 'counter' ];
return array (
'status' => 'inProgress' ,
'progress' => $pwdPercentage ,
'errors' => $errors
);
}
// all modifications are done
else {
return array (
'status' => 'finished' ,
'progress' => 100 ,
'errors' => array ()
);
}
}
2015-08-04 18:41:12 +00:00
2013-04-06 15:00:53 +00:00
/**
2015-01-07 17:16:35 +00:00
* Returns a list of possible PDF entries for this account .
*
* @ param array $pdfKeys list of PDF keys that are included in document
* @ return list of PDF entries ( array ( < PDF key > => < PDF lines > ))
*/
public function get_pdfEntries ( $pdfKeys ) {
2013-04-06 15:00:53 +00:00
$return = array ();
2013-11-09 13:26:31 +00:00
$this -> addSimplePDFField ( $return , 'userPrincipalName' , _ ( 'User name' ));
$this -> addSimplePDFField ( $return , 'cn' , _ ( 'Common name' ));
$this -> addSimplePDFField ( $return , 'sAMAccountName' , _ ( 'User name (pre W2K)' ));
2013-04-06 15:00:53 +00:00
$this -> addSimplePDFField ( $return , 'description' , _ ( 'Description' ));
$this -> addSimplePDFField ( $return , 'displayName' , _ ( 'Display name' ));
$this -> addSimplePDFField ( $return , 'givenName' , _ ( 'First name' ));
$this -> addSimplePDFField ( $return , 'initials' , _ ( 'Initials' ));
$this -> addSimplePDFField ( $return , 'l' , _ ( 'Location' ));
$this -> addSimplePDFField ( $return , 'mail' , _ ( 'Email address' ));
2013-04-27 17:38:01 +00:00
$this -> addSimplePDFField ( $return , 'otherMailbox' , _ ( 'Email alias' ));
2013-04-06 15:00:53 +00:00
$this -> addSimplePDFField ( $return , 'otherTelephone' , _ ( 'Other telephone numbers' ));
$this -> addSimplePDFField ( $return , 'physicalDeliveryOfficeName' , _ ( 'Office name' ));
$this -> addSimplePDFField ( $return , 'postalCode' , _ ( 'Postal code' ));
$this -> addSimplePDFField ( $return , 'postOfficeBox' , _ ( 'Post office box' ));
$this -> addSimplePDFField ( $return , 'sn' , _ ( 'Last name' ));
$this -> addSimplePDFField ( $return , 'st' , _ ( 'State' ));
$this -> addSimplePDFField ( $return , 'streetAddress' , _ ( 'Street' ));
$this -> addSimplePDFField ( $return , 'telephoneNumber' , _ ( 'Telephone number' ));
2016-01-03 15:43:28 +00:00
$this -> addSimplePDFField ( $return , 'facsimileTelephoneNumber' , _ ( 'Fax number' ));
2013-04-06 15:00:53 +00:00
$this -> addSimplePDFField ( $return , 'url' , _ ( 'Other web sites' ));
$this -> addSimplePDFField ( $return , 'wWWHomePage' , _ ( 'Web site' ));
2014-02-12 19:39:51 +00:00
$this -> addSimplePDFField ( $return , 'msSFU30Name' , _ ( 'NIS name' ));
$this -> addSimplePDFField ( $return , 'msSFU30NisDomain' , _ ( 'NIS domain' ));
2015-11-08 16:33:08 +00:00
$this -> addSimplePDFField ( $return , 'title' , _ ( 'Job title' ));
$this -> addSimplePDFField ( $return , 'carLicense' , _ ( 'Car license' ));
$this -> addSimplePDFField ( $return , 'employeeNumber' , _ ( 'Employee number' ));
$this -> addSimplePDFField ( $return , 'employeeType' , _ ( 'Employee type' ));
$this -> addSimplePDFField ( $return , 'businessCategory' , _ ( 'Business category' ));
$this -> addSimplePDFField ( $return , 'departmentNumber' , _ ( 'Department' ));
$this -> addSimplePDFField ( $return , 'ou' , _ ( 'Organisational unit' ));
$this -> addSimplePDFField ( $return , 'o' , _ ( 'Organisation' ));
$this -> addSimplePDFField ( $return , 'manager' , _ ( 'Manager' ));
2013-04-14 19:19:33 +00:00
$deactivated = _ ( 'no' );
if ( $this -> isDeactivated ( $this -> attributes )) {
$deactivated = _ ( 'yes' );
}
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'deactivated' , _ ( 'Account is deactivated' ), $deactivated );
2013-04-14 19:19:33 +00:00
$noExpire = _ ( 'no' );
if ( $this -> isNeverExpiring ( $this -> attributes )) {
$noExpire = _ ( 'yes' );
}
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'noExpire' , _ ( 'Password does not expire' ), $noExpire );
2015-11-02 20:53:20 +00:00
$this -> addPDFKeyValue ( $return , 'accountExpires' , _ ( 'Account expiration date' ), $this -> formatAccountExpires ());
2013-04-14 19:19:33 +00:00
$requireCard = _ ( 'no' );
if ( $this -> isSmartCardRequired ( $this -> attributes )) {
$requireCard = _ ( 'yes' );
}
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'requireCard' , _ ( 'Require smartcard' ), $requireCard );
2013-04-14 19:19:33 +00:00
$pwdMustChange = _ ( 'no' );
if ( isset ( $this -> attributes [ 'pwdLastSet' ][ 0 ]) && ( $this -> attributes [ 'pwdLastSet' ][ 0 ] === '0' )) {
$pwdMustChange = _ ( 'yes' );
}
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'pwdMustChange' , _ ( 'Password change at next login' ), $pwdMustChange );
2013-04-14 19:19:33 +00:00
$this -> addSimplePDFField ( $return , 'profilePath' , _ ( 'Profile path' ));
$this -> addSimplePDFField ( $return , 'scriptPath' , _ ( 'Logon script' ));
2013-11-23 14:40:06 +00:00
$this -> addSimplePDFField ( $return , 'homeDirectory' , _ ( 'Home directory' ));
$this -> addSimplePDFField ( $return , 'homeDrive' , _ ( 'Home drive' ));
2013-04-14 19:19:33 +00:00
$groups = array ();
foreach ( $this -> groupList as $group ) {
$groups [] = extractRDNValue ( $group );
}
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'groups' , _ ( 'Groups' ), $groups );
2013-04-21 18:53:39 +00:00
// password
if ( isset ( $this -> clearTextPassword )) {
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'password' , _ ( 'Password' ), $this -> clearTextPassword );
2013-04-21 18:53:39 +00:00
}
else if ( isset ( $this -> attributes [ 'INFO.userPasswordClearText' ])) {
2015-03-15 17:38:03 +00:00
$this -> addPDFKeyValue ( $return , 'password' , _ ( 'Password' ), $this -> attributes [ 'INFO.userPasswordClearText' ]);
2013-04-21 18:53:39 +00:00
}
2015-09-02 16:39:30 +00:00
// last password change
$this -> addPDFKeyValue ( $return , 'pwdLastSet' , _ ( 'Last password change' ), $this -> formatPwdLastSet ());
// last login
$this -> addPDFKeyValue ( $return , 'lastLogonTimestamp' , _ ( 'Last login' ), $this -> formatLastLogonTimestamp ());
2013-04-06 15:00:53 +00:00
return $return ;
}
2015-08-04 18:41:12 +00:00
2013-04-14 19:19:33 +00:00
/**
* Returns a list of elements for the account profiles .
*
* @ return htmlElement profile elements
*/
function get_profileOptions () {
2013-12-28 10:47:50 +00:00
$return = parent :: get_profileOptions ();
2013-11-09 13:26:31 +00:00
// domain
$domains = $this -> getDomains ();
$domains [] = '' ;
$return -> addElement ( new htmlTableExtendedSelect ( 'windowsUser_userPrincipalNameDomain' , $domains , array (), _ ( 'Domain' ), 'userPrincipalNameDomain' ), true );
// group memberships
2013-04-14 19:19:33 +00:00
$groups = $this -> findGroups ();
$groupList = array ();
foreach ( $groups as $dn ) {
$groupList [ extractRDNValue ( $dn )] = $dn ;
}
$groupSelect = new htmlTableExtendedSelect ( 'windowsUser_groups' , $groupList , array (), _ ( 'Groups' ), 'groups' , 10 );
$groupSelect -> setHasDescriptiveElements ( true );
$groupSelect -> setMultiSelect ( true );
$return -> addElement ( $groupSelect , true );
return $return ;
}
2015-08-04 18:41:12 +00:00
2013-04-14 19:19:33 +00:00
/**
* Loads the values of an account profile into internal variables .
*
* @ param array $profile hash array with profile values ( identifier => value )
*/
function load_profile ( $profile ) {
// profile mappings in meta data
parent :: load_profile ( $profile );
2013-11-09 13:26:31 +00:00
// load domain
if ( isset ( $profile [ 'windowsUser_userPrincipalNameDomain' ][ 0 ])) {
$user = empty ( $this -> attributes [ 'userPrincipalName' ][ 0 ]) ? '' : $this -> attributes [ 'userPrincipalName' ][ 0 ];
$user = explode ( '@' , $user );
$user = $user [ 0 ] . '@' . $profile [ 'windowsUser_userPrincipalNameDomain' ][ 0 ];
$this -> attributes [ 'userPrincipalName' ][ 0 ] = $user ;
}
2013-04-14 19:19:33 +00:00
// load groups
if ( isset ( $profile [ 'windowsUser_groups' ][ 0 ])) {
$this -> groupList = $profile [ 'windowsUser_groups' ];
}
2013-12-28 10:47:50 +00:00
// other mailboxes
if ( ! empty ( $profile [ 'windowsUser_otherMailbox' ][ 0 ])) {
$this -> attributes [ 'otherMailbox' ] = preg_split ( '/;[ ]*/' , $profile [ 'windowsUser_otherMailbox' ][ 0 ]);
}
2015-11-02 20:53:20 +00:00
// account expiration date
if ( ! empty ( $profile [ 'windowsUser_accountExpires' ][ 0 ]) && is_numeric ( $profile [ 'windowsUser_accountExpires' ][ 0 ])) {
$numDays = $profile [ 'windowsUser_accountExpires' ][ 0 ];
$date = new DateTime ( 'now' , getTimeZone ());
$toAdd = new DateInterval ( 'P' . $numDays . 'D' );
$dateTarget = $date -> add ( $toAdd );
$this -> setExpirationDate ( $dateTarget -> format ( 'Y' ), $dateTarget -> format ( 'm' ), $dateTarget -> format ( 'd' ));
}
2015-11-07 14:44:34 +00:00
// departments
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' )) {
if ( isset ( $profile [ 'windowsUser_departmentNumber' ][ 0 ]) && $profile [ 'windowsUser_departmentNumber' ][ 0 ] != '' ) {
$departments = explode ( ';' , $profile [ 'windowsUser_departmentNumber' ][ 0 ]);
// remove extra spaces and set attributes
$this -> attributes [ 'departmentNumber' ] = array_map ( 'trim' , $departments );
}
}
// organizational unit
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' ) && isset ( $profile [ 'windowsUser_ou' ][ 0 ])) {
$oList = preg_split ( '/;[ ]*/' , $profile [ 'windowsUser_ou' ][ 0 ]);
$this -> attributes [ 'ou' ] = $oList ;
}
// organisation
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' ) && isset ( $profile [ 'windowsUser_o' ][ 0 ])) {
$oList = preg_split ( '/;[ ]*/' , $profile [ 'windowsUser_o' ][ 0 ]);
$this -> attributes [ 'o' ] = $oList ;
}
2013-04-14 19:19:33 +00:00
}
2013-04-20 12:52:30 +00:00
/**
* Returns the meta HTML code for each input field .
* format : array ( < field1 > => array ( < META HTML > ), ... )
* It is not possible to display help links .
*
* @ param array $fields list of active fields
* @ param array $attributes attributes of LDAP account
* @ param boolean $passwordChangeOnly indicates that the user is only allowed to change his password and no LDAP content is readable
* @ param array $readOnlyFields list of read - only fields
2015-08-04 18:41:12 +00:00
* @ return array list of meta HTML elements ( field name => htmlResponsiveRow )
2013-04-20 12:52:30 +00:00
*/
function getSelfServiceOptions ( $fields , $attributes , $passwordChangeOnly , $readOnlyFields ) {
$return = array ();
if ( in_array ( 'unicodePwd' , $fields )) {
2015-08-04 18:41:12 +00:00
$row = new htmlResponsiveRow ();
$pwd1 = new htmlResponsiveInputField ( $this -> getSelfServiceLabel ( 'unicodePwd' , _ ( 'New password' )), 'windowsUser_unicodePwd' );
2014-05-25 17:29:19 +00:00
$pwd1 -> setIsPassword ( true , true );
2015-08-04 18:41:12 +00:00
$pwd1 -> setFieldSize ( null );
$row -> add ( $pwd1 , 12 );
$pwd2 = new htmlResponsiveInputField ( _ ( 'Reenter password' ), 'windowsUser_unicodePwd2' );
2013-04-20 12:52:30 +00:00
$pwd2 -> setIsPassword ( true );
2015-08-04 18:41:12 +00:00
$pwd2 -> setFieldSize ( null );
2014-05-25 14:37:05 +00:00
$pwd2 -> setSameValueFieldID ( 'windowsUser_unicodePwd' );
2015-08-04 18:41:12 +00:00
$row -> add ( $pwd2 , 12 );
$return [ 'unicodePwd' ] = $row ;
2013-04-20 12:52:30 +00:00
}
if ( $passwordChangeOnly ) {
return $return ; // only password fields as long no LDAP content can be read
}
2013-04-20 16:13:16 +00:00
$this -> addSimpleSelfServiceTextField ( $return , 'physicalDeliveryOfficeName' , _ ( 'Office name' ), $fields , $attributes , $readOnlyFields );
$this -> addSimpleSelfServiceTextField ( $return , 'telephoneNumber' , _ ( 'Telephone number' ), $fields , $attributes , $readOnlyFields );
2016-01-03 15:43:28 +00:00
$this -> addSimpleSelfServiceTextField ( $return , 'facsimileTelephoneNumber' , _ ( 'Fax number' ), $fields , $attributes , $readOnlyFields );
2013-04-20 16:13:16 +00:00
$this -> addSimpleSelfServiceTextField ( $return , 'wWWHomePage' , _ ( 'Web site' ), $fields , $attributes , $readOnlyFields );
// TODO remove this workaround when self service allows to specify the list of active modules
if ( isset ( $attributes [ 'street' ])) {
$attributes [ 'streetAddress' ] = $attributes [ 'street' ];
}
$this -> addSimpleSelfServiceTextField ( $return , 'streetAddress' , _ ( 'Street' ), $fields , $attributes , $readOnlyFields , false , true );
$this -> addSimpleSelfServiceTextField ( $return , 'st' , _ ( 'State' ), $fields , $attributes , $readOnlyFields );
$this -> addSimpleSelfServiceTextField ( $return , 'l' , _ ( 'Location' ), $fields , $attributes , $readOnlyFields );
$this -> addSimpleSelfServiceTextField ( $return , 'postOfficeBox' , _ ( 'Post office box' ), $fields , $attributes , $readOnlyFields );
$this -> addSimpleSelfServiceTextField ( $return , 'postalCode' , _ ( 'Postal code' ), $fields , $attributes , $readOnlyFields );
2015-09-02 16:39:30 +00:00
// last password change
$row = new htmlResponsiveRow ();
$row -> addLabel ( new htmlOutputText ( $this -> getSelfServiceLabel ( 'pwdLastSet' , _ ( 'Last password change' ))));
$row -> addField ( new htmlOutputText ( $this -> formatPwdLastSet ( $attributes )));
$return [ 'pwdLastSet' ] = $row ;
2015-11-02 20:53:20 +00:00
// account expiration
$row = new htmlResponsiveRow ();
$row -> addLabel ( new htmlOutputText ( $this -> getSelfServiceLabel ( 'accountExpires' , _ ( 'Account expiration date' ))));
$row -> addField ( new htmlOutputText ( $this -> formatAccountExpires ( $attributes )));
$return [ 'accountExpires' ] = $row ;
2013-04-20 12:52:30 +00:00
return $return ;
}
/**
* Checks if all input values are correct and returns the LDAP attributes which should be changed .
* < br > Return values :
* < br > messages : array of parameters to create status messages
* < br > add : array of attributes to add
* < br > del : array of attributes to remove
* < br > mod : array of attributes to modify
* < br > info : array of values with informational value ( e . g . to be used later by pre / postModify actions )
2015-08-04 18:41:12 +00:00
*
2013-04-20 12:52:30 +00:00
* Calling this method does not require the existence of an enclosing { @ link accountContainer } .
*
* @ param string $fields input fields
* @ param array $attributes LDAP attributes
* @ param boolean $passwordChangeOnly indicates that the user is only allowed to change his password and no LDAP content is readable
* @ param array $readOnlyFields list of read - only fields
* @ return array messages and attributes ( array ( 'messages' => array (), 'add' => array ( 'mail' => array ( 'test@test.com' )), 'del' => array (), 'mod' => array (), 'info' => array ()))
*/
function checkSelfServiceOptions ( $fields , $attributes , $passwordChangeOnly , $readOnlyFields ) {
$return = array ( 'messages' => array (), 'add' => array (), 'del' => array (), 'mod' => array (), 'info' => array ());
if ( in_array ( 'unicodePwd' , $fields )) {
if ( isset ( $_POST [ 'windowsUser_unicodePwd' ]) && ( $_POST [ 'windowsUser_unicodePwd' ] != '' )) {
if ( $_POST [ 'windowsUser_unicodePwd' ] != $_POST [ 'windowsUser_unicodePwd2' ]) {
$return [ 'messages' ][] = $this -> messages [ 'unicodePwd' ][ 0 ];
}
else {
if ( ! get_preg ( $_POST [ 'windowsUser_unicodePwd' ], 'password' )) {
$return [ 'messages' ][] = $this -> messages [ 'unicodePwd' ][ 1 ];
}
else {
2014-04-17 19:26:08 +00:00
$userName = empty ( $attributes [ 'userPrincipalName' ][ 0 ]) ? null : $attributes [ 'userPrincipalName' ][ 0 ];
$additionalAttrs = array ();
if ( ! empty ( $attributes [ 'sn' ][ 0 ])) {
$additionalAttrs [] = $attributes [ 'sn' ][ 0 ];
}
if ( ! empty ( $attributes [ 'givenName' ][ 0 ])) {
$additionalAttrs [] = $attributes [ 'givenName' ][ 0 ];
}
$pwdPolicyResult = checkPasswordStrength ( $_POST [ 'windowsUser_unicodePwd' ], $userName , $additionalAttrs );
2013-04-20 12:52:30 +00:00
if ( $pwdPolicyResult === true ) {
$this -> setSelfServicePassword ( $return , $attributes );
$return [ 'info' ][ 'userPasswordClearText' ][ 0 ] = $_POST [ 'windowsUser_unicodePwd' ];
}
else {
$return [ 'messages' ][] = array ( 'ERROR' , $pwdPolicyResult );
}
}
}
}
}
if ( $passwordChangeOnly ) {
return $return ; // skip processing if only a password change is done
}
2013-04-20 16:13:16 +00:00
// TODO remove this workaround when self service allows to specify the list of active modules
if ( isset ( $attributes [ 'street' ])) {
$attributes [ 'streetAddress' ] = $attributes [ 'street' ];
2013-04-20 12:52:30 +00:00
}
2013-04-20 16:13:16 +00:00
$this -> checkSimpleSelfServiceTextField ( $return , 'physicalDeliveryOfficeName' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'telephoneNumber' , $attributes , $fields , $readOnlyFields , 'telephone' );
2016-01-03 15:43:28 +00:00
$this -> checkSimpleSelfServiceTextField ( $return , 'facsimileTelephoneNumber' , $attributes , $fields , $readOnlyFields , 'telephone' );
2013-04-20 16:13:16 +00:00
$this -> checkSimpleSelfServiceTextField ( $return , 'wWWHomePage' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'streetAddress' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'st' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'l' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'postOfficeBox' , $attributes , $fields , $readOnlyFields );
$this -> checkSimpleSelfServiceTextField ( $return , 'postalCode' , $attributes , $fields , $readOnlyFields , 'postalCode' );
2013-04-20 12:52:30 +00:00
return $return ;
}
2015-08-04 18:41:12 +00:00
2013-04-20 12:52:30 +00:00
/**
* Sets the user password in self service .
* Since the change requires the old password we need to run ldapmodify for this task .
2015-08-04 18:41:12 +00:00
*
2013-04-20 12:52:30 +00:00
* Enter description here ...
* @ param array $return return value for checkSelfServiceOptions () ( used to add message if any )
* @ param array $attributes LDAP attributes
*/
private function setSelfServicePassword ( & $return , $attributes ) {
$newPasswordVal = self :: pwdAttributeValue ( $_POST [ 'windowsUser_unicodePwd' ]);
$oldPassword = Ldap :: decrypt ( $_SESSION [ 'selfService_clientPassword' ], 'SelfService' );
$oldPasswordVal = self :: pwdAttributeValue ( $oldPassword );
$dn = $attributes [ 'dn' ];
$ldif = " dn: " . $dn . " \n " ;
$ldif .= " changetype: modify \n " ;
$ldif .= " delete: unicodePwd \n " ;
$ldif .= " unicodePwd:: " . base64_encode ( $oldPasswordVal ) . " \n " ;
$ldif .= " - \n " ;
$ldif .= " add: unicodePwd \n " ;
$ldif .= " unicodePwd:: " . base64_encode ( $newPasswordVal ) . " \n " ;
$ldif .= " - \n " ;
2015-08-04 18:41:12 +00:00
2013-04-20 12:52:30 +00:00
$serverURL = $_SESSION [ 'selfServiceProfile' ] -> serverURL ;
$tls = '' ;
if ( $_SESSION [ 'selfServiceProfile' ] -> useTLS ) {
$tls = ' -ZZ ' ;
}
$cmd = " /usr/bin/ldapmodify -H " . $serverURL . $tls . " -D " . escapeshellarg ( $dn ) . " -x -w " . escapeshellarg ( $oldPassword );
2015-08-04 18:41:12 +00:00
2013-04-20 12:52:30 +00:00
$descriptorspec = array (
0 => array ( " pipe " , " r " ), // stdin
1 => array ( " pipe " , " w " ), // stout
2 => array ( " pipe " , " w " ) // sterr
);
2015-08-04 18:41:12 +00:00
$process = proc_open ( $cmd , $descriptorspec , $pipes );
2013-04-20 12:52:30 +00:00
if ( is_resource ( $process )) {
fwrite ( $pipes [ 0 ], $ldif );
}
else {
logNewMessage ( LOG_ERR , 'Unable to change password of ' . $dn . '. Calling /usr/bin/ldapmodify failed.' );
$return [ 'messages' ][] = array ( 'ERROR' , _ ( 'Unable to change password.' ));
return ;
}
fclose ( $pipes [ 0 ]);
$outputMessages = '' ;
while ( ! feof ( $pipes [ 1 ])) {
$output = fgets ( $pipes [ 1 ], 1024 );
if ( $output != '' ) {
$outputMessages .= $output ;
}
}
while ( ! feof ( $pipes [ 2 ])) {
$output = fgets ( $pipes [ 2 ], 1024 );
if ( $output != '' ) {
$outputMessages .= $output ;
}
}
fclose ( $pipes [ 1 ]);
$returnCode = proc_close ( $process );
if ( $returnCode != 0 ) {
2014-02-27 20:50:57 +00:00
$outputMessages = htmlspecialchars ( $outputMessages );
// Active Directory message translations
if (( strpos ( $outputMessages , 'DSID-03190F80' ) !== false ) && ( strpos ( $outputMessages , 'unicodePwd' ) !== false )) {
$outputMessages = _ ( 'Your password does not meet the password strength qualifications. Please retry with another one.' ) . '<br><br>' . $outputMessages ;
}
2013-04-20 12:52:30 +00:00
logNewMessage ( LOG_ERR , 'Changing user password failed: ' . $outputMessages );
2014-02-27 20:50:57 +00:00
$return [ 'messages' ][] = array ( 'ERROR' , _ ( 'Unable to change password.' ), $outputMessages );
2013-04-20 12:52:30 +00:00
return ;
}
else {
2015-08-04 18:41:12 +00:00
// update session password for next page load
2013-04-20 12:52:30 +00:00
$_SESSION [ 'selfService_clientPasswordNew' ] = $_POST [ 'windowsUser_unicodePwd' ];
}
}
2013-04-07 17:28:09 +00:00
/**
* This method specifies if a module manages password attributes . The module alias will
2015-08-04 18:41:12 +00:00
* then appear as option in the GUI .
2013-04-07 17:28:09 +00:00
* < br > If the module only wants to get notified about password changes then return false .
*
* @ return boolean true if this module manages password attributes
*/
public function managesPasswordAttributes () {
return true ;
}
/**
* Specifies if this module supports to force that a user must change his password on next login .
2015-08-04 18:41:12 +00:00
*
2013-04-07 17:28:09 +00:00
* @ return boolean force password change supported
*/
public function supportsForcePasswordChange () {
2013-04-13 15:57:32 +00:00
return true ;
2013-04-07 17:28:09 +00:00
}
/**
* This function is called whenever the password should be changed . Account modules
* must change their password attributes only if the modules list contains their module name .
*
* @ param String $password new password
* @ param array $modules list of modules for which the password should be changed
* @ param boolean $forcePasswordChange force the user to change his password at next login
* @ return array list of error messages if any as parameter array for StatusMessage
* e . g . return arrray ( array ( 'ERROR' , 'Password change failed.' ))
*/
public function passwordChangeRequested ( $password , $modules , $forcePasswordChange ) {
if ( ! in_array ( get_class ( $this ), $modules )) {
return array ();
}
2014-04-17 19:26:08 +00:00
// check password strength
$user = empty ( $this -> attributes [ 'userPrincipalName' ][ 0 ]) ? null : $this -> attributes [ 'userPrincipalName' ][ 0 ];
$additionalAttrs = array ();
if ( ! empty ( $this -> attributes [ 'sn' ][ 0 ])) {
$additionalAttrs [] = $this -> attributes [ 'sn' ][ 0 ];
}
if ( ! empty ( $this -> attributes [ 'givenName' ][ 0 ])) {
$additionalAttrs [] = $this -> attributes [ 'givenName' ][ 0 ];
}
$checkResult = checkPasswordStrength ( $password , $user , $additionalAttrs );
if ( $checkResult !== true ) {
return array ( array ( 'ERROR' , $checkResult ));
}
// set new password
2013-04-20 08:54:29 +00:00
$pwdBin = self :: pwdAttributeValue ( $password );
2013-04-07 17:28:09 +00:00
$this -> orig [ 'unicodePwd' ][ 0 ] = 'unknown' ;
$this -> attributes [ 'unicodePwd' ][ 0 ] = $pwdBin ;
2013-04-13 15:57:32 +00:00
$this -> attributes [ 'pwdLastSet' ][ 0 ] = '-1' ;
2013-04-21 16:41:19 +00:00
if ( $forcePasswordChange ) {
$this -> attributes [ 'pwdLastSet' ][ 0 ] = '0' ;
}
2013-04-21 18:53:39 +00:00
$this -> clearTextPassword = $password ;
2013-04-07 17:28:09 +00:00
return array ();
}
2015-08-04 18:41:12 +00:00
2013-04-14 19:19:33 +00:00
/**
* Creates the LDAP password value .
2015-08-04 18:41:12 +00:00
*
2013-04-14 19:19:33 +00:00
* @ param String $password password
*/
2013-04-20 08:54:29 +00:00
public static function pwdAttributeValue ( $password ) {
2013-04-14 19:19:33 +00:00
return iconv ( 'UTF-8' , 'UTF-16LE' , '"' . $password . '"' );
}
2013-04-06 15:00:53 +00:00
2013-04-13 15:57:32 +00:00
/**
* Returns if the account is currently deactivated .
2015-08-04 18:41:12 +00:00
*
* @ param array $attrs LDAP attributes
2013-04-13 15:57:32 +00:00
* @ return boolean is deactivated
*/
public static function isDeactivated ( $attrs ) {
$myAttrs = array_change_key_case ( $attrs , CASE_LOWER );
if ( ! isset ( $myAttrs [ 'useraccountcontrol' ][ 0 ])) {
return false ;
}
return intval ( $myAttrs [ 'useraccountcontrol' ][ 0 ]) & windowsUser :: AC_ACCOUNT_DISABLED ;
}
2013-04-06 15:00:53 +00:00
2013-04-13 15:57:32 +00:00
/**
* Sets if the account is currently deactivated .
2015-08-04 18:41:12 +00:00
*
2013-04-13 15:57:32 +00:00
* @ param boolean $deactivated is deactivated
2013-04-20 08:32:12 +00:00
* @ param array $attrs LDAP attributes to modify ( default $this -> attributes )
2013-04-13 15:57:32 +00:00
*/
2013-04-20 08:32:12 +00:00
public function setIsDeactivated ( $deactivated , & $attrs = null ) {
if ( $attrs == null ) {
$attrs = & $this -> attributes ;
}
2013-04-13 15:57:32 +00:00
foreach ( $attrs as $key => $value ) {
if ( strtolower ( $key ) == 'useraccountcontrol' ) {
if ( $deactivated ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) | windowsUser :: AC_ACCOUNT_DISABLED ;
}
else {
if ( intval ( $attrs [ $key ][ 0 ]) & windowsUser :: AC_ACCOUNT_DISABLED ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) - windowsUser :: AC_ACCOUNT_DISABLED ;
}
}
}
}
}
2013-04-06 15:00:53 +00:00
2013-04-13 15:57:32 +00:00
/**
* Returns if the account is currently locked out .
2015-08-04 18:41:12 +00:00
*
* @ param array $attrs LDAP attributes
2013-04-13 15:57:32 +00:00
* @ return boolean is locked out
*/
private static function isLockedOut ( $attrs ) {
$myAttrs = array_change_key_case ( $attrs , CASE_LOWER );
if ( ! isset ( $attrs [ 'useraccountcontrol' ][ 0 ])) {
return false ;
}
return intval ( $attrs [ 'useraccountcontrol' ][ 0 ]) & windowsUser :: AC_LOCKED_OUT ;
}
/**
* Unlocks the account .
2015-08-04 18:41:12 +00:00
*
2013-04-13 15:57:32 +00:00
* @ param array $attrs LDAP attributes to modify
*/
public static function unlock ( & $attrs ) {
foreach ( $attrs as $key => $value ) {
if ( strtolower ( $key ) == 'useraccountcontrol' ) {
if ( intval ( $attrs [ $key ][ 0 ]) & windowsUser :: AC_LOCKED_OUT ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) - windowsUser :: AC_LOCKED_OUT ;
}
}
}
}
/**
* Returns if the account requires a smartcard to login .
2015-08-04 18:41:12 +00:00
*
* @ param array $attrs LDAP attributes
2013-04-13 15:57:32 +00:00
* @ return boolean requires a smartcard
*/
public static function isSmartCardRequired ( $attrs ) {
$myAttrs = array_change_key_case ( $attrs , CASE_LOWER );
if ( ! isset ( $myAttrs [ 'useraccountcontrol' ][ 0 ])) {
return false ;
}
return intval ( $myAttrs [ 'useraccountcontrol' ][ 0 ]) & windowsUser :: AC_SMARTCARD_REQUIRED ;
}
/**
* Sets if the account requires a smartcard to login .
2015-08-04 18:41:12 +00:00
*
2013-04-13 15:57:32 +00:00
* @ param array $attrs LDAP attributes to modify
* @ param boolean $requireCard requires a smartcard
*/
public static function setIsSmartCardRequired ( & $attrs , $requireCard ) {
foreach ( $attrs as $key => $value ) {
if ( strtolower ( $key ) == 'useraccountcontrol' ) {
if ( $requireCard ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) | windowsUser :: AC_SMARTCARD_REQUIRED ;
}
else {
if ( intval ( $attrs [ $key ][ 0 ]) & windowsUser :: AC_SMARTCARD_REQUIRED ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) - windowsUser :: AC_SMARTCARD_REQUIRED ;
}
}
}
}
}
/**
* Returns if the account never expires .
2015-08-04 18:41:12 +00:00
*
* @ param array $attrs LDAP attributes
2013-04-13 15:57:32 +00:00
* @ return boolean never expires
*/
public static function isNeverExpiring ( $attrs ) {
$myAttrs = array_change_key_case ( $attrs , CASE_LOWER );
if ( ! isset ( $myAttrs [ 'useraccountcontrol' ][ 0 ])) {
return false ;
}
return intval ( $myAttrs [ 'useraccountcontrol' ][ 0 ]) & windowsUser :: AC_PWD_NEVER_EXPIRES ;
}
/**
* Sets if the account never expires .
2015-08-04 18:41:12 +00:00
*
2013-04-13 15:57:32 +00:00
* @ param array $attrs LDAP attributes to modify
* @ param boolean $neverExpires never expires
*/
public static function setIsNeverExpiring ( & $attrs , $neverExpires ) {
foreach ( $attrs as $key => $value ) {
if ( strtolower ( $key ) == 'useraccountcontrol' ) {
if ( $neverExpires ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) | windowsUser :: AC_PWD_NEVER_EXPIRES ;
}
else {
if ( intval ( $attrs [ $key ][ 0 ]) & windowsUser :: AC_PWD_NEVER_EXPIRES ) {
$attrs [ $key ][ 0 ] = intval ( $attrs [ $key ][ 0 ]) - windowsUser :: AC_PWD_NEVER_EXPIRES ;
}
}
}
}
}
/**
* Finds all existing groups .
*
* @ return array group DNs
*/
private function findGroups () {
if ( $this -> groupCache != null ) {
return $this -> groupCache ;
}
$return = array ();
$types = array ( 'group' );
$results = searchLDAPByFilter ( '(objectClass=group)' , array ( 'dn' ), $types );
$count = sizeof ( $results );
for ( $i = 0 ; $i < $count ; $i ++ ) {
if ( isset ( $results [ $i ][ 'dn' ])) {
$return [] = $results [ $i ][ 'dn' ];
}
}
$this -> groupCache = $return ;
return $return ;
}
2015-08-04 18:41:12 +00:00
2013-11-09 13:26:31 +00:00
/**
* Gets the list of possible domains from the config setting .
2015-08-04 18:41:12 +00:00
*
2013-11-09 13:26:31 +00:00
* @ return array domain list
*/
private function getDomains () {
$domains = array ();
if ( ! empty ( $this -> moduleSettings [ 'windowsUser_domains' ])) {
foreach ( $this -> moduleSettings [ 'windowsUser_domains' ] as $domain ) {
$domain = trim ( str_replace ( '@' , '' , $domain ));
if ( ! empty ( $domain )) {
$domains [] = $domain ;
}
}
}
return array_values ( array_unique ( $domains ));
}
2015-08-04 18:41:12 +00:00
2015-09-02 16:39:30 +00:00
/**
* Returns the formatted value for last password change .
*
* @ param array $attributes user attributes ( $this -> attributes if null )
* @ return String last password change or " - "
*/
private function formatPwdLastSet ( $attributes = null ) {
if ( $attributes == null ) {
$attributes = & $this -> attributes ;
}
if ( ! empty ( $attributes [ 'pwdlastset' ][ 0 ])) {
return $this -> formatFileTime ( $attributes [ 'pwdlastset' ][ 0 ]);
}
elseif ( empty ( $attributes [ 'pwdLastSet' ][ 0 ])) {
return ' - ' ;
}
return $this -> formatFileTime ( $attributes [ 'pwdLastSet' ][ 0 ]);
}
/**
* Returns the formatted value for last login .
*
* @ return String last login or " - "
*/
private function formatLastLogonTimestamp () {
if ( empty ( $this -> attributes [ 'lastLogonTimestamp' ][ 0 ])) {
return ' - ' ;
}
return $this -> formatFileTime ( $this -> attributes [ 'lastLogonTimestamp' ][ 0 ]);
}
2015-11-02 20:53:20 +00:00
/**
* Returns the formatted value for the account expiration date .
*
* @ param array $attributes user attributes ( $this -> attributes if null )
* @ return String date or -
*/
private function formatAccountExpires ( $attributes = null ) {
if ( $attributes == null ) {
$attributes = & $this -> attributes ;
}
if ( empty ( $attributes [ 'accountExpires' ][ 0 ]) || ( $attributes [ 'accountExpires' ][ 0 ] == '0' )
|| ( $attributes [ 'accountExpires' ][ 0 ] == '9223372036854775807' )) {
return ' - ' ;
}
return $this -> formatFileTime ( $attributes [ 'accountExpires' ][ 0 ]);
}
2015-09-02 16:39:30 +00:00
/**
* Formats a value in file time ( 100 ns since 1601 - 01 - 01 ) .
*
* @ param integer $value time value
* @ return String formatted value
*/
private function formatFileTime ( $value ) {
2015-11-16 19:48:58 +00:00
if ( empty ( $value ) || ( $value == '-1' )) {
2015-09-02 16:39:30 +00:00
return '' ;
}
$seconds = substr ( $value , 0 , - 7 );
$time = new DateTime ( '1601-01-01' , new DateTimeZone ( 'UTC' ));
$time -> add ( new DateInterval ( 'PT' . $seconds . 'S' ));
$time -> setTimezone ( getTimeZone ());
return $time -> format ( 'Y-m-d H:i:s' );
}
2015-11-02 20:53:20 +00:00
/**
* Returns a value in file time ( 100 ns since 1601 - 01 - 01 ) .
*
* @ param integer $value time value as int
* @ return DateTime time value
*/
2015-11-27 21:03:27 +00:00
public static function getFileTime ( $value ) {
2015-11-02 20:53:20 +00:00
if ( empty ( $value )) {
return null ;
}
$seconds = substr ( $value , 0 , - 7 );
$time = new DateTime ( '1601-01-01' , new DateTimeZone ( 'UTC' ));
$time -> add ( new DateInterval ( 'PT' . $seconds . 'S' ));
$time -> setTimezone ( getTimeZone ());
return $time ;
}
/**
* Sets the expiration date of this account .
* If all parameters are null the expiration date will be removed .
*
* @ param String $year year ( e . g . 2040 )
* @ param String $month month ( e . g . 8 )
* @ param String $day day ( e . g . 27 )
*/
public function setExpirationDate ( $year , $month , $day ) {
if (( $year == null ) && ( $month == null ) && ( $day == null )) {
unset ( $this -> attributes [ 'accountExpires' ]);
return ;
}
$this -> attributes [ 'accountExpires' ][ 0 ] = $this -> buildExpirationDate ( $year , $month , $day );
}
/**
* Builds the value for the expiration date .
*
* @ param int $year year
* @ param int $month month
* @ param int $day day
*/
private function buildExpirationDate ( $year , $month , $day ) {
$timeBase = new DateTime ( '1601-01-01' , getTimeZone ());
$time = new DateTime ( " $year - $month - $day " , getTimeZone ());
$timeDiff = $time -> diff ( $timeBase );
$days = $timeDiff -> format ( '%a' );
$seconds = $days * 24 * 3600 - ( $time -> getOffset ());
return $seconds . '0000000' ;
}
2015-11-07 14:44:34 +00:00
/**
* Returns a list of configuration options .
*
* Calling this method does not require the existence of an enclosing { @ link accountContainer } .< br >
* < br >
* The field names are used as keywords to load and save settings .
* We recommend to use the module name as prefix for them ( e . g . posixAccount_homeDirectory ) to avoid naming conflicts .
*
* @ param array $scopes account types ( user , group , host )
* @ param array $allScopes list of all active account modules and their scopes ( module => array ( scopes ))
* @ return mixed htmlElement or array of htmlElement
*
* @ see htmlElement
*/
public function get_configOptions ( $scopes , $allScopes ) {
// configuration options
$configContainer = new htmlTable ();
$configContainerHead = new htmlTable ();
$configContainerHead -> addElement ( new htmlTableExtendedInputTextarea ( 'windowsUser_domains' , '' , 30 , 3 , _ ( 'Domains' ), 'domains' ));
$configContainer -> addElement ( $configContainerHead , true );
$configContainer -> addVerticalSpace ( '10px' );
$configHiddenGroup = new htmlGroup ();
$configHiddenGroup -> addElement ( new htmlOutputText ( _ ( 'Hidden options' )));
$configHiddenGroup -> addElement ( new htmlHelpLink ( 'hiddenOptions' ));
$configContainer -> addElement ( $configHiddenGroup , true );
$configContainerOptions = new htmlTable ();
2016-01-03 15:43:28 +00:00
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidefacsimileTelephoneNumber' , false , _ ( 'Fax number' ), null , false ));
2015-11-07 14:44:34 +00:00
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidesAMAccountName' , true , _ ( 'User name (pre W2K)' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidemsSFU30Name' , true , _ ( 'NIS name' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidemsSFU30NisDomain' , true , _ ( 'NIS domain' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidepwdLastSet' , false , _ ( 'Last password change' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidelastLogonTimestamp' , false , _ ( 'Last login' ), null , false ), true );
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidejpegPhoto' , true , _ ( 'Photo' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidetitle' , true , _ ( 'Job title' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidecarLicense' , true , _ ( 'Car license' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hideemployeeNumber' , true , _ ( 'Employee number' ), null , false ));
2016-01-03 15:43:28 +00:00
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hideemployeeType' , true , _ ( 'Employee type' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidebusinessCategory' , true , _ ( 'Business category' ), null , false ), true );
2015-11-07 14:44:34 +00:00
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidedepartmentNumber' , true , _ ( 'Department' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hideou' , true , _ ( 'Organisational unit' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hideo' , true , _ ( 'Organisation' ), null , false ));
$configContainerOptions -> addElement ( new htmlTableExtendedInputCheckbox ( 'windowsUser_hidemanager' , true , _ ( 'Manager' ), null , false ));
$configContainer -> addElement ( $configContainerOptions , true );
2015-11-07 15:43:43 +00:00
$advancedOptions = new htmlTable ();
$advancedOptions -> addElement ( new htmlSubTitle ( _ ( 'Photo' )), true );
$photoTable = new htmlTable ();
$photoTable -> colspan = 2 ;
if ( extension_loaded ( 'imagick' )) {
$photoTable -> addElement ( new htmlTableExtendedInputField ( _ ( 'Maximum width (px)' ), 'windowsUser_jpegPhoto_maxWidth' , null , 'crop' ), true );
$photoTable -> addElement ( new htmlTableExtendedInputField ( _ ( 'Maximum height (px)' ), 'windowsUser_jpegPhoto_maxHeight' , null , 'crop' ), true );
}
$photoTable -> addElement ( new htmlTableExtendedInputField ( _ ( 'Maximum file size (kB)' ), 'windowsUser_jpegPhoto_maxSize' ), true );
$advancedOptions -> addElement ( $photoTable , true );
$advancedOptionsAccordion = new htmlAccordion ( 'inetOrgPersonAdvancedOptions' , array ( _ ( 'Advanced options' ) => $advancedOptions ), false );
$advancedOptionsAccordion -> colspan = 5 ;
$configContainer -> addElement ( $advancedOptionsAccordion );
2015-11-07 14:44:34 +00:00
return $configContainer ;
}
2015-11-08 09:59:20 +00:00
/**
* Loads cached data from LDAP such as departmets etc .
*/
private function initCache () {
if ( $this -> departmentCache != null ) {
return ;
}
$attrs = array ();
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidedepartmentNumber' , true )) {
$attrs [] = 'departmentNumber' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideou' , true )) {
$attrs [] = 'ou' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideo' , true )) {
$attrs [] = 'o' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidetitle' , true )) {
$attrs [] = 'title' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hideemployeeType' , true )) {
$attrs [] = 'employeeType' ;
}
if ( ! $this -> isBooleanConfigOptionSet ( 'windowsUser_hidebusinessCategory' , true )) {
$attrs [] = 'businessCategory' ;
}
$departments = array ();
$ous = array ();
$os = array ();
$titles = array ();
$employeeTypes = array ();
$businessCategories = array ();
if ( sizeof ( $attrs ) > 0 ) {
$result = searchLDAPByFilter ( '(objectClass=user)' , $attrs , array ( $this -> get_scope ()));
foreach ( $result as $attributes ) {
if ( isset ( $attributes [ 'departmentnumber' ])) {
foreach ( $attributes [ 'departmentnumber' ] as $val ) {
$departments [] = $val ;
}
}
if ( isset ( $attributes [ 'ou' ])) {
foreach ( $attributes [ 'ou' ] as $val ) {
$ous [] = $val ;
}
}
if ( isset ( $attributes [ 'o' ])) {
foreach ( $attributes [ 'o' ] as $val ) {
$os [] = $val ;
}
}
if ( isset ( $attributes [ 'title' ])) {
foreach ( $attributes [ 'title' ] as $val ) {
$titles [] = $val ;
}
}
if ( isset ( $attributes [ 'employeetype' ])) {
foreach ( $attributes [ 'employeetype' ] as $val ) {
$employeeTypes [] = $val ;
}
}
if ( isset ( $attributes [ 'businesscategory' ])) {
foreach ( $attributes [ 'businesscategory' ] as $val ) {
$businessCategories [] = $val ;
}
}
}
}
$this -> departmentCache = array_values ( array_unique ( $departments ));
$this -> oCache = array_values ( array_unique ( $os ));
$this -> ouCache = array_values ( array_unique ( $ous ));
$this -> titleCache = array_values ( array_unique ( $titles ));
$this -> employeeTypeCache = array_values ( array_unique ( $employeeTypes ));
$this -> businessCategoryCache = array_values ( array_unique ( $businessCategories ));
}
2015-11-18 07:17:54 +00:00
/**
* Returns a list of jobs that can be run .
*
* @ param LAMConfig $config configuration
* @ return array list of jobs
*/
public function getSupportedJobs ( & $config ) {
return array (
new WindowsPasswordNotifyJob ()
);
}
}
2016-01-05 16:55:01 +00:00
if ( interface_exists ( '\LAM\JOB\Job' , false )) {
2015-11-18 07:17:54 +00:00
include_once dirname ( __FILE__ ) . '/../passwordExpirationJob.inc' ;
/**
* Job to notify users about password expiration .
*
* @ package jobs
*/
class WindowsPasswordNotifyJob extends \LAM\JOB\PasswordExpirationJob {
/**
* Returns the alias name of the job .
*
* @ return String name
*/
public function getAlias () {
return _ ( 'Windows' ) . ': ' . _ ( 'Notify users about password expiration' );
}
/**
* Returns the description of the job .
*
* @ return String description
*/
public function getDescription () {
return _ ( 'This job sends out emails to inform your users that their passwords will expire soon.' );
}
/**
* Returns a list of password policy options . The options are later passed to function checkSingleUser () .
* This reads the password policy to calculate expiration times later . Maxpwdage is the maximum amount of
* time , in 100 - nanosecond intervals , a password is valid .
*
* @ return array options ( 'maxpwdage' => max age in ns )
*/
protected function getPolicyOptions () {
$userSuffix = $_SESSION [ 'config' ] -> get_Suffix ( 'user' );
if ( empty ( $userSuffix )) {
logNewMessage ( LOG_ERR , 'No user suffix set in server profile.' );
return array ();
}
// extract base DN from user suffix
$domainRoot = substr ( $userSuffix , stripos ( $userSuffix , 'dc=' ));
if ( empty ( $domainRoot )) {
logNewMessage ( LOG_ERR , " No domain root found in $userSuffix . " );
return array ();
}
logNewMessage ( LOG_DEBUG , " Using $domainRoot as domain root " );
$policyDN = 'cn=builtin,' . $domainRoot ;
$policyAttrs = ldapGetDN ( $policyDN , array ( 'maxPwdAge' ));
if ( empty ( $policyAttrs [ 'maxpwdage' ][ 0 ])) {
logNewMessage ( LOG_ERR , 'No maxPwdAge found for this domain.' );
return array ();
}
$maxPwdAge = $policyAttrs [ 'maxpwdage' ][ 0 ];
logNewMessage ( LOG_DEBUG , " Using maxPwdAge = $maxPwdAge . " );
return array ( 'maxpwdage' => $maxPwdAge );
}
/**
* Searches for users in LDAP .
*
* @ param String $jobID unique job identifier
* @ param array $options config options ( name => value )
* @ return array list of user attributes
*/
protected function findUsers ( $jobID , $options ) {
// read users
2015-11-27 21:03:27 +00:00
$sysattrs = array ( 'mail' , 'pwdLastSet' , 'accountExpires' , 'useraccountcontrol' );
2015-11-18 07:17:54 +00:00
$attrs = $this -> getAttrWildcards ( $jobID , $options );
$attrs = array_values ( array_unique ( array_merge ( $attrs , $sysattrs )));
$userResults = searchLDAPByFilter ( '(&(pwdLastSet=*)(mail=*))' , $attrs , array ( 'user' ));
return $userResults ;
}
/**
* Checks if a user needs to change his password .
*
* @ param integer $jobID job ID
* @ param array $options job settings
* @ param PDO $pdo PDO
* @ param DateTime $now current time
* @ param array $policyOptions list of max age values ( policy DN => maxAge )
* @ param array $user user attributes
* @ param boolean $isDryRun just do a dry run , nothing is modified
*/
protected function checkSingleUser ( $jobID , $options , & $pdo , $now , $policyOptions , $user , $isDryRun ) {
2015-11-27 21:03:27 +00:00
// skip if password does not expire at all
2015-11-18 07:17:54 +00:00
if ( windowsUser :: isNeverExpiring ( $user )) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' does not expire.' );
return ;
}
2015-11-27 21:03:27 +00:00
// skip if no information about last password change
2015-11-18 07:17:54 +00:00
if ( empty ( $user [ 'pwdlastset' ][ 0 ]) || ( $user [ 'pwdlastset' ][ 0 ] < 1 )) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' has no valid "pwdLastSet".' );
return ;
}
2015-11-27 21:03:27 +00:00
// skip if account itself is expired
if ( ! empty ( $user [ 'accountexpires' ][ 0 ])) {
$accountExpiration = windowsUser :: getFileTime ( $user [ 'accountexpires' ][ 0 ]);
if ( $accountExpiration <= $now ) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' already expired' );
return ;
}
}
// skip if account is deactivated
if ( windowsUser :: isDeactivated ( $user )) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' is deactivated.' );
return ;
}
2015-11-18 07:17:54 +00:00
$maxPwdAge = $policyOptions [ 'maxpwdage' ];
// calculate time when password expires
2015-11-27 21:03:27 +00:00
$lastPwdTime = windowsUser :: getFileTime ( $user [ 'pwdlastset' ][ 0 ]);
2015-11-18 07:17:54 +00:00
logNewMessage ( LOG_DEBUG , " Last password change on " . $lastPwdTime -> format ( 'Y-m-d' ));
$numDaysToWarn = $options [ $this -> getConfigPrefix () . '_mailNotificationPeriod' . $jobID ][ 0 ];
logNewMessage ( LOG_DEBUG , " Number of days before warning " . $numDaysToWarn );
2015-11-27 21:03:27 +00:00
// expiration date = pwdLastSet - maxpwdage
$expireTime = windowsUser :: getFileTime ( $user [ 'pwdlastset' ][ 0 ] - $maxPwdAge );
2015-11-18 07:17:54 +00:00
logNewMessage ( LOG_DEBUG , " Password expires on " . $expireTime -> format ( 'Y-m-d' ));
// skip already expired accounts
if ( $expireTime <= $now ) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' already expired' );
return ;
}
// calculate time of notification
$notifyTime = clone $expireTime ;
$notifyTime -> sub ( new DateInterval ( 'P' . $numDaysToWarn . 'D' ));
$notifyTime -> setTimeZone ( getTimeZone ());
logNewMessage ( LOG_DEBUG , " Password notification on " . $notifyTime -> format ( 'Y-m-d H:i' ));
// skip if notification is in the future
if ( $notifyTime > $now ) {
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' does not need notification yet.' );
return ;
}
$dbLastChange = $this -> getDBLastPwdChangeTime ( $jobID , $pdo , $user [ 'dn' ]);
// skip entries where mail was already sent
2015-11-27 21:03:27 +00:00
if ( $dbLastChange == $user [ 'pwdlastset' ][ 0 ]) {
2015-11-18 07:17:54 +00:00
logNewMessage ( LOG_DEBUG , $user [ 'dn' ] . ' was already notified.' );
return ;
}
if ( $isDryRun ) {
// no action for dry run
logNewMessage ( LOG_NOTICE , 'Not sending email to ' . $user [ 'dn' ] . ' because of dry run.' );
return ;
}
// send email
$success = $this -> sendMail ( $options , $jobID , $user );
// update DB if mail was sent successfully
if ( $success ) {
2015-11-27 21:03:27 +00:00
$this -> setDBLastPwdChangeTime ( $jobID , $pdo , $user [ 'dn' ], $user [ 'pwdlastset' ][ 0 ]);
2015-11-18 07:17:54 +00:00
}
}
}
2013-04-13 15:57:32 +00:00
}
2015-08-04 18:41:12 +00:00
2013-04-06 15:00:53 +00:00
?>