mirror of
https://gitlab.easter-eggs.com/ee/ldapsaisie.git
synced 2024-12-23 08:53:47 +01:00
1e2316d76f
- Ajout du principe de relations entre type d'objets (LSrelation) Exemple : Utilisateur appartenant à un groupe - Ajout du LSformElement_select_object : Sélection d'un objet à travers une interface plus conviviale qu'une liste déroulante.
477 lines
13 KiB
PHP
477 lines
13 KiB
PHP
<?php
|
||
/*******************************************************************************
|
||
* Copyright (C) 2007 Easter-eggs
|
||
* http://ldapsaisie.labs.libre-entreprise.org
|
||
*
|
||
* Author: See AUTHORS file in top-level directory.
|
||
*
|
||
* This program is free software; you can redistribute it and/or
|
||
* modify it under the terms of the GNU General Public License version 2
|
||
* as published by the Free Software Foundation.
|
||
*
|
||
* 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.
|
||
|
||
******************************************************************************/
|
||
|
||
$GLOBALS['LSobjects']['LSeepeople'] = array (
|
||
'objectclass' => array(
|
||
'top',
|
||
'lspeople',
|
||
'posixAccount',
|
||
'sambaSamAccount',
|
||
),
|
||
'rdn' => 'uid',
|
||
'container_dn' => 'ou=people',
|
||
'before_save' => 'valid',
|
||
'after_save' => 'valid',
|
||
'select_display_attrs' => '%{cn}',
|
||
'label' => _('Utilisateurs'),
|
||
'relations' => array(
|
||
'groups' => array(
|
||
'label' => _('Appartient aux groupes...'),
|
||
'LSobject' => 'LSeegroup',
|
||
'list_function' => 'listUserGroups',
|
||
'update_function' => 'updateUserGroups',
|
||
'remove_function' => 'removeMember',
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'admin' => 'w'
|
||
)
|
||
)
|
||
),
|
||
// 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 (
|
||
'filter' => 'uid=%{val}',
|
||
'result' => 0,
|
||
'msg' => _('Cet identifiant est d<>j<EFBFBD> utilis<69>.')
|
||
)
|
||
),
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 0,
|
||
'create' => 1
|
||
)
|
||
),
|
||
'uidNumber' => array (
|
||
'label' => _('Identifiant (num<75>rique)'),
|
||
'ldap_type' => 'numeric',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'generate_function' => 'generate_uidNumber',
|
||
'check_data' => array (
|
||
'numeric' => array(
|
||
'msg' => _("L'identifiant unique doit <20>tre un entier.")
|
||
),
|
||
),
|
||
'validation' => array (
|
||
array (
|
||
'filter' => 'uidNumber=%{val}',
|
||
'result' => 0,
|
||
'msg' => _('Cet uid est d<>j<EFBFBD> utilis<69>.')
|
||
)
|
||
),
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 0,
|
||
)
|
||
),
|
||
'cn' => array (
|
||
'label' => _('Nom complet'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'default_value' => 'titi',
|
||
'validation' => 'valid',
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 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(
|
||
'self' => 'w',
|
||
'users' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
),
|
||
'onDisplay' => 'return_data'
|
||
),
|
||
'sn' => array (
|
||
'label' => _('Nom'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
)
|
||
),
|
||
'gidNumber' => array (
|
||
'label' => _('Groupe principal'),
|
||
'ldap_type' => 'numeric',
|
||
'html_type' => 'select_list',
|
||
'multiple' => false,
|
||
'required' => 1,
|
||
'validation' => array (
|
||
array (
|
||
'object_type' => 'LSeegroup', // 'object_type' : Permet definir le type d'objet recherch<63>s
|
||
//'basedn' => 'o=company', // et d'utiliser les objectClass d<>finis dans le fichier de configuration
|
||
'filter' => '(gidNumber=%{val})', // pour la recherche
|
||
'result' => 1
|
||
)
|
||
),
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
),
|
||
'possible_values' => array(
|
||
'OTHER_OBJECT' => array(
|
||
'object_type' => 'LSeegroup', // Nom de l'objet <20> lister
|
||
'display_attribute' => '%{cn} (%{gidNumber})', // Sp<53>cifie le attributs <20> lister pour le choix,
|
||
// si non d<>finie => utilisation du 'select_display_attrs'
|
||
// de la d<>finition de l'objet
|
||
|
||
'value_attribute' => 'gidNumber', // Sp<53>cifie le attributs dont la valeur sera retourn<72>e par
|
||
/*'filter' => // le formulaire sp<73>cifie les filtres de recherche pour
|
||
array ( // l'<27>tablissement de la liste d'objets :
|
||
array( // Premier filtre
|
||
'filter' => 'cn=*a*',
|
||
//'basedn' => 'o=company',
|
||
'scope' => 'sub',
|
||
)
|
||
)*/
|
||
)
|
||
)
|
||
),
|
||
'loginShell' => array (
|
||
'label' => _('Interpreteur de commande'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'select_list',
|
||
'required' => 1,
|
||
'default_value' => '/bin/false',
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 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(
|
||
'admin' => 'r'
|
||
),
|
||
'form' => array (
|
||
//'modify' => 0,
|
||
)
|
||
),
|
||
'homeDirectory' => array (
|
||
'label' => _('R<>pertoire personnel'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'default_value' => '/home/%{uid}',
|
||
'generate_function' => 'generate_homeDirectory',
|
||
'rights' => array(
|
||
'self' => 'r'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 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<74>e n'est pas valide.")
|
||
),
|
||
),
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
)
|
||
),
|
||
'personalTitle' => array (
|
||
'label' => _('Titre'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'select_list',
|
||
'required' => 1,
|
||
'default_value' => 'M.',
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
),
|
||
'possible_values' => array(
|
||
'M.' => 'M.',
|
||
'Mme' => 'Mme',
|
||
'Mlle' => 'Mlle'
|
||
)
|
||
),
|
||
'maildrop' => array (
|
||
'label' => _('Mail ind<6E>sirable'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'multiple' => true,
|
||
'check_data' => array (
|
||
'email' => array(
|
||
'msg' => _("L'adresse e-mail entr<74>e n'est pas valide.")
|
||
),
|
||
),
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
)
|
||
),
|
||
'vacationActive' => array (
|
||
'label' => _('R<>ponse automatique'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'select_list',
|
||
'default_value' => '',
|
||
'check_data' => array (
|
||
'email' => array(
|
||
'msg' => _("L'adresse e-mail entr<74>e n'est pas valide.")
|
||
),
|
||
),
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'admin' => 'w',
|
||
'user' => 'r'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
),
|
||
'possible_values' => array(
|
||
'' => 'Non',
|
||
'%{uid}@autoreponse.example.fr' => 'Oui'
|
||
)
|
||
),
|
||
'vacationInfo' => array (
|
||
'label' => _('Message en reponse'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'textarea',
|
||
'multiple' => true,
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
)
|
||
),
|
||
'vacationForward' => array (
|
||
'label' => _('Transfert de mail'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'check_data' => array (
|
||
'email' => array(
|
||
'msg' => _("L'adresse e-mail entr<74>e n'est pas valide.")
|
||
),
|
||
),
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 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<74>e n'est pas valide.")
|
||
),
|
||
),
|
||
'rights' => array(
|
||
'self' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
)
|
||
),
|
||
'description' => array (
|
||
'label' => _('Description'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
),
|
||
'view' => 1,
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
)
|
||
),
|
||
'userPassword' => array (
|
||
'label' => _('Mot de passe'),
|
||
'ldap_type' => 'password',
|
||
'html_type' => 'password',
|
||
'required' => 1,
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'admin' => 'w'
|
||
),
|
||
'dependAttrs' => array(
|
||
'sambaLMPassword',
|
||
'sambaNTPassword'
|
||
),
|
||
'form' => array (
|
||
'modify' => 1,
|
||
'create' => 1
|
||
)
|
||
),
|
||
'sambaLMPassword' => array (
|
||
'label' => _('Mot de passe Samba (LM)'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'generate_function' => 'generate_sambaLMPassword',
|
||
'form' => array (
|
||
'modify' => 0
|
||
)
|
||
),
|
||
'sambaNTPassword' => array (
|
||
'label' => _('Mot de passe Samba (NT)'),
|
||
'ldap_type' => 'ascii',
|
||
'html_type' => 'text',
|
||
'required' => 1,
|
||
'generate_function' => 'generate_sambaNTPassword',
|
||
'form' => array (
|
||
'modify' => 0
|
||
)
|
||
),
|
||
'jpegPhoto' => array (
|
||
'label' => _('Photo'),
|
||
'ldap_type' => 'image',
|
||
'html_type' => 'image',
|
||
'required' => 0,
|
||
'view' => 0,
|
||
'check_data' => array (
|
||
'imagesize' => array(
|
||
'msg' => _("La taille de l'image n'est pas valide."),
|
||
'param' => array(
|
||
'maxWidth' => 2000
|
||
)
|
||
),
|
||
'imagefilesize' => array(
|
||
'msg' => _("La taille du fichier image n'est pas valide."),
|
||
'param' => array(
|
||
'maxSize' => 3000000 // taille du fichier en octets
|
||
)
|
||
),
|
||
'imagefile' => array(
|
||
'msg' => _("Le type du fichier n'est pas valide.")
|
||
)
|
||
),
|
||
'form' => array (
|
||
'modify' => 1
|
||
),
|
||
'rights' => array(
|
||
'self' => 'w',
|
||
'user' => 'r',
|
||
'admin' => 'w'
|
||
)
|
||
)
|
||
)
|
||
);
|
||
?>
|