- LSldapObject : Ajout de la possibilite de trigger avant et après la

modification d'un attribut en particulier
- config.error_code.php : Revue de l'encodage / allègement du fichier
This commit is contained in:
Benjamin Renard 2008-10-14 11:58:00 +00:00
parent c5e7165e13
commit 74afda65d5
3 changed files with 227 additions and 256 deletions

View file

@ -353,7 +353,8 @@ $GLOBALS['LSobjects']['LSeepeople'] = array (
'modify' => 1, 'modify' => 1,
'create' => 1, 'create' => 1,
'lostPassword' => 1 'lostPassword' => 1
) ),
'after_modify' => 'valid'
), ),
'lsRecoveryHash' => array ( 'lsRecoveryHash' => array (
'label' => _('Hash de recouvrement du mot de passe'), 'label' => _('Hash de recouvrement du mot de passe'),

View file

@ -22,314 +22,252 @@
$GLOBALS['LSerror_code'] = array ( $GLOBALS['LSerror_code'] = array (
'-1' => array ( '-1' => array (
'msg' => _("Erreur inconnue!"), 'msg' => _("Erreur inconnue!")
'level' => 'c'
), ),
0 => array( 0 => array(
'msg' => "%{msg}", 'msg' => "%{msg}"
'level' => 'c'
), ),
// LSldap // LSldap
1 => array ( 1 => array (
'msg' => _("LSldap : Erreur durant la connexion au serveur LDAP (%{msg})."), 'msg' => _("LSldap : Erreur durant la connexion au serveur LDAP (%{msg}).")
'level' => 'c'
), ),
2 => array ( 2 => array (
'msg' => _("LSldap : Erreur durant la recherche LDAP (%{msg})."), 'msg' => _("LSldap : Erreur durant la recherche LDAP (%{msg}).")
'level' => 'c'
), ),
3 => array ( 3 => array (
'msg' => _("LSldap : Type d'objet inconnu."), 'msg' => _("LSldap : Type d'objet inconnu.")
'level' => 'c'
), ),
4 => array ( 4 => array (
'msg' => _("LSldap : Erreur durant la récupération de l'entrée Ldap."), 'msg' => _("LSldap : Erreur durant la récupération de l'entrée Ldap.")
'level' => 'c'
), ),
5 => array ( 5 => array (
'msg' => _("LSldap : Erreur durant la mise à jour de l'entrée Ldap (DN : %{dn})."), 'msg' => _("LSldap : Erreur durant la mise à jour de l'entrée Ldap (DN : %{dn}).")
'level' => 'c'
), ),
6 => array ( 6 => array (
'msg' => _("LSldap : Erreur durant la suppression des attributs vides."), 'msg' => _("LSldap : Erreur durant la suppression des attributs vides.")
'level' => 'w'
), ),
7 => array ( 7 => array (
'msg' => _("LSldap : Erreur durant le changement du DN de l'objet."), 'msg' => _("LSldap : Erreur durant le changement du DN de l'objet.")
'level' => 'w'
), ),
// LSldapObject // LSldapObject
21 => array ( 21 => array (
'msg' => _("LSldapObject : Type d'objet inconnu."), 'msg' => _("LSldapObject : Type d'objet inconnu.")
'level' => 'c'
), ),
22 => array ( 22 => array (
'msg' => _("LSldapObject : Formulaire de mise jour inconnu par l'objet %{msg}."), 'msg' => _("LSldapObject : Formulaire de mise jour inconnu par l'objet %{msg}.")
'level' => 'c'
), ),
23 => array ( 23 => array (
'msg' => _("LSldapObject : Aucun formulaire n'existe dans l'objet %{msg}."), 'msg' => _("LSldapObject : Aucun formulaire n'existe dans l'objet %{msg}.")
'level' => 'c'
), ),
24 => array ( 24 => array (
'msg' => _("LSldapObject : La fonction %{func} pour valider l'attribut %{attr} de l'objet %{obj} est inconnue."), 'msg' => _("LSldapObject : La fonction %{func} pour valider l'attribut %{attr} de l'objet %{obj} est inconnue.")
'level' => 'c'
), ),
25 => array ( 25 => array (
'msg' => _("LSldapObject : Des données de configuration sont manquant pour la validation de l'attribut %{attr} de l'objet %{obj}."), 'msg' => _("LSldapObject : Des données de configuration sont manquant pour la validation de l'attribut %{attr} de l'objet %{obj}.")
'level' => 'c'
), ),
26 => array ( 26 => array (
'msg' => _("LSldapObject : Erreur de configuration : L'objet %{obj} ne possède pas d'attribut %{attr}."), 'msg' => _("LSldapObject : Erreur de configuration : L'objet %{obj} ne possède pas d'attribut %{attr}.")
'level' => 'c'
), ),
27 => array ( 27 => array (
'msg' => _("LSldapObject : La fonction %{func} devant être executée avant la modification n'existe pas."), 'msg' => _("LSldapObject : La fonction %{func} devant être executée avant la modification n'existe pas.")
'level' => 'c'
), ),
28 => array ( 28 => array (
'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée avant la modification a échouée."), 'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée avant la modification a échouée.")
'level' => 'c'
), ),
29 => array ( 29 => array (
'msg' => _("LSldapObject : La fonction %{func} devant être executée après la modification n'existe pas."), 'msg' => _("LSldapObject : La fonction %{func} devant être executée après la modification n'existe pas.")
'level' => 'c'
), ),
30 => array ( 30 => array (
'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée après la modification a échouée."), 'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée après la modification a échouée.")
'level' => 'c'
), ),
31 => array ( 31 => array (
'msg' => _("LSldapObject : Il manque des informations de configuration du type d'objet %{obj} pour la création du nouveau DN."), 'msg' => _("LSldapObject : Il manque des informations de configuration du type d'objet %{obj} pour la création du nouveau DN.")
'level' => 'c'
), ),
32 => array ( 32 => array (
'msg' => _("LSldapObject : L'attribut %{attr} de l'objet n'est pas encore définis. Il est impossible de generer un nouveau DN."), 'msg' => _("LSldapObject : L'attribut %{attr} de l'objet n'est pas encore définis. Il est impossible de generer un nouveau DN.")
'level' => 'c'
), ),
33 => array ( 33 => array (
'msg' => _("LSldapObject : Sans DN, l'objet n'a put être modifié."), 'msg' => _("LSldapObject : Sans DN, l'objet n'a put être modifié.")
'level' => 'c'
), ),
34 => array ( 34 => array (
'msg' => _("LSldapObject : L'attribut %{attr_depend} dépendant de l'attribut %{attr} n'existe pas."), 'msg' => _("LSldapObject : L'attribut %{attr_depend} dépendant de l'attribut %{attr} n'existe pas.")
'level' => 'w'
), ),
35 => array ( 35 => array (
'msg' => _("LSldapObject : Erreur durant la suppression de %{objectname}."), 'msg' => _("LSldapObject : Erreur durant la suppression de %{objectname}.")
'level' => 'c'
), ),
36 => array ( 36 => array (
'msg' => _("LSldapObject : Erreur durant les actions avant renomage."), 'msg' => _("LSldapObject : Erreur durant les actions avant renomage.")
'level' => 'c'
), ),
37 => array ( 37 => array (
'msg' => _("LSldapObject : Erreur durant les actions après renomage."), 'msg' => _("LSldapObject : Erreur durant les actions aprês renomage.")
'level' => 'c'
), ),
38 => array ( 38 => array (
'msg' => _("LSldapObject : Erreur durant les actions avant suppression."), 'msg' => _("LSldapObject : Erreur durant les actions avant suppression.")
'level' => 'c'
), ),
39 => array ( 39 => array (
'msg' => _("LSldapObject : Erreur durant les actions après suppresion."), 'msg' => _("LSldapObject : Erreur durant les actions aprês suppresion.")
'level' => 'c'
), ),
301 => array ( 301 => array (
'msg' => _("LSldapObject : Erreur durant les actions après la création. L'objet est pour autant créé."), 'msg' => _("LSldapObject : Erreur durant les actions aprês la création. L'objet est pour autant créé.")
'level' => 'c'
), ),
302 => array ( 302 => array (
'msg' => _("LSldapObject : La fonction %{fonction} devant être éxecutée après la création de l'objet n'existe pas."), 'msg' => _("LSldapObject : La fonction %{fonction} devant être éxecutée aprês la création de l'objet n'existe pas.")
'level' => 'c'
), ),
303 => array ( 303 => array (
'msg' => _("LSldapObject : Erreur durant l'exection de la fonction %{fonction} devant être éxecutée après la création de l'objet."), 'msg' => _("LSldapObject : Erreur durant l'exection de la fonction %{fonction} devant être éxecutée aprês la création de l'objet.")
'level' => 'c'
), ),
304 => array ( 304 => array (
'msg' => _("LSldapObject : La fonction %{fonction} devant être éxecutée après la suppression de l'objet n'existe pas."), 'msg' => _("LSldapObject : La fonction %{fonction} devant être éxecutée aprês la suppression de l'objet n'existe pas.")
'level' => 'c'
), ),
305 => array ( 305 => array (
'msg' => _("LSldapObject : Erreur durant l'exection de la fonction %{fonction} devant être éxecutée après la suppression de l'objet."), 'msg' => _("LSldapObject : Erreur durant l'exection de la fonction %{fonction} devant être éxecutée aprês la suppression de l'objet.")
'level' => 'c' ),
306 => array (
'msg' => _("LSldapObject : La fonction %{func} devant être executée après la modification de l'attribut %{attr} n'existe pas.")
),
307 => array (
'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée après la modification de l'attribut %{attr} a échouée.")
),
308 => array (
'msg' => _("LSldapObject : La fonction %{func} devant être executée avant la modification de l'attribut %{attr} n'existe pas.")
),
309 => array (
'msg' => _("LSldapObject : L'execution de la fonction %{func} devant être executée avant la modification de l'attribut %{attr} a échouée.")
), ),
// LSattribute // LSattribute
41 => array ( 41 => array (
'msg' => _("LSattribute : Attribut %{attr} : Type d'attribut (ldap // html) inconnu (ldap = %{ldap} | html = %{html})."), 'msg' => _("LSattribute : Attribut %{attr} : Type d'attribut (ldap // html) inconnu (ldap = %{ldap} | html = %{html}).")
'level' => 'c'
), ),
42 => array ( 42 => array (
'msg' => _("LSattribute : La fonction %{func} pour afficher l'attribut %{attr} est inconnue."), 'msg' => _("LSattribute : La fonction %{func} pour afficher l'attribut %{attr} est inconnue.")
'level' => 'c'
), ),
43 => array ( 43 => array (
'msg' => _("LSattribute : La règle %{rule} pour valider l'attribut %{attr} est inconnue."), 'msg' => _("LSattribute : La règle %{rule} pour valider l'attribut %{attr} est inconnue.")
'level' => 'c'
), ),
44 => array ( 44 => array (
'msg' => _("LSattribute : Les données de configuration pour vérifié l'attribut %{attr} sont incorrects."), 'msg' => _("LSattribute : Les données de configuration pour vérifié l'attribut %{attr} sont incorrects.")
'level' => 'c'
), ),
45 => array ( 45 => array (
'msg' => _("LSattribute : La fonction %{func} pour sauver l'attribut %{attr} est inconnue."), 'msg' => _("LSattribute : La fonction %{func} pour sauver l'attribut %{attr} est inconnue.")
'level' => 'c'
), ),
46 => array ( 46 => array (
'msg' => _("LSattribute : La valeur de l'attribut %{attr} ne peut pas être générée."), 'msg' => _("LSattribute : La valeur de l'attribut %{attr} ne peut pas être générée.")
'level' => 'c'
), ),
47 => array ( 47 => array (
'msg' => _("LSattribute : La valeur de l'attribut %{attr} n'a pas put être générée."), 'msg' => _("LSattribute : La valeur de l'attribut %{attr} n'a pas put être générée.")
'level' => 'c'
), ),
48 => array ( 48 => array (
'msg' => _("LSattribute : La génération de l'attribut %{attr} n'a pas retourné une valeur correcte."), 'msg' => _("LSattribute : La génération de l'attribut %{attr} n'a pas retourné une valeur correcte.")
'level' => 'c'
), ),
// LSattr_html // LSattr_html
101 => array ( 101 => array (
'msg' => _("LSattr_html : La fonction addToForm() du type html de l'attribut %{attr} n'est pas définie."), 'msg' => _("LSattr_html : La fonction addToForm() du type html de l'attribut %{attr} n'est pas définie.")
'level' => 'c'
), ),
102 => array ( 102 => array (
'msg' => _("LSattr_html_select_list : Des données de configuration sont manquante pour la génération de la liste deroulante de l'attribut %{attr}."), 'msg' => _("LSattr_html_select_list : Des données de configuration sont manquante pour la génération de la liste deroulante de l'attribut %{attr}.")
'level' => 'c'
), ),
103 => array ( 103 => array (
'msg' => _("LSattr_html_%{type} : Les données multiples ne sont pas gérés pour ce type d'attribut."), 'msg' => _("LSattr_html_%{type} : Les données multiples ne sont pas gérés pour ce type d'attribut.")
'level' => 'c'
), ),
// LSform // LSform
201 => array( 201 => array(
'msg' => _("LSform : Erreur durant la recupération des valeurs du formulaire."), 'msg' => _("LSform : Erreur durant la recupération des valeurs du formulaire.")
'level' => 'c'
), ),
202 => array( 202 => array(
'msg' => _("LSform : Erreur durant la récupération de la valeur du formulaire du champ '%{element}'."), 'msg' => _("LSform : Erreur durant la récupération de la valeur du formulaire du champ '%{element}'.")
'level' => 'c'
), ),
203 => array( 203 => array(
'msg' => _("LSform : Les données du champ %{element} ne sont pas valides."), 'msg' => _("LSform : Les données du champ %{element} ne sont pas valides.")
'level' => 'c'
), ),
204 => array( 204 => array(
'msg' => _("LSform : Le champ %{element} n'existe pas."), 'msg' => _("LSform : Le champ %{element} n'existe pas.")
'level' => 'c'
), ),
205 => array( 205 => array(
'msg' => _("LSfom : Type de champ inconnu (%{type})."), 'msg' => _("LSfom : Type de champ inconnu (%{type}).")
'level' => 'c'
), ),
206 => array( 206 => array(
'msg' => _("LSform : Erreur durant la création de l'élement '%{element}'."), 'msg' => _("LSform : Erreur durant la création de l'élement '%{element}'.")
'level' => 'c'
), ),
207 => array( 207 => array(
'msg' => _("LSform : Aucune valeur de rentrée pour le champs '%{element}'."), 'msg' => _("LSform : Aucune valeur de rentrée pour le champs '%{element}'.")
'level' => 'c'
), ),
801 => array( 801 => array(
'msg' => _("LSformRule : Aucune regex n'a été fournis pour la validation des données."), 'msg' => _("LSformRule : Aucune regex n'a été fournis pour la validation des données.")
'level' => 'w'
), ),
// functions // functions
901 => array ( 901 => array (
'msg' => _("Functions 'getFData' : La methode %{meth} de l'objet %{obj} n'existe pas."), 'msg' => _("Functions 'getFData' : La methode %{meth} de l'objet %{obj} n'existe pas.")
'level' => 'c'
), ),
// LSsession // LSsession
1001 => array ( 1001 => array (
'msg' => _("LSsession : La constante %{const} n'est pas définie."), 'msg' => _("LSsession : La constante %{const} n'est pas définie.")
'level' => 'c'
), ),
1002 => array ( 1002 => array (
'msg' => _("LSsession : Le support %{addon} n'est pas assuré. Vérifier la compatibilité du système et la configuration de l'addon"), 'msg' => _("LSsession : Le support %{addon} n'est pas assuré. Vérifier la compatibilité du système et la configuration de l'addon")
'level' => 'c'
), ),
1003 => array ( 1003 => array (
'msg' => _("LSsession : Données de configuration du serveur LDAP invalide. Impossible d'établir une connexion."), 'msg' => _("LSsession : Données de configuration du serveur LDAP invalide. Impossible d'établir une connexion.")
'level' => 'c'
), ),
1004 => array ( 1004 => array (
'msg' => _("LSsession : Impossible de charger l'objets de type %{type} : type inconnu."), 'msg' => _("LSsession : Impossible de charger l'objets de type %{type} : type inconnu.")
'level' => 'c'
), ),
1005 => array ( 1005 => array (
'msg' => _("LSsession : Impossible d'effecture l'authentification : Type d'objet d'authentification inconnu (%{type})."), 'msg' => _("LSsession : Impossible d'effecture l'authentification : Type d'objet d'authentification inconnu (%{type}).")
'level' => 'c'
), ),
1006 => array ( 1006 => array (
'msg' => _("LSsession : Identifiant ou mot de passe incorrect."), 'msg' => _("LSsession : Identifiant ou mot de passe incorrect.")
'level' => 'c'
), ),
1007 => array ( 1007 => array (
'msg' => _("LSsession : Impossible de vous identifier : Duplication d'authentité."), 'msg' => _("LSsession : Impossible de vous identifier : Duplication d'authentité.")
'level' => 'c'
), ),
1008 => array ( 1008 => array (
'msg' => _("LSsession : Impossible d'inclure le moteur de rendu Smarty."), 'msg' => _("LSsession : Impossible d'inclure le moteur de rendu Smarty.")
'level' => 'c'
), ),
1009 => array ( 1009 => array (
'msg' => _("LSsession : Impossible de se connecter au Serveur LDAP."), 'msg' => _("LSsession : Impossible de se connecter au Serveur LDAP.")
'level' => 'c'
), ),
1010 => array ( 1010 => array (
'msg' => _("LSsession : Impossible de charger la classe des objets d'authentification."), 'msg' => _("LSsession : Impossible de charger la classe des objets d'authentification.")
'level' => 'c'
), ),
1011 => array ( 1011 => array (
'msg' => _("LSsession : Vous n'êtes pas authorisé à  effectuer cette action."), 'msg' => _("LSsession : Vous n'êtes pas authorisé à effectuer cette action.")
'level' => 'c'
), ),
1012 => array ( 1012 => array (
'msg' => _("LSsession : Des informations sont manquantes pour l'affichage de cette page."), 'msg' => _("LSsession : Des informations sont manquantes pour l'affichage de cette page.")
'level' => 'c'
), ),
1013 => array ( 1013 => array (
'msg' => _("LSrelations : La fonction de listage pour la relation %{relation} est inconnu."), 'msg' => _("LSrelations : La fonction de listage pour la relation %{relation} est inconnu.")
'level' => 'c'
), ),
1014 => array ( 1014 => array (
'msg' => _("LSrelations : La fonction de mise à jour pour la relation %{relation} est inconnu."), 'msg' => _("LSrelations : La fonction de mise à jour pour la relation %{relation} est inconnu.")
'level' => 'c'
), ),
1015 => array ( 1015 => array (
'msg' => _("LSrelations : Une erreur s'est produite durant la mise a jour de la relation %{relation}."), 'msg' => _("LSrelations : Une erreur s'est produite durant la mise a jour de la relation %{relation}.")
'level' => 'c'
), ),
1016 => array ( 1016 => array (
'msg' => _("LSrelations : L'objet %{LSobject} de la relation %{relation} est inconnu."), 'msg' => _("LSrelations : L'objet %{LSobject} de la relation %{relation} est inconnu.")
'level' => 'w'
), ),
1017 => array ( 1017 => array (
'msg' => _("LSsession : Impossible de créer correctement la liste des niveaux. Vérifier la configuration."), 'msg' => _("LSsession : Impossible de créer correctement la liste des niveaux. Vérifier la configuration.")
'level' => 'c'
), ),
1018 => array ( 1018 => array (
'msg' => _("LSsession : La récupération de mot de passe est désactivée pour ce serveur LDAP."), 'msg' => _("LSsession : La récupération de mot de passe est désactivée pour ce serveur LDAP.")
'level' => 'c'
), ),
1019 => array ( 1019 => array (
'msg' => _("LSsession : Des informations sont manquantes pour la récupération de votre mot de passe. Contactez l'administrateur du système."), 'msg' => _("LSsession : Des informations sont manquantes pour la récupération de votre mot de passe. Contactez l'administrateur du systême.")
'level' => 'c'
), ),
1020 => array ( 1020 => array (
'msg' => _("LSsession : Erreur durant la récupération de votre mot de passe. Contactez l'administrateur du système."), 'msg' => _("LSsession : Erreur durant la récupération de votre mot de passe. Contactez l'administrateur du systême.")
'level' => 'c'
), ),
1021 => array ( 1021 => array (
'msg' => _("LSrelation : Des paramètres sont manquants dans l'invocation des méthodes de manipulations de relations standarts (Méthode : %{meth})."), 'msg' => _("LSrelation : Des paramètres sont manquants dans l'invocation des méthodes de manipulations de relations standarts (Méthode : %{meth}).")
'level' => 'c'
) )
); );
?> ?>

View file

@ -25,7 +25,7 @@ $GLOBALS['LSsession'] -> loadLSclass('LSattribute');
/** /**
* Base d'un objet ldap * Base d'un objet ldap
* *
* Cette classe définis la base de tout objet ldap géré par LdapSaisie * Cette classe définis la base de tout objet ldap géré par LdapSaisie
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
*/ */
@ -46,15 +46,15 @@ class LSldapObject {
/** /**
* Constructeur * Constructeur
* *
* Cette methode construit l'objet et définis la configuration. * Cette methode construit l'objet et définis la configuration.
* Elle lance la construction du tableau d'attributs représentés par un objet LSattribute. * Elle lance la construction du tableau d'attributs représentés par un objet LSattribute.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @param[in] $type_name [<b>required</b>] string Le nom du type de l'objet * @param[in] $type_name [<b>required</b>] string Le nom du type de l'objet
* @param[in] $config array La configuration de l'objet * @param[in] $config array La configuration de l'objet
* *
* @retval boolean true si l'objet a été construit, false sinon. * @retval boolean true si l'objet a été construit, false sinon.
*/ */
function LSldapObject($type_name,$config='auto') { function LSldapObject($type_name,$config='auto') {
$this -> type_name = $type_name; $this -> type_name = $type_name;
@ -77,16 +77,16 @@ class LSldapObject {
} }
/** /**
* Charge les données de l'objet * Charge les données de l'objet
* *
* Cette methode définis le DN de l'objet et charge les valeurs de attributs de l'objet * Cette methode définis le DN de l'objet et charge les valeurs de attributs de l'objet
* à partir de l'annuaire. * à partir de l'annuaire.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @param[in] $dn string Le DN de l'objet. * @param[in] $dn string Le DN de l'objet.
* *
* @retval boolean true si la chargement a réussi, false sinon. * @retval boolean true si la chargement a réussi, false sinon.
*/ */
function loadData($dn) { function loadData($dn) {
$this -> dn = $dn; $this -> dn = $dn;
@ -102,11 +102,11 @@ class LSldapObject {
} }
/** /**
* Recharge les données de l'objet * Recharge les données de l'objet
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true si la rechargement a réussi, false sinon. * @retval boolean true si la rechargement a réussi, false sinon.
*/ */
function reloadData() { function reloadData() {
$data = $GLOBALS['LSldap'] -> getAttrs($this -> dn); $data = $GLOBALS['LSldap'] -> getAttrs($this -> dn);
@ -132,7 +132,7 @@ class LSldapObject {
* Retourne la valeur descriptive d'affichage de l'objet * Retourne la valeur descriptive d'affichage de l'objet
* *
* Cette fonction retourne la valeur descriptive d'affichage de l'objet en fonction * Cette fonction retourne la valeur descriptive d'affichage de l'objet en fonction
* du format défini dans la configuration de l'objet ou spécifié en paramètre. * du format défini dans la configuration de l'objet ou spécifié en paramètre.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
@ -154,16 +154,16 @@ class LSldapObject {
} }
/** /**
* Chaine formatée * Chaine formatée
* *
* Cette fonction retourne la valeur d'une chaine formatée en prennant les valeurs * Cette fonction retourne la valeur d'une chaine formatée en prennant les valeurs
* de l'objet. * de l'objet.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @param[in] $format string Format de la chaine * @param[in] $format string Format de la chaine
* *
* @retval string Valeur d'une chaine formatée * @retval string Valeur d'une chaine formatée
*/ */
function getFData($format) { function getFData($format) {
$format=getFData($format,$this,'getValue'); $format=getFData($format,$this,'getValue');
@ -173,15 +173,15 @@ class LSldapObject {
/** /**
* Construit un formulaire de l'objet * Construit un formulaire de l'objet
* *
* Cette méthode construit un formulaire LSform à partir de la configuration de l'objet * Cette méthode construit un formulaire LSform à partir de la configuration de l'objet
* et de chaque attribut. * et de chaque attribut.
* *
* @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer * @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer
* @param[in] $load DN d'un objet similaire dont la valeur des attribut doit être chargé dans le formulaire. * @param[in] $load DN d'un objet similaire dont la valeur des attribut doit être chargé dans le formulaire.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval LSform Le formulaire crée * @retval LSform Le formulaire crée
*/ */
function getForm($idForm,$load=NULL) { function getForm($idForm,$load=NULL) {
$GLOBALS['LSsession'] -> loadLSclass('LSform'); $GLOBALS['LSsession'] -> loadLSclass('LSform');
@ -216,15 +216,15 @@ class LSldapObject {
/** /**
* Construit un formulaire de l'objet * Construit un formulaire de l'objet
* *
* Cette méthode construit un formulaire LSform à partir de la configuration de l'objet * Cette méthode construit un formulaire LSform à partir de la configuration de l'objet
* et de chaque attribut. * et de chaque attribut.
* *
* @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer * @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer
* @param[in] $config Configuration spécifique pour le formulaire * @param[in] $config Configuration spécifique pour le formulaire
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval LSform Le formulaire crée * @retval LSform Le formulaire crée
*/ */
function getView() { function getView() {
$GLOBALS['LSsession'] -> loadLSclass('LSform'); $GLOBALS['LSsession'] -> loadLSclass('LSform');
@ -239,13 +239,13 @@ class LSldapObject {
/** /**
* Rafraichis le formulaire de l'objet * Rafraichis le formulaire de l'objet
* *
* Cette méthode recharge les données d'un formulaire LSform. * Cette méthode recharge les données d'un formulaire LSform.
* *
* @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer * @param[in] $idForm [<b>required</b>] Identifiant du formulaire a créer
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true sile formulaire a été rafraichis, false sinon * @retval boolean true sile formulaire a été rafraichis, false sinon
*/ */
function refreshForm($idForm) { function refreshForm($idForm) {
$LSform = $this -> forms[$idForm][0]; $LSform = $this -> forms[$idForm][0];
@ -258,15 +258,15 @@ class LSldapObject {
} }
/** /**
* Met à jour les données de l'objet et de l'entré de l'annuaire * Met à jour les données de l'objet et de l'entré de l'annuaire
* *
* Met à jour les données de l'objet à partir d'un retour d'un formulaire. * Met à jour les données de l'objet à partir d'un retour d'un formulaire.
* *
* @param[in] $idForm Identifiant du formulaire d'origine * @param[in] $idForm Identifiant du formulaire d'origine
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true si la mise à jour a réussi, false sinon * @retval boolean true si la mise à jour a réussi, false sinon
* *
* @see validateAttrsData() * @see validateAttrsData()
* @see submitChange() * @see submitChange()
@ -316,8 +316,24 @@ class LSldapObject {
return; return;
} }
} }
// $this -> attrs[*] => before_modify
foreach($new_data as $attr_name => $attr_val) {
if(isset($this -> config['attrs'][$attr_name]['before_modify'])) {
if(function_exists($this -> config['attrs'][$attr_name]['before_modify'])) {
if(!$this -> config['attrs'][$attr_name]['before_modify']($this)) {
$GLOBALS['LSerror'] -> addErrorCode(309,array('func' => $this -> config['attrs'][$attr_name]['before_modify'],'attr' => $attr_name));
return;
}
}
else {
$GLOBALS['LSerror'] -> addErrorCode(308,array('func' => $this -> config['attrs'][$attr_name]['before_modify'],'attr' => $attr_name));
return;
}
}
}
if ($this -> submitChange($idForm)) { if ($this -> submitChange($idForm)) {
LSdebug('Les modifications sont submitées'); LSdebug('Les modifications sont submitées');
$this -> submitError = false; $this -> submitError = false;
$this -> reloadData(); $this -> reloadData();
$this -> refreshForm($idForm); $this -> refreshForm($idForm);
@ -337,6 +353,22 @@ class LSldapObject {
return; return;
} }
} }
// $this -> attrs[*] => After Modify
foreach($new_data as $attr_name => $attr_val) {
if(isset($this -> config['attrs'][$attr_name]['after_modify'])) {
if(function_exists($this -> config['attrs'][$attr_name]['after_modify'])) {
if(!$this -> config['attrs'][$attr_name]['after_modify']($this)) {
$GLOBALS['LSerror'] -> addErrorCode(307,array('func' => $this -> config['after_modify'],'attr' => $attr_name));
return;
}
}
else {
$GLOBALS['LSerror'] -> addErrorCode(306,array('func' => $this -> config['after_modify'],'attr' => $attr_name));
return;
}
}
}
return true; return true;
} }
else { else {
@ -345,13 +377,13 @@ class LSldapObject {
} }
/** /**
* Valide les données retournées par un formulaire * Valide les données retournées par un formulaire
* *
* @param[in] $idForm Identifiant du formulaire d'origine * @param[in] $idForm Identifiant du formulaire d'origine
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true si les données sont valides, false sinon * @retval boolean true si les données sont valides, false sinon
*/ */
function validateAttrsData($idForm) { function validateAttrsData($idForm) {
$LSform=$this -> forms[$idForm][0]; $LSform=$this -> forms[$idForm][0];
@ -388,14 +420,14 @@ class LSldapObject {
} }
/** /**
* Valide les données d'un attribut * Valide les données d'un attribut
* *
* @param[in] $LSForm Formulaire d'origine * @param[in] $LSForm Formulaire d'origine
* @param[in] &$attr Attribut à valider * @param[in] &$attr Attribut à valider
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true si les données sont valides, false sinon * @retval boolean true si les données sont valides, false sinon
*/ */
function validateAttrData(&$LSform,&$attr) { function validateAttrData(&$LSform,&$attr) {
$vconfig=$attr -> getValidateConfig(); $vconfig=$attr -> getValidateConfig();
@ -408,12 +440,12 @@ class LSldapObject {
// Validation des valeurs de l'attribut // Validation des valeurs de l'attribut
if(is_array($vconfig)) { if(is_array($vconfig)) {
foreach($vconfig as $test) { foreach($vconfig as $test) {
// Définition du basedn par défaut // Définition du basedn par défaut
if (!isset($test['basedn'])) { if (!isset($test['basedn'])) {
$test['basedn']=$GLOBALS['LSsession']->topDn; $test['basedn']=$GLOBALS['LSsession']->topDn;
} }
// Définition du message d'erreur // Définition du message d'erreur
if (!empty($test['msg'])) { if (!empty($test['msg'])) {
$msg_error=getFData($test['msg'],$this,'getValue'); $msg_error=getFData($test['msg'],$this,'getValue');
} }
@ -475,7 +507,7 @@ class LSldapObject {
} }
} }
} }
// Génération des valeurs des attributs dépendants // Génération des valeurs des attributs dépendants
$dependsAttrs=$attr->getDependsAttrs(); $dependsAttrs=$attr->getDependsAttrs();
if (!empty($dependsAttrs)) { if (!empty($dependsAttrs)) {
foreach($dependsAttrs as $dependAttr) { foreach($dependsAttrs as $dependAttr) {
@ -502,13 +534,13 @@ class LSldapObject {
} }
/** /**
* Met à jour les données modifiés dans l'annuaire * Met à jour les données modifiés dans l'annuaire
* *
* @param[in] $idForm Identifiant du formulaire d'origine * @param[in] $idForm Identifiant du formulaire d'origine
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean true si la mise à jour a réussi, false sinon * @retval boolean true si la mise à jour a réussi, false sinon
*/ */
function submitChange($idForm) { function submitChange($idForm) {
$submitData=array(); $submitData=array();
@ -578,8 +610,8 @@ class LSldapObject {
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval array Tableau : * @retval array Tableau :
* - [0] : le premier paramètre * - [0] : le premier paramètre
* - [1] : les paramètres suivants * - [1] : les paramètres suivants
*/ */
function getDnInfos($dn) { function getDnInfos($dn) {
$infos=ldap_explode_dn($dn,0); $infos=ldap_explode_dn($dn,0);
@ -611,16 +643,16 @@ class LSldapObject {
} }
/** /**
* Retourne une liste d'objet du même type. * Retourne une liste d'objet du même type.
* *
* Effectue une recherche en fonction des paramètres passé et retourne un * Effectue une recherche en fonction des paramètres passé et retourne un
* tableau d'objet correspond au resultat de la recherche. * tableau d'objet correspond au resultat de la recherche.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @param[in] $filter array (ou string) Filtre de recherche Ldap / Tableau de filtres de recherche * @param[in] $filter array (ou string) Filtre de recherche Ldap / Tableau de filtres de recherche
* @param[in] $basedn string DN de base pour la recherche * @param[in] $basedn string DN de base pour la recherche
* @param[in] $params array Paramètres de recherche au format Net_LDAP2::search() * @param[in] $params array Paramètres de recherche au format Net_LDAP2::search()
* *
* @retval array Tableau d'objets correspondant au resultat de la recherche * @retval array Tableau d'objets correspondant au resultat de la recherche
*/ */
@ -636,22 +668,22 @@ class LSldapObject {
for($i=0;$i<$nbFilter;$i++) { for($i=0;$i<$nbFilter;$i++) {
$new_attrs=array(); $new_attrs=array();
// Défintion des paramètres de base pour la recherche // Défintion des paramètres de base pour la recherche
$sbasedn=$basedn; $sbasedn=$basedn;
$sparams=$params; $sparams=$params;
$ret=array(); $ret=array();
if (isset($filter[$i]['scope'])) if (isset($filter[$i]['scope']))
$sparams["scope"]=$filter[$i]['scope']; $sparams["scope"]=$filter[$i]['scope'];
// Definition des critères de recherche correspondant au type d'objet à lister // Definition des critères de recherche correspondant au type d'objet à lister
if(($nbFilter==1)||(!isset($filter[$i]['attr']))) { if(($nbFilter==1)||(!isset($filter[$i]['attr']))) {
// Filtre sur l'objet souhaité // Filtre sur l'objet souhaité
$sfilter='(&'; $sfilter='(&';
$sfilter.=$this -> getObjectFilter(); $sfilter.=$this -> getObjectFilter();
$sfilter_end=')'; $sfilter_end=')';
$check_final_dn=true; $check_final_dn=true;
} }
// Initialisation des critères d'une recherche intermédiaire // Initialisation des critères d'une recherche intermédiaire
else { else {
if(isset($filter[$i]['object_type'])) { if(isset($filter[$i]['object_type'])) {
$obj_tmp=new $filter[$i]['object_type'](); $obj_tmp=new $filter[$i]['object_type']();
@ -670,17 +702,17 @@ class LSldapObject {
$sbasedn=$filter[$i]['basedn']; $sbasedn=$filter[$i]['basedn'];
} }
} }
// Dans le cas d'une recherche intermédiaire ou finale // Dans le cas d'une recherche intermédiaire ou finale
if($attrs!=false) { if($attrs!=false) {
// Initialisation des variables // Initialisation des variables
$ret_gen=array(); $ret_gen=array();
$new_attrs=array(); $new_attrs=array();
// Pour tout les attributs retournés // Pour tout les attributs retournés
for($ii=0;$ii<count($attrs);$ii++) { for($ii=0;$ii<count($attrs);$ii++) {
$sfilter_for=''; $sfilter_for='';
// Définition du filtre de recherche à partir des paramètres utilisateurs et // Définition du filtre de recherche à partir des paramètres utilisateurs et
// des paramètres de recherche de l'objet à listé (dans le cas d'une recherche finale // des paramètres de recherche de l'objet à listé (dans le cas d'une recherche finale
if((isset($filter[$i]['filter']))&&(!empty($filter[$i]['filter']))) { if((isset($filter[$i]['filter']))&&(!empty($filter[$i]['filter']))) {
$sfilter_user=getFData($filter[$i]['filter'],$attrs[$ii]); $sfilter_user=getFData($filter[$i]['filter'],$attrs[$ii]);
if($sfilter_user[0]=='(') if($sfilter_user[0]=='(')
@ -697,7 +729,7 @@ class LSldapObject {
if ((!$this -> isCompatibleDNs($sbasedn,$basedn))&&($check_final_dn)) continue; if ((!$this -> isCompatibleDNs($sbasedn,$basedn))&&($check_final_dn)) continue;
} }
// Vérification de la compatibilité du basedn de la recherche et du basedn générale // Vérification de la compatibilité du basedn de la recherche et du basedn générale
// Finalisation du filtre // Finalisation du filtre
$sfilter_for.=$sfilter_end; $sfilter_for.=$sfilter_end;
@ -707,7 +739,7 @@ class LSldapObject {
// Si il y un retour // Si il y un retour
if(isset($ret[0])) { if(isset($ret[0])) {
// si il ya une suite (recherche intermédiaire) // si il ya une suite (recherche intermédiaire)
if($filter[$i]['attr']){ if($filter[$i]['attr']){
for($iii=0;$iii<count($ret);$iii++) { for($iii=0;$iii<count($ret);$iii++) {
if(isset($ret[$iii]['attrs'][$filter[$i]['attr']])) { if(isset($ret[$iii]['attrs'][$filter[$i]['attr']])) {
@ -725,7 +757,7 @@ class LSldapObject {
} }
} }
else { else {
// vérification de la compatibilité de la compatibilité du DN resultant // vérification de la compatibilité de la compatibilité du DN resultant
// et du basedn de recherche // et du basedn de recherche
if (!$this -> isCompatibleDNs($ret[0]['dn'],$basedn)) if (!$this -> isCompatibleDNs($ret[0]['dn'],$basedn))
continue; continue;
@ -740,9 +772,9 @@ class LSldapObject {
$ret=$ret_gen; $ret=$ret_gen;
break; break;
} }
// dans le cas d'une suite prévu mais d'un retour nul de la précédente recherche // dans le cas d'une suite prévu mais d'un retour nul de la précédente recherche
else if(empty($new_attrs)) { else if(empty($new_attrs)) {
// retour vide et arrêt de la recherche // retour vide et arrêt de la recherche
$ret=array(); $ret=array();
break; break;
} }
@ -752,7 +784,7 @@ class LSldapObject {
} }
// Dans le cas de la recherche initiale // Dans le cas de la recherche initiale
else { else {
// Déclaration du filtre de recherche // Déclaration du filtre de recherche
if((isset($filter[$i]['filter']))&&(!empty($filter[$i]['filter']))) { if((isset($filter[$i]['filter']))&&(!empty($filter[$i]['filter']))) {
if($filter[$i]['filter'][0]=='(') { if($filter[$i]['filter'][0]=='(') {
$sfilter.=$filter[$i]['filter']; $sfilter.=$filter[$i]['filter'];
@ -767,7 +799,7 @@ class LSldapObject {
// Lancement de la recherche // Lancement de la recherche
$ret=$GLOBALS['LSldap'] -> search ($sfilter,$sbasedn,$sparams); $ret=$GLOBALS['LSldap'] -> search ($sfilter,$sbasedn,$sparams);
//Si filtre multiple => on recupère une liste d'attributs //Si filtre multiple => on recupère une liste d'attributs
if(isset($filter[$i]['attr'])) { if(isset($filter[$i]['attr'])) {
for($ii=0;$ii<count($ret);$ii++) { for($ii=0;$ii<count($ret);$ii++) {
if(isset($ret[$ii]['attrs'][$filter[$i]['attr']])) { if(isset($ret[$ii]['attrs'][$filter[$i]['attr']])) {
@ -784,16 +816,16 @@ class LSldapObject {
} }
} }
// Si aucunne valeur n'est retournées // Si aucunne valeur n'est retournées
if(empty($attrs)){ if(empty($attrs)){
// arrêt et retour à zéro // arrêt et retour à zéro
$ret=array(); $ret=array();
break; break;
} }
} }
// Si recherche unique // Si recherche unique
else { else {
// préparation du retour finale // préparation du retour finale
if (is_array($ret)) { if (is_array($ret)) {
$ret_final=array(); $ret_final=array();
foreach($ret as $obj) foreach($ret as $obj)
@ -808,7 +840,7 @@ class LSldapObject {
} }
} }
// Création d'un tableau d'objet correspondant au valeur retourné // Création d'un tableau d'objet correspondant au valeur retourné
for($i=0;$i<count($ret);$i++) { for($i=0;$i<count($ret);$i++) {
$retInfos[$i] = new $this -> type_name($this -> config); $retInfos[$i] = new $this -> type_name($this -> config);
$retInfos[$i] -> loadData($ret[$i]); $retInfos[$i] -> loadData($ret[$i]);
@ -819,7 +851,7 @@ class LSldapObject {
/** /**
* Recherche un objet à partir de la valeur exact de son RDN * Recherche un objet à partir de la valeur exact de son RDN
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
@ -836,7 +868,7 @@ class LSldapObject {
/** /**
* Retourne une valeur de l'objet * Retourne une valeur de l'objet
* *
* Retourne une valeur en fonction du paramètre. Si la valeur est inconnue, la valeur retourné est ' '. * Retourne une valeur en fonction du paramètre. Si la valeur est inconnue, la valeur retourné est ' '.
* tableau d'objet correspond au resultat de la recherche. * tableau d'objet correspond au resultat de la recherche.
* *
* Valeurs possibles : * Valeurs possibles :
@ -846,9 +878,9 @@ class LSldapObject {
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @param[in] $val string Le nom de la valeur demandée * @param[in] $val string Le nom de la valeur demandée
* *
* @retval mixed la valeur demandé ou ' ' si celle-ci est inconnue. * @retval mixed la valeur demandé ou ' ' si celle-ci est inconnue.
*/ */
function getValue($val) { function getValue($val) {
if(($val=='dn')||($val=='%{dn}')) { if(($val=='dn')||($val=='%{dn}')) {
@ -878,7 +910,7 @@ class LSldapObject {
} }
/** /**
* Retourn un tableau pour un select d'un objet du même type * Retourn un tableau pour un select d'un objet du même type
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
@ -896,7 +928,7 @@ class LSldapObject {
/** /**
* Retourne le DN de l'objet * Retourne le DN de l'objet
* *
* Cette methode retourne le DN de l'objet. Si celui-ci n'existe pas, il le construit à partir de la * Cette methode retourne le DN de l'objet. Si celui-ci n'existe pas, il le construit à partir de la
* configuration de l'objet et la valeur de son attribut rdn. * configuration de l'objet et la valeur de son attribut rdn.
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
@ -938,11 +970,11 @@ class LSldapObject {
} }
/** /**
* Retourne qui est l'utilisateur par rapport à cet object * Retourne qui est l'utilisateur par rapport à cet object
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval string 'admin'/'self'/'user' pour Admin , l'utilisateur lui même ou un simple utilisateur * @retval string 'admin'/'self'/'user' pour Admin , l'utilisateur lui même ou un simple utilisateur
*/ */
function whoami() { function whoami() {
if (!$this -> _whoami) if (!$this -> _whoami)
@ -967,7 +999,7 @@ class LSldapObject {
* *
* @author Benjamin Renard <brenard@easter-eggs.com> * @author Benjamin Renard <brenard@easter-eggs.com>
* *
* @retval boolean True si l'objet à été supprimé, false sinon * @retval boolean True si l'objet à été supprimé, false sinon
*/ */
function remove() { function remove() {
if ($this -> beforeDelete()) { if ($this -> beforeDelete()) {
@ -1028,10 +1060,10 @@ class LSldapObject {
} }
/** /**
* Methode créant la liste des objets en relations avec l'objet courant et qui * Methode créant la liste des objets en relations avec l'objet courant et qui
* la met en cache ($this -> _relationsCache) * la met en cache ($this -> _relationsCache)
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function updateRelationsCache() { function updateRelationsCache() {
$this -> _relationsCache=array(); $this -> _relationsCache=array();
@ -1055,12 +1087,12 @@ class LSldapObject {
); );
} }
else { else {
LSdebug('Problème durant la mise en cache de la relation '.$relation_name); LSdebug('Problème durant la mise en cache de la relation '.$relation_name);
return; return;
} }
} }
else { else {
LSdebug('Les méthodes de mise en cache de la relation '.$relation_name. ' ne sont pas toutes disponibles.'); LSdebug('Les méthodes de mise en cache de la relation '.$relation_name. ' ne sont pas toutes disponibles.');
return; return;
} }
} }
@ -1075,29 +1107,29 @@ class LSldapObject {
} }
/** /**
* Methode executant les actions nécéssaires avant le changement du DN de * Methode executant les actions nécéssaires avant le changement du DN de
* l'objet. * l'objet.
* *
* Cette méthode n'est qu'un exemple et elle doit être certainement réécrite * Cette méthode n'est qu'un exemple et elle doit être certainement réécrite
* pour les objets plus complexe. * pour les objets plus complexe.
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function beforeRename() { function beforeRename() {
return $this -> updateRelationsCache(); return $this -> updateRelationsCache();
} }
/** /**
* Methode executant les actions nécéssaires après le changement du DN de * Methode executant les actions nécéssaires après le changement du DN de
* l'objet. * l'objet.
* *
* Cette méthode n'est qu'un exemple et elle doit être certainement réécrite * Cette méthode n'est qu'un exemple et elle doit être certainement réécrite
* pour les objets plus complexe. * pour les objets plus complexe.
* *
* @param[in] $oldDn string L'ancien DN de l'objet * @param[in] $oldDn string L'ancien DN de l'objet
* @param[in] $newDn string Le nouveau DN de l'objet * @param[in] $newDn string Le nouveau DN de l'objet
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function afterRename($oldDn,$newDn) { function afterRename($oldDn,$newDn) {
$error = 0; $error = 0;
@ -1124,26 +1156,26 @@ class LSldapObject {
} }
/** /**
* Methode executant les actions nécéssaires avant la suppression de * Methode executant les actions nécéssaires avant la suppression de
* l'objet. * l'objet.
* *
* Cette méthode n'est qu'un exemple et elle doit être certainement réécrite * Cette méthode n'est qu'un exemple et elle doit être certainement réécrite
* pour les objets plus complexe. * pour les objets plus complexe.
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function beforeDelete() { function beforeDelete() {
return $this -> updateRelationsCache(); return $this -> updateRelationsCache();
} }
/** /**
* Methode executant les actions nécéssaires après la suppression de * Methode executant les actions nécéssaires après la suppression de
* l'objet. * l'objet.
* *
* Cette méthode n'est qu'un exemple et elle doit être certainement réécrite * Cette méthode n'est qu'un exemple et elle doit être certainement réécrite
* pour les objets plus complexe. * pour les objets plus complexe.
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function afterDelete() { function afterDelete() {
$error = 0; $error = 0;
@ -1188,13 +1220,13 @@ class LSldapObject {
} }
/** /**
* Methode executant les actions nécéssaires après la création de * Methode executant les actions nécéssaires après la création de
* l'objet. * l'objet.
* *
* Cette méthode n'est qu'un exemple et elle doit être certainement réécrite * Cette méthode n'est qu'un exemple et elle doit être certainement réécrite
* pour les objets plus complexe. * pour les objets plus complexe.
* *
* @retval True en cas de cas ce succès, False sinon. * @retval True en cas de cas ce succès, False sinon.
*/ */
function afterCreate() { function afterCreate() {
LSdebug('after'); LSdebug('after');
@ -1206,7 +1238,7 @@ class LSldapObject {
if (isset($GLOBALS['LSobjects'][$type]['container_auto_create'])&&isset($GLOBALS['LSobjects'][$type]['container_dn'])) { if (isset($GLOBALS['LSobjects'][$type]['container_auto_create'])&&isset($GLOBALS['LSobjects'][$type]['container_dn'])) {
$dn = $GLOBALS['LSobjects'][$type]['container_dn'].','.$this -> getDn(); $dn = $GLOBALS['LSobjects'][$type]['container_dn'].','.$this -> getDn();
if(!$GLOBALS['LSldap'] -> getNewEntry($dn,$GLOBALS['LSobjects'][$type]['container_auto_create']['objectclass'],$GLOBALS['LSobjects'][$type]['container_auto_create']['attrs'],true)) { if(!$GLOBALS['LSldap'] -> getNewEntry($dn,$GLOBALS['LSobjects'][$type]['container_auto_create']['objectclass'],$GLOBALS['LSobjects'][$type]['container_auto_create']['attrs'],true)) {
LSdebug("Impossible de créer l'entrée fille : ".print_r( LSdebug("Impossible de créer l'entrée fille : ".print_r(
array( array(
'dn' => $dn, 'dn' => $dn,
'objectClass' => $GLOBALS['LSobjects'][$type]['container_auto_create']['objectclass'], 'objectClass' => $GLOBALS['LSobjects'][$type]['container_auto_create']['objectclass'],
@ -1277,12 +1309,12 @@ class LSldapObject {
} }
/** /**
* Retourne la liste des relations pour l'objet en fonction de sa présence * Retourne la liste des relations pour l'objet en fonction de sa présence
* dans un des attributs * dans un des attributs
* *
* Retourne un tableau de d'objet (type : $objectType) correspondant à la * Retourne un tableau de d'objet (type : $objectType) correspondant à la
* relation entre l'objet $object et les objets de type $objectType. Cette relation * relation entre l'objet $object et les objets de type $objectType. Cette relation
* est établis par la présence de la valeur de référence à l'objet dans * est établis par la présence de la valeur de référence à l'objet dans
* l'attribut des objets de type $objectType. * l'attribut des objets de type $objectType.
* *
* @param[in] $object Un object de type $objectType * @param[in] $object Un object de type $objectType
@ -1317,14 +1349,14 @@ class LSldapObject {
/** /**
* Ajoute un objet en relation dans l'attribut $attr de $this * Ajoute un objet en relation dans l'attribut $attr de $this
* *
* @param[in] $object Un objet de type $objectType à ajouter * @param[in] $object Un objet de type $objectType à ajouter
* @param[in] $attr L'attribut dans lequel l'objet doit être ajouté * @param[in] $attr L'attribut dans lequel l'objet doit être ajouté
* @param[in] $objectType Le type d'objet en relation * @param[in] $objectType Le type d'objet en relation
* @param[in] $attrValue La valeur que doit avoir l'attribut : * @param[in] $attrValue La valeur que doit avoir l'attribut :
* - soit le dn (par defaut) * - soit le dn (par defaut)
* - soit la valeur [0] d'un attribut * - soit la valeur [0] d'un attribut
* *
* @retval boolean true si l'objet à été ajouté, False sinon * @retval boolean true si l'objet à été ajouté, False sinon
**/ **/
function addOneObjectInRelation($object,$attr,$objectType,$attrValue='dn') { function addOneObjectInRelation($object,$attr,$objectType,$attrValue='dn') {
if ((!$attr)||(!$objectType)) { if ((!$attr)||(!$objectType)) {
@ -1367,14 +1399,14 @@ class LSldapObject {
/** /**
* Supprime un objet en relation dans l'attribut $attr de $this * Supprime un objet en relation dans l'attribut $attr de $this
* *
* @param[in] $object Un objet de type $objectType à supprimer * @param[in] $object Un objet de type $objectType à supprimer
* @param[in] $attr L'attribut dans lequel l'objet doit être supprimé * @param[in] $attr L'attribut dans lequel l'objet doit être supprimé
* @param[in] $objectType Le type d'objet en relation * @param[in] $objectType Le type d'objet en relation
* @param[in] $attrValue La valeur que doit avoir l'attribut : * @param[in] $attrValue La valeur que doit avoir l'attribut :
* - soit le dn (par defaut) * - soit le dn (par defaut)
* - soit la valeur [0] d'un attribut * - soit la valeur [0] d'un attribut
* *
* @retval boolean true si l'objet à été supprimé, False sinon * @retval boolean true si l'objet à été supprimé, False sinon
**/ **/
function deleteOneObjectInRelation($object,$attr,$objectType,$attrValue='dn') { function deleteOneObjectInRelation($object,$attr,$objectType,$attrValue='dn') {
if ((!$attr)||(!$objectType)) { if ((!$attr)||(!$objectType)) {
@ -1411,15 +1443,15 @@ class LSldapObject {
/** /**
* Renome un objet en relation dans l'attribut $attr de $this * Renome un objet en relation dans l'attribut $attr de $this
* *
* @param[in] $object Un objet de type $objectType à renomer * @param[in] $object Un objet de type $objectType à renomer
* @param[in] $oldValue string L'ancienne valeur faisant référence à l'objet * @param[in] $oldValue string L'ancienne valeur faisant référence à l'objet
* @param[in] $attr L'attribut dans lequel l'objet doit être supprimé * @param[in] $attr L'attribut dans lequel l'objet doit être supprimé
* @param[in] $objectType Le type d'objet en relation * @param[in] $objectType Le type d'objet en relation
* @param[in] $attrValue La valeur que doit avoir l'attribut : * @param[in] $attrValue La valeur que doit avoir l'attribut :
* - soit le dn (par defaut) * - soit le dn (par defaut)
* - soit la valeur [0] d'un attribut * - soit la valeur [0] d'un attribut
* *
* @retval boolean True en cas de succès, False sinon * @retval boolean True en cas de succès, False sinon
*/ */
function renameOneObjectInRelation($object,$oldValue,$attr,$objectType,$attrValue='dn') { function renameOneObjectInRelation($object,$oldValue,$attr,$objectType,$attrValue='dn') {
if ((!$attr)||(!$objectType)) { if ((!$attr)||(!$objectType)) {
@ -1457,7 +1489,7 @@ class LSldapObject {
} }
/** /**
* Met à jour les objets du meme type que $this en relation avec l'objet $object * Met à jour les objets du meme type que $this en relation avec l'objet $object
* de type $objectType en modifiant la valeur de leur attribut $attr des objets * de type $objectType en modifiant la valeur de leur attribut $attr des objets
* en relation * en relation
* *
@ -1469,7 +1501,7 @@ class LSldapObject {
* - soit le dn (par defaut) * - soit le dn (par defaut)
* - soit la valeur [0] d'un attribut * - soit la valeur [0] d'un attribut
* *
* @retval boolean true si tout c'est bien passé, False sinon * @retval boolean true si tout c'est bien passé, False sinon
**/ **/
function updateObjectsInRelation($object,$listDns,$attr,$objectType,$attrValue='dn') { function updateObjectsInRelation($object,$listDns,$attr,$objectType,$attrValue='dn') {
if ((!$attr)||(!$objectType)) { if ((!$attr)||(!$objectType)) {