array( 'top', 'ostpeople', 'posixAccount', 'sambaSamAccount', ), 'rdn' => 'uid', 'container_dn' => 'ou=people', 'before_save' => 'valid', 'after_save' => 'valid', 'select_display_attrs' => '%{cn]', // Attributes 'attrs' => array ( 'uid' => array ( 'label' => _('Identifiant'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'check_data' => array ( 'alphanumeric' => array( 'msg' => _("L'identifiant ne doit comporter que des lettres et des chiffres.") ), ), 'validation' => array ( array ( 'basedn' => 'o=ost', 'filter' => 'uid=%{val}', 'result' => 0, 'msg' => _('Cet identifiant est déjà utilisé.') ) ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 0, 'add' => 1 ) ), 'uidNumber' => array ( 'label' => _('Identifiant (numérique)'), 'ldap_type' => 'numeric', 'html_type' => 'text', 'required' => 1, 'generate_function' => 'generate_uidNumber', 'check_data' => array ( 'numeric' => array( 'msg' => _("L'identifiant unique doit être un entier.") ), ), 'validation' => array ( array ( 'basedn' => 'o=ost', 'filter' => 'uidNumber=%{val}', 'result' => 0, 'msg' => _('Cet uid est déjà utilisé.') ) ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 0, ) ), 'cn' => array ( 'label' => _('Nom complet'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'default_value' => 'titi', 'validation' => 'valid', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ) ), 'givenName' => array ( 'label' => _('Prenom'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'default_value' => 'toto', 'check_data' => array ( 'alphanumeric' => array( 'msg' => _('Le prenom ne doit comporter que des lettres et des chiffres.') ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ), 'onDisplay' => 'return_data' ), 'sn' => array ( 'label' => _('Nom'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ) ), 'gidNumber' => array ( 'label' => _('Groupe principal'), 'ldap_type' => 'numeric', 'html_type' => 'select_list', 'required' => 1, 'validation' => array ( array ( 'object_type' => 'LSeegroup', // 'object_type' : Permet definir le type d'objet recherchés 'basedn' => 'o=ost', // et d'utiliser les objectClass définis dans le fichier de configuration 'filter' => '(gidNumber=%{val})', // pour la recherche 'result' => 1 ) ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ), 'possible_values' => array( '' => '-- Selectionner --', 'OTHER_OBJECT' => array( 'object_type' => 'LSeegroup', // Nom de l'objet à lister 'display_attribute' => '%{cn} (%{gidNumber})', // Spécifie le attributs à lister pour le choix, // si non définie => utilisation du 'select_display_attrs' // de la définition de l'objet 'value_attribute' => 'gidNumber', // Spécifie le attributs dont la valeur sera retournée par 'filter' => // le formulaire spécifie les filtres de recherche pour array ( // l'établissement de la liste d'objets : array( // Premier filtre 'filter' => 'cn=*a*', 'basedn' => 'o=ost', 'scope' => 'sub', ) ) ) ) ), 'loginShell' => array ( 'label' => _('Interpreteur de commande'), 'ldap_type' => 'ascii', 'html_type' => 'select_list', 'required' => 1, 'default_value' => '/bin/false', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ), 'possible_values' => array( '/bin/false' => _('Aucun'), '/bin/bash' => 'Bash', ) ), 'sambaSID' => array ( 'label' => _('Identifiant Samba'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'generate_function' => 'generate_sambaSID', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'r', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'homeDirectory' => array ( 'label' => _('Répertoire personnel'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'default_value' => '/home/%{uid}', 'generate_function' => 'generate_homeDirectory', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'r', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'mail' => array ( 'label' => _('Adresse e-mail'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'required' => 1, 'check_data' => array ( 'email' => array( 'msg' => _("L'adresse e-mail entrée n'est pas valide.") ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'r', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ) ), 'personalTitle' => array ( 'label' => _('Titre'), 'ldap_type' => 'ascii', 'html_type' => 'select_list', 'required' => 1, 'default_value' => 'M.', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, 'add' => 1 ), 'possible_values' => array( 'M.' => 'M.', 'Mme' => 'Mme', 'Mlle' => 'Mlle' ) ), 'maildrop' => array ( 'label' => _('Mail indésirable'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'check_data' => array ( 'email' => array( 'msg' => _("L'adresse e-mail entrée n'est pas valide.") ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'vacationActive' => array ( 'label' => _('Réponce automatique'), 'ldap_type' => 'ascii', 'html_type' => 'select_list', 'default_value' => '', 'check_data' => array ( 'email' => array( 'msg' => _("L'adresse e-mail entrée n'est pas valide.") ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ), 'possible_values' => array( '%{uid}@autoreponse.obs-ost.fr' => 'Oui', '' => 'Non' ) ), 'vacationInfo' => array ( 'label' => _('Message en reponse'), 'ldap_type' => 'ascii', 'html_type' => 'textarea', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'vacationForward' => array ( 'label' => _('Transfert de mail'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'check_data' => array ( 'email' => array( 'msg' => _("L'adresse e-mail entrée n'est pas valide.") ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'mailQuota' => array ( 'label' => _('Quota boite mail'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'check_data' => array ( 'numeric' => array( 'msg' => _("Le quota de l'adresse mail entrée n'est pas valide.") ), ), 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'r', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'description' => array ( 'label' => _('Description'), 'ldap_type' => 'ascii', 'html_type' => 'text', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'form' => array ( 'test' => 1, ) ), 'userPassword' => array ( 'label' => _('Mot de passe'), 'ldap_type' => 'password', 'html_type' => 'password', 'required' => 1, 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => 'r' // définition des droits de tout les utilisateurs ), 'dependAttrs' => array( 'sambaLMPassword', 'sambaNTPassword' ), 'form' => array ( 'test' => 1, 'add' => 1 ) ), 'sambaLMPassword' => array ( 'label' => _('Mot de passe Samba (LM)'), 'ldap_type' => 'ascii', 'html_type' => 'password', 'required' => 1, 'generate_function' => 'generate_sambaLMPassword', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => '' // définition des droits de tout les utilisateurs ) ), 'sambaNTPassword' => array ( 'label' => _('Mot de passe Samba (NT)'), 'ldap_type' => 'ascii', 'html_type' => 'password', 'required' => 1, 'generate_function' => 'generate_sambaNTPassword', 'rights' => array( // Définition de droits : 'r' => lecture / 'w' => modification / '' => aucun (par defaut) 'self' => 'w', // définition des droits de l'utilisateur sur lui même 'users' => '' // définition des droits de tout les utilisateurs ) ) ) ); ?>