2003-12-12 00:52:35 +00:00
< ? php
/*
$Id $
This code is part of LDAP Account Manager ( http :// www . sourceforge . net / projects / lam )
Copyright ( C ) 2003 Tilo Lutz
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2004-07-02 12:09:06 +00:00
/**
* Manages the atrributes of object class inetOrgPerson .
*
* @ package modules
* @ author Tilo Lutz
* @ author Roland Gruber
* @ author Michael Duergner
2003-12-12 00:52:35 +00:00
*/
2004-07-02 12:09:06 +00:00
/**
* This class contains all account LDAP attributes
* and funtioncs required to deal with inetOrgPerson .
*
* @ package modules
2003-12-12 00:52:35 +00:00
*/
2004-06-08 18:54:37 +00:00
class inetOrgPerson extends baseModule {
2004-06-13 19:58:58 +00:00
2004-06-24 09:51:12 +00:00
/**
* Creates a new inetOrgPerson object .
*/
function inetOrgPerson ( $scope ) {
// error messages for input checks
$this -> messages [ 'host' ] = array ( 'ERROR' , _ ( 'Unix workstations' ), _ ( 'Unix workstations is invalid.' ));
$this -> messages [ 'givenName' ] = array ( 'ERROR' , _ ( 'Given name' ), _ ( 'Given name contains invalid characters' ));
$this -> messages [ 'surname' ] = array ( 'ERROR' , _ ( 'Surname' ), _ ( 'Surname contains invalid characters' ));
$this -> messages [ 'telephoneNumber' ] = array ( 'ERROR' , _ ( 'Telephone number' ), _ ( 'Please enter a valid telephone number!' ));
$this -> messages [ 'mobileTelephone' ] = array ( 'ERROR' , _ ( 'Mobile number' ), _ ( 'Please enter a valid mobile number!' ));
$this -> messages [ 'facsimileNumber' ] = array ( 'ERROR' , _ ( 'Fax number' ), _ ( 'Please enter a valid fax number!' ));
2004-07-02 16:01:17 +00:00
$this -> messages [ 'email' ] = array ( 'ERROR' , _ ( 'eMail address' ), _ ( 'Please enter a valid eMail address!' ));
2004-06-24 09:51:12 +00:00
$this -> messages [ 'street' ] = array ( 'ERROR' , _ ( 'Street' ), _ ( 'Please enter a valid street name!' ));
$this -> messages [ 'postalAddress' ] = array ( 'ERROR' , _ ( 'Postal address' ), _ ( 'Please enter a valid postal address!' ));
$this -> messages [ 'postalCode' ] = array ( 'ERROR' , _ ( 'Postal code' ), _ ( 'Please enter a valid postal code!' ));
$this -> messages [ 'title' ] = array ( 'ERROR' , _ ( 'Title' ), _ ( 'Please enter a valid title!' ));
$this -> messages [ 'employeeType' ] = array ( 'ERROR' , _ ( 'Employee type' ), _ ( 'Please enter a valid employee type!' ));
2004-07-01 15:54:33 +00:00
// call parent constructor
parent :: baseModule ( $scope );
2004-06-24 09:51:12 +00:00
}
2004-06-13 19:58:58 +00:00
/**
* Returns meta data that is interpreted by parent class
*
* @ return array array with meta data
*/
function get_metaData () {
$return = array ();
// manages user accounts
$return [ " account_types " ] = array ( " user " );
2004-06-14 16:05:36 +00:00
// alias name
$return [ " alias " ] = _ ( 'Personal' );
2004-06-20 17:32:02 +00:00
// module dependencies
$return [ 'dependencies' ] = array ( 'depends' => array ( 'posixAccount' ), 'conflicts' => array ( 'account' ));
2004-07-01 15:54:33 +00:00
// profile elements
$return [ 'profile_options' ] = array (
array (
0 => array ( 'kind' => 'text' , 'text' => _ ( 'Job title' ) . " : " ),
1 => array ( 'kind' => 'input' , 'name' => 'inetOrgPerson_title' , 'type' => 'text' , 'size' => '30' , 'maxlength' => '255' ),
2 => array ( 'kind' => 'help' , 'value' => 'TODO' )),
array (
0 => array ( 'kind' => 'text' , 'text' => _ ( 'Employee type' ) . " : " ),
1 => array ( 'kind' => 'input' , 'name' => 'inetOrgPerson_employeeType' , 'type' => 'text' , 'size' => '30' , 'maxlength' => '255' ),
2 => array ( 'kind' => 'help' , 'value' => 'TODO' ))
);
// profile checks
$return [ 'profile_checks' ][ 'inetOrgPerson_title' ] = array ( 'type' => 'regex_i' , 'regex' => $this -> regex_title ,
'error_message' => $this -> messages [ 'title' ]);
$return [ 'profile_checks' ][ 'inetOrgPerson_employeeType' ] = array ( 'type' => 'regex_i' ,
'regex' => $this -> regex_employeeType , 'error_message' => $this -> messages [ 'employeeType' ]);
2004-08-17 15:16:17 +00:00
// available PDF fields
$return [ 'PDF_fields' ] = array ( 'description' ,
'host' ,
'title' ,
'givenName' ,
'sn' ,
'employeeType' ,
'street' ,
'postalCode' ,
'postalAddress' ,
'telephoneNumber' ,
'mobileTelephoneNumber' ,
'facimilieTelefonNumber' ,
'mail' );
2004-09-08 17:39:06 +00:00
// help Entries
$return [ 'help' ] = array ( 'description' => array ( " ext " => " FALSE " , " Headline " => _ ( " Gecos " ), " Text " => _ ( " Host description. If left empty host name will be used. " )),
'title' => array ( " ext " => " FALSE " , " Headline " => _ ( " Title " ), " Text " => _ ( " Title of user, Mr., Ms., ... " )),
'givenName' => array ( " ext " => " FALSE " , " Headline " => _ ( " Given name " ), " Text " => _ ( " Given name of user. Only letters, - and spaces are allowed. " )),
'sn' => array ( " ext " => " FALSE " , " Headline " => _ ( " Surname " ), " Text " => _ ( " Surname of user. Only letters, - and spaces are allowed. " )),
'employeeType' => array ( " ext " => " FALSE " , " Headline " => _ ( " Employee type " ), " Text " => _ ( " Employee type: worker, student, nurse, ... " )),
'street' => array ( " ext " => " FALSE " , " Headline " => _ ( " Street " ), " Text " => _ ( " Street " )),
'postalCode' => array ( " ext " => " FALSE " , " Headline " => _ ( " Postal code " ), " Text " => _ ( " Postal code " )),
'postalAddress' => array ( " ext " => " FALSE " , " Headline " => _ ( " Postal address " ), " Text " => _ ( " Postal address, city " )),
'telephoneNumber' => array ( " ext " => " FALSE " , " Headline " => _ ( " Telephone number " ), " Text " => _ ( " Telephone number " )),
'mobileTelephoneNumber' => array ( " ext " => " FALSE " , " Headline " => _ ( " Mobile number " ), " Text " => _ ( " Mobile number " )),
'facsimileTelephoneNumber' => array ( " ext " => " FALSE " , " Headline " => _ ( " Fax number " ), " Text " => _ ( " Fax number " )),
'mail' => array ( " ext " => " FALSE " , " Headline " => _ ( " eMail address " ), " Text " => _ ( " eMail address " )));
2004-08-17 15:16:17 +00:00
2004-06-13 19:58:58 +00:00
return $return ;
}
2004-07-02 12:09:06 +00:00
/**
* Initializes the module in its accountContainer
*
* @ param string $base the name of account_container in session
*/
2004-06-08 18:54:37 +00:00
function init ( $base ) {
2004-09-01 20:53:06 +00:00
// call parent init
parent :: init ( $base );
2003-12-27 11:21:00 +00:00
// load attribtues which are used in inetOrgPerson objectClass
2004-02-09 18:11:01 +00:00
// unset attributes which are "must" but not in this module
// cn will be set to uid in module posixAccount
// Therefore module posixAccount is required an cn will be removed from main index in account_container
2003-12-27 11:21:00 +00:00
// Create copy of attributes
2004-02-12 12:09:41 +00:00
$this -> orig = $_SESSION [ $this -> base ] -> get_module_attributes ( 'inetOrgPerson' );
$this -> attributes = $_SESSION [ $this -> base ] -> get_module_attributes ( 'inetOrgPerson' );
2003-12-27 11:21:00 +00:00
// Add objectClass to attributes
2003-12-19 12:45:23 +00:00
$this -> attributes [ 'objectClass' ][ 0 ] = 'inetOrgPerson' ;
2003-12-12 00:52:35 +00:00
}
// Variables
2004-07-02 12:09:06 +00:00
/** This variable contains all inetOrgPerson attributes */
2003-12-12 11:52:52 +00:00
var $attributes ;
2004-07-02 12:09:06 +00:00
/**
* If an account was loaded all attributes are kept in this array
* to compare it with new changed attributes .
2003-12-12 00:52:35 +00:00
*/
var $orig ;
2004-07-02 12:09:06 +00:00
/** regular expression for host name */
var $regex_host = '^([a-z0-9\\.-])+(([,])+([ ])*([a-z0-9\\.-])+)*$' ;
/** regular expression for first/last name */
var $regex_name = '^([a-z <20> <> <EFBFBD> <EFBFBD> -])+$' ;
/** regular expression for telephone numbers */
2004-06-24 09:51:12 +00:00
var $regex_telephoneNumber = '^(\+)*([0-9]|[ ]|[.]|[(]|[)]|[/]|[-])*$' ;
2004-07-02 12:09:06 +00:00
/** regular expression for e-mail */
var $regex_email = '^(([0-9a-z\\._-])+[@]([0-9a-z-])+([.]([0-9a-z-])+)*)*$' ;
/** regular expression for street names */
var $regex_street = '^([0-9a-z \\.<2E> <> <EFBFBD> <EFBFBD> -])*$' ;
/** regular expression for postal address */
var $regex_postalAddress = '^([0-9a-z \\.<2E> <> <EFBFBD> <EFBFBD> -])*$' ;
/** regular expression for postal codes */
var $regex_postalCode = '^([0-9a-z])*$' ;
/** regular expression for job titles */
var $regex_title = '^([0-9a-z \\.<2E> <> <EFBFBD> <EFBFBD> -])*$' ;
/** regular expression for employee types */
var $regex_employeeType = '^([0-9a-z \\.<2E> <> <EFBFBD> <EFBFBD> -])*$' ;
/** list of possible error messages */
2004-06-24 09:51:12 +00:00
var $messages = array ();
2004-02-21 17:35:16 +00:00
2003-12-27 11:21:00 +00:00
/* This function returns true if all required attributes from other
* modules are set . This is required to prevent undefined states
*/
2003-12-20 19:24:01 +00:00
function module_ready () {
return true ;
}
2004-02-09 18:11:01 +00:00
/* This functions return true
* if all needed settings are done
*/
function module_complete () {
if ( ! $this -> module_ready ()) return false ;
if ( $this -> attributes [ 'sn' ][ 0 ] == '' ) return false ;
if ( $this -> attributes [ 'givenName' ][ 0 ] == '' ) return false ;
return true ;
}
2003-12-27 11:21:00 +00:00
/* This function returns a list of all html - pages in module
* This is usefull for mass upload and pdf - files
* because lam can walk trough all pages itself and do some
* error checkings
*/
function pages () {
return array ( 'attributes' );
}
2004-01-18 12:52:52 +00:00
/*
*/
2004-09-08 18:26:00 +00:00
/* function get_help ( $id ) {
2004-01-18 12:52:52 +00:00
switch ( $id ) {
2004-09-08 17:39:06 +00:00
case 'description' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Gecos " ), " Text " => _ ( " Host description. If left empty host name will be used. " ));
break ;
case 'title' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Title " ), " Text " => _ ( " Title of user, Mr., Ms., ... " ));
break ;
case 'givenName' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Given name " ), " Text " => _ ( " Given name of user. Only letters, - and spaces are allowed. " ));
break ;
case 'sn' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Surname " ), " Text " => _ ( " Surname of user. Only letters, - and spaces are allowed. " ));
break ;
case 'employeeType' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Employee type " ), " Text " => _ ( " Employee type: worker, student, nurse, ... " ));
break ;
case 'street' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Street " ), " Text " => _ ( " Street " ));
break ;
case 'postalCode' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Postal code " ), " Text " => _ ( " Postal code " ));
break ;
case 'postalAddress' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Postal address " ), " Text " => _ ( " Postal address, city " ));
break ;
case 'telephoneNumber' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Telephone number " ), " Text " => _ ( " Telephone number " ));
break ;
case 'mobileTelephoneNumber' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Mobile number " ), " Text " => _ ( " Mobile number " ));
break ;
case 'facsimileTelephoneNumber' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " Fax number " ), " Text " => _ ( " Fax number " ));
break ;
case 'mail' :
return array ( " ext " => " FALSE " , " Headline " => _ ( " eMail address " ), " Text " => _ ( " eMail address " ));
2004-01-18 12:52:52 +00:00
break ;
}
2004-09-08 17:39:06 +00:00
return false ;
2004-09-08 18:26:00 +00:00
} */
2004-01-18 12:52:52 +00:00
2003-12-30 15:36:30 +00:00
/* This function returns all ldap attributes
* which are part of inetOrgPerson and returns
* also their values .
2003-12-12 00:52:35 +00:00
*/
2003-12-30 15:36:30 +00:00
function get_attributes () {
return $this -> attributes ;
2003-12-12 00:52:35 +00:00
}
/* This function loads all attributes into the object
* $attr is an array as it ' s retured from ldap_get_attributes
*/
function load_attributes ( $attr ) {
2003-12-30 17:09:15 +00:00
// Load attributes which are displayed
2003-12-12 18:21:15 +00:00
// unset count entries
unset ( $attr [ 'count' ]);
$attributes = array_keys ( $attr );
foreach ( $attributes as $attribute ) unset ( $attr [ $attribute ][ 'count' ]);
// unset double entries
for ( $i = 0 ; $i < count ( $attr ); $i ++ )
if ( isset ( $attr [ $i ])) unset ( $attr [ $i ]);
foreach ( $attributes as $attribute ) {
2003-12-30 17:09:15 +00:00
if ( isset ( $this -> attributes [ $attribute ])) {
2003-12-12 18:21:15 +00:00
// decode as unicode
2003-12-30 17:09:15 +00:00
$this -> attributes [ $attribute ] = $attr [ $attribute ];
for ( $i = 0 ; $i < count ( $this -> attributes [ $attribute ]); $i ++ ) {
$this -> attributes [ $attribute ][ $i ] = utf8_decode ( $this -> attributes [ $attribute ][ $i ]);
$this -> orig [ $attribute ][ $i ] = utf8_decode ( $this -> attributes [ $attribute ][ $i ]);
}
2003-12-12 18:21:15 +00:00
}
}
2003-12-27 11:21:00 +00:00
// Add objectClass to orig because we don't want to add objectClass if it's already set
2003-12-19 12:45:23 +00:00
$this -> orig [ 'objectClass' ][ 0 ] = 'inetOrgPerson' ;
2003-12-12 18:21:15 +00:00
return 0 ;
2003-12-12 00:52:35 +00:00
}
2003-12-27 11:21:00 +00:00
/* This function returns an array with 4 entries :
* array ( DN1 ( 'add' => array ( $attr ), 'remove' => array ( $attr ), 'modify' => array ( $attr ), 'lamdaemon' => array ( cmds )), DN2 .... )
2003-12-12 00:52:35 +00:00
* 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
* add are attributes which have to be added to ldap entry
* remove are attributes which have to be removed from ldap entry
2003-12-27 11:21:00 +00:00
* lamdaemon are lamdaemon commands to modify homedir , quotas , ...
2003-12-12 00:52:35 +00:00
*/
function save_attributes () {
2003-12-27 11:21:00 +00:00
// Get easy attributes
2003-12-20 19:24:01 +00:00
$return = $_SESSION [ $this -> base ] -> save_module_attributes ( $this -> attributes , $this -> orig );
2003-12-27 11:21:00 +00:00
// unset password. First we hanlde userPassword with posixAccount, second we hanlde it completly separat
// because it en/decrypted in session
2003-12-20 21:42:52 +00:00
if ( isset ( $return [ $_SESSION [ $this -> base ] -> dn ][ 'modify' ][ 'userPassword' ]))
unset ( $return [ $_SESSION [ $this -> base ] -> dn ][ 'modify' ][ 'userPassword' ]);
2003-12-27 11:21:00 +00:00
// Return attributes
2003-12-15 15:11:44 +00:00
return $return ;
2003-12-12 00:52:35 +00:00
}
2003-12-30 15:36:30 +00:00
/* Write variables into object and do some regexp checks
2003-12-12 00:52:35 +00:00
*/
2003-12-30 15:36:30 +00:00
function delete_attributes ( $post ) {
2004-01-10 11:47:48 +00:00
return 0 ;
2003-12-30 15:36:30 +00:00
}
2004-01-18 12:52:52 +00:00
function proccess_attributes ( $post , $profile = false ) {
2003-12-30 15:36:30 +00:00
// Load attributes
$this -> attributes [ 'description' ][ 0 ] = $post [ 'description' ];
$this -> attributes [ 'sn' ][ 0 ] = $post [ 'sn' ];
$this -> attributes [ 'givenName' ][ 0 ] = $post [ 'givenName' ];
$this -> attributes [ 'title' ][ 0 ] = $post [ 'title' ];
$this -> attributes [ 'mail' ][ 0 ] = $post [ 'mail' ];
$this -> attributes [ 'telephoneNumber' ][ 0 ] = $post [ 'telephoneNumber' ];
$this -> attributes [ 'mobileTelephoneNumber' ][ 0 ] = $post [ 'mobileTelephoneNumber' ];
$this -> attributes [ 'facsimileTelephoneNumber' ][ 0 ] = $post [ 'facsimileTelephoneNumber' ];
$this -> attributes [ 'street' ][ 0 ] = $post [ 'street' ];
$this -> attributes [ 'postalCode' ][ 0 ] = $post [ 'postalCode' ];
$this -> attributes [ 'postalAddress' ][ 0 ] = $post [ 'postalAddress' ];
$this -> attributes [ 'employeeType' ][ 0 ] = $post [ 'employeeType' ];
// handle host-attribute in on epice because it's not set by default
if ( isset ( $this -> attributes [ 'host' ])) {
$host = $post [ 'host' ];
2004-07-02 12:09:06 +00:00
if (( ! $host == '' ) && ! eregi ( $this -> regex_host , $host ))
2004-06-24 09:51:12 +00:00
$errors [ 'host' ][] = $this -> messages [ 'host' ];
2003-12-30 15:36:30 +00:00
$hosts = explode ( " " , $host );
$this -> attributes [ 'host' ] = array ();
foreach ( $hosts as $host )
if ( $host != " " ) $this -> attributes [ 'host' ][] = $host ;
}
// Do some regex-checks and return error if attributes are set to wrong values
2004-01-18 12:52:52 +00:00
if ( ! $profile ) {
2004-07-02 12:09:06 +00:00
if ( ! eregi ( $this -> regex_name , $this -> attributes [ 'givenName' ][ 0 ])) $errors [ 'givenName' ][] = $this -> messages [ 'givenName' ];
if ( ! eregi ( $this -> regex_name , $this -> attributes [ 'sn' ][ 0 ])) $errors [ 'sn' ][] = $this -> messages [ 'surname' ];
2004-07-02 16:01:17 +00:00
if ( ! ereg ( $this -> regex_telephoneNumber , $this -> attributes [ 'telephoneNumber' ][ 0 ])) $errors [ 'telephoneNumber' ][] = $this -> messages [ 'telephoneNumber' ];
if ( ! ereg ( $this -> regex_telephoneNumber , $this -> attributes [ 'mobileTelephoneNumber' ][ 0 ])) $errors [ 'mobileTelephoneNumber' ][] = $this -> messages [ 'mobileTelephone' ];
if ( ! ereg ( $this -> regex_telephoneNumber , $this -> attributes [ 'facsimileTelephoneNumber' ][ 0 ])) $errors [ 'facsimileTelephoneNumber' ][] = $this -> messages [ 'facsimileNumber' ];
if ( ! eregi ( $this -> regex_email , $this -> attributes [ 'mail' ][ 0 ])) $errors [ 'mail' ][] = $this -> messages [ 'email' ];
if ( ! eregi ( $this -> regex_street , $this -> attributes [ 'street' ][ 0 ])) $errors [ 'street' ][] = $this -> messages [ 'street' ];
if ( ! eregi ( $this -> regex_postalAddress , $this -> attributes [ 'postalAddress' ][ 0 ])) $errors [ 'postalAdress' ][] = $this -> messages [ 'postalAddress' ];
if ( ! eregi ( $this -> regex_postalCode , $this -> attributes [ 'personal_postalCode' ][ 0 ])) $errors [ 'personal_postalCode' ][] = $this -> messages [ 'postalCode' ];
2004-01-18 12:52:52 +00:00
}
2004-07-02 16:01:17 +00:00
if ( ! eregi ( $this -> regex_title , $this -> attributes [ 'title' ][ 0 ])) $errors [ 'title' ][] = $this -> messages [ 'title' ];
if ( ! eregi ( $this -> regex_employeeType , $this -> attributes [ 'employeeType' ][ 0 ])) $errors [ 'employeeType' ][] = $this -> messages [ 'employeeType' ];
2003-12-30 15:36:30 +00:00
// Return error-messages
if ( is_array ( $errors )) return $errors ;
return 0 ;
2003-12-12 00:52:35 +00:00
}
/* This function will create the html - page
* to show a page with all attributes .
* It will output a complete html - table
*/
2004-01-18 12:52:52 +00:00
function display_html_attributes ( $post , $profile = false ) {
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Description' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'description' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'description' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'description' ));
2003-12-20 19:24:01 +00:00
if ( isset ( $this -> attributes [ 'host' ])) {
if ( is_array ( $this -> attributes [ 'host' ]))
2004-01-18 12:52:52 +00:00
foreach ( $this -> attributes [ 'host' ] as $host ) $hostvalue .= $host . " " ;
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Unix workstations' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'host' , 'type' => 'text' , 'size' => '20' ,
'maxlength' => '255' , 'value' => $hostvalues ),
2 => array ( 'kind' => 'help' , 'value' => 'host' ));
2003-12-20 19:24:01 +00:00
}
2004-07-01 15:54:33 +00:00
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Job title' ) ),
2004-01-18 12:52:52 +00:00
1 => array ( 'kind' => 'input' , 'name' => 'title' , 'type' => 'text' , 'size' => '10' ,
2004-07-01 15:54:33 +00:00
'value' => $this -> attributes [ 'title' ][ 0 ] ),
2004-01-18 12:52:52 +00:00
2 => array ( 'kind' => 'help' , 'value' => 'title' ));
if ( ! $profile ) {
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'First name' ) . '*' ),
1 => array ( 'kind' => 'input' , 'name' => 'givenName' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'givenName' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'givenName' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Last name' ) . '*' ),
1 => array ( 'kind' => 'input' , 'name' => 'sn' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'sn' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'sn' ));
}
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Employee type' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'employeeType' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'employeeType' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'employeeType' ));
if ( ! $profile ) {
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Street' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'street' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'street' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'street' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Postal code' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'postalCode' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'postalCode' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'postalCode' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Postal address' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'postalAddress' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'postalAddress' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'postalAddress' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Telephone number' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'telephoneNumber' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'telephoneNumber' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'telephoneNumber' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Mobile number' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'mobileTelephoneNumber' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'mobileTelephoneNumber' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'mobileTelephoneNumber' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'Fax number' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'facsimileTelephoneNumber' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'facsimileTelephoneNumber' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'facsimileTelephoneNumber' ));
$return [] = array ( 0 => array ( 'kind' => 'text' , 'text' => _ ( 'eMail address' ) ),
1 => array ( 'kind' => 'input' , 'name' => 'mail' , 'type' => 'text' , 'size' => '30' ,
'maxlength' => '255' , 'value' => $this -> attributes [ 'mail' ][ 0 ] ),
2 => array ( 'kind' => 'help' , 'value' => 'mail' ));
}
return $return ;
2003-12-12 00:52:35 +00:00
}
2004-01-18 12:52:52 +00:00
function display_html_delete ( $post , $profile = false ) {
2003-12-30 15:36:30 +00:00
return 0 ;
}
2004-03-09 12:03:39 +00:00
2004-08-17 15:16:17 +00:00
/*
* ( non - PHPDoc )
* @ see baseModule #get_pdfEntries
*/
2004-05-29 19:20:28 +00:00
function get_pdfEntries ( $account_type = " user " ) {
return array ( 'inetOrgPerson_description' => array ( '<block><key>' . _ ( 'Description' ) . '</key><value>' . $this -> attributes [ 'description' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_host' => array ( '<block><key>' . _ ( 'Unix workstations' ) . '</key><value>' . $this -> attributes [ 'host' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_title' => array ( '<block><key>' . _ ( 'Title' ) . '</key><value>' . $this -> attributes [ 'title' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_givenName' => array ( '<block><key>' . _ ( 'First name' ) . '</key><value>' . $this -> attributes [ 'givenName' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_sn' => array ( '<block><key>' . _ ( 'Last name' ) . '</key><value>' . $this -> attributes [ 'sn' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_employeeType' => array ( '<block><key>' . _ ( 'Employee type' ) . '</key><value>' . $this -> attributes [ 'employeeType' ][ 0 ]),
'inetOrgPerson_street' => array ( '<block><key>' . _ ( 'Street' ) . '</key><value>' . $this -> attributes [ 'street' ] . '</value></block>' ),
'inetOrgPerson_postalCode' => array ( '<block><key>' . _ ( 'Postal code' ) . '</key><value>' . $this -> attributes [ 'postalCode' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_postalAddress' => array ( '<block><key>' . _ ( 'Postal address' ) . '</key><value>' . $this -> attributes [ 'postalAddress' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_telephoneNumber' => array ( '<block><key>' . _ ( 'Telephone number' ) . '</key><value>' . $this -> attributes [ 'telephoneNumber' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_mobileTelephoneNumber' => array ( '<block><key>' . _ ( 'Mobile number' ) . '</key><value>' . $this -> attributes [ 'mobileTelephoneNumber' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_facimileTelefonNumber' => array ( '<block><key>' . _ ( 'Fax number' ) . '</key><value>' . $this -> attributes [ 'facsimileTelephoneNumber' ][ 0 ] . '</value></block>' ),
'inetOrgPerson_mail' => array ( '<block><key>' . _ ( 'eMail address' ) . '</key><value>' . $this -> attributes [ 'mail' ][ 0 ] . '</value></block>' ));
2004-05-24 21:39:57 +00:00
}
2004-03-14 17:33:05 +00:00
2004-03-09 12:03:39 +00:00
}
2003-12-12 00:52:35 +00:00
?>