76a600e4f0b7ebfbad39bf15983b8d456e07c09e
[ldapsaisie.git] / public_html / includes / addons / LSaddons.supann.php
1 <?php
2 /*******************************************************************************
3  * Copyright (C) 2007 Easter-eggs
4  * http://ldapsaisie.labs.libre-entreprise.org
5  *
6  * Author: See AUTHORS file in top-level directory.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License version 2
10  * as published by the Free Software Foundation.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20
21 ******************************************************************************/
22
23 // Messages d'erreur
24
25 // Support
26 LSerror :: defineError('SUPANN_SUPPORT_01',
27   _("SUPANN Support : The constant %{const} is not defined.")
28 );
29 LSerror :: defineError('SUPANN_SUPPORT_02',
30   _("SUPANN Support : The LSobject type %{type} does not exist. Can't work with entities..")
31 );
32
33
34 // Autres erreurs
35 LSerror :: defineError('SUPANN_01',
36   _("SUPANN Support : The attribute %{dependency} is missing. Unable to forge the attribute %{attr}.")
37 );
38 LSerror :: defineError('SUPANN_02',
39   _("SUPANN Support : Can't get the basedn of entities. Unable to forge the attribute %{attr}.")
40 );
41       
42  /**
43   * Verification du support SUPANN par ldapSaisie
44   * 
45   * @author Benjamin Renard <brenard@easter-eggs.com>
46   *
47   * @retval boolean true si SUPANN est pleinement supporté, false sinon
48   */
49   function LSaddon_supann_support() {
50     $retval = true;
51         
52     $MUST_DEFINE_CONST= array(
53       'LS_SUPANN_LASTNAME_ATTR',
54       'LS_SUPANN_FIRSTNAME_ATTR',
55       'LS_SUPANN_LSOBJECT_ENTITE_TYPE',
56       'LS_SUPANN_ETABLISSEMENT_UAI',
57       'LS_SUPANN_ETABLISSEMENT_DN'
58     );
59
60     foreach($MUST_DEFINE_CONST as $const) {
61       if ( (!defined($const)) || (constant($const) == "")) {
62         LSerror :: addErrorCode('SUPANN_SUPPORT_01',$const);
63         $retval=false;
64       }
65     }
66
67     if ( defined('LS_SUPANN_LSOBJECT_ENTITE_TYPE') ) {
68       if ( ! LSsession :: loadLSobject( LS_SUPANN_LSOBJECT_ENTITE_TYPE ) ) {
69         LSerror :: addErrorCode('SUPANN_SUPPORT_02', LS_SUPANN_LSOBJECT_ENTITE_TYPE);
70       }
71     }
72     
73     return $retval;
74   }
75
76  /**
77   * Generation du displayName
78   * 
79   * @author Benjamin Renard <brenard@easter-eggs.com>
80   *
81   * @param[in] $ldapObject L'objet ldap
82   *
83   * @retval string Le displayName ou false si il y a un problème durant la génération
84   */
85   function generate_displayName($ldapObject) {
86     if ( get_class($ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ]) != 'LSattribute' ) {
87       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_LASTNAME_ATTR, 'attr' => 'cn'));
88       return;
89     }
90     if ( get_class($ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ]) != 'LSattribute' ) {
91       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_FIRSTNAME_ATTR, 'attr' => 'cn'));
92       return;
93     }
94
95     $noms = $ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ] -> getValue();
96     $prenoms = $ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ] -> getValue();
97
98     return ($prenoms[0].' '.$noms[0]);
99   }
100   
101  /**
102   * Generation du CN
103   * 
104   * @author Benjamin Renard <brenard@easter-eggs.com>
105   *
106   * @param[in] $ldapObject L'objet ldap
107   *
108   * @retval string Le CN ou false si il y a un problème durant la génération
109   */
110   function generate_cn($ldapObject) {
111     if ( get_class($ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ]) != 'LSattribute' ) {
112       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_LASTNAME_ATTR, 'attr' => 'cn'));
113       return;
114     }
115     if ( get_class($ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ]) != 'LSattribute' ) {
116       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_FIRSTNAME_ATTR, 'attr' => 'cn'));
117       return;
118     }
119
120     $noms = $ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ] -> getValue();
121     $prenoms = $ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ] -> getValue();
122
123     return (replaceAccents($noms[0]).' '.replaceAccents($prenoms[0]));
124   }
125   
126   
127  /**
128   * Supprime les accents d'une chaine
129   * 
130   * @param[in] $string La chaine originale
131   * 
132   * @retval string La chaine sans les accents
133   */
134   function replaceAccents($string){
135     $replaceAccent = Array(
136       "à" => "a",
137       "á" => "a",
138       "â" => "a",
139       "ã" => "a",
140       "ä" => "a",
141       "ç" => "c",
142       "è" => "e",
143       "é" => "e",
144       "ê" => "e",
145       "ë" => "e",
146       "ì" => "i",
147       "í" => "i",
148       "î" => "i",
149       "ï" => "i",
150       "ñ" => "n",
151       "ò" => "o",
152       "ó" => "o",
153       "ô" => "o",
154       "õ" => "o",
155       "ö" => "o",
156       "ù" => "u",
157       "ú" => "u",
158       "û" => "u",
159       "ü" => "u",
160       "ý" => "y",
161       "ÿ" => "y",
162       "À" => "A",
163       "Á" => "A",
164       "Â" => "A",
165       "Ã" => "A",
166       "Ä" => "A",
167       "Ç" => "C",
168       "È" => "E",
169       "É" => "E",
170       "Ê" => "E",
171       "Ë" => "E",
172       "Ì" => "I",
173       "Í" => "I",
174       "Î" => "I",
175       "Ï" => "I",
176       "Ñ" => "N",
177       "Ò" => "O",
178       "Ó" => "O",
179       "Ô" => "O",
180       "Õ" => "O",
181       "Ö" => "O",
182       "Ù" => "U",
183       "Ú" => "U",
184       "Û" => "U",
185       "Ü" => "U",
186       "Ý" => "Y"
187     );
188     return strtr($string, $replaceAccent);
189   }
190
191   function generate_eduPersonOrgUnitDN($ldapObject) {
192     if ( get_class($ldapObject -> attrs[ 'supannEntiteAffectation' ]) != 'LSattribute' ) {
193       LSerror :: addErrorCode('SUPANN_01',array('dependency' => 'supannEntiteAffectation', 'attr' => 'eduPersonOrgUnitDN'));
194       return;
195     }
196
197     $affectations = $ldapObject -> attrs[ 'supannEntiteAffectation' ] -> getUpdateData();
198
199     $basedn=LSconfig :: get('LSobjects.'.LS_SUPANN_LSOBJECT_ENTITE_TYPE.'.container_dn').','.LSsession::getTopDn();
200     if ($basedn=="") {
201       LSerror :: addErrorCode('SUPANN_02','eduPersonOrgUnitDN');
202       return;
203     }
204
205     $retval=array();
206     foreach ($affectations as $aff) {
207       $retval[]="supannCodeEntite=".$aff.",$basedn";
208     }
209
210     return $retval;
211   }
212
213   function generate_eduPersonPrimaryOrgUnitDN($ldapObject) {
214     if ( get_class($ldapObject -> attrs[ 'supannEntiteAffectationPrincipale' ]) != 'LSattribute' ) {
215       LSerror :: addErrorCode('SUPANN_01',array('dependency' => 'supannEntiteAffectationPrincipale', 'attr' => 'eduPersonPrimaryOrgUnitDN'));
216       return;
217     }
218
219     $affectations = $ldapObject -> attrs[ 'supannEntiteAffectationPrincipale' ] -> getUpdateData();
220
221     $basedn=LSconfig :: get('LSobjects.'.LS_SUPANN_LSOBJECT_ENTITE_TYPE.'.container_dn').','.LSsession::getTopDn();
222     if ($basedn=="") {
223       LSerror :: addErrorCode('SUPANN_02','eduPersonPrimaryOrgUnitDN');
224       return;
225     }
226
227     $retval=array();
228     foreach ($affectations as $aff) {
229       $retval[]="supannCodeEntite=".$aff.",$basedn";
230     }
231
232     return $retval;
233   }
234
235   function generate_eduPersonOrgDN($ldapObject) {
236     if ( get_class($ldapObject -> attrs[ 'supannEtablissement' ]) != 'LSattribute' ) {
237       LSerror :: addErrorCode('SUPANN_01',array('dependency' => 'supannEtablissement', 'attr' => 'eduPersonOrgDN'));
238       return;
239     }
240
241     $eta = $ldapObject -> attrs[ 'supannEtablissement' ] -> getUpdateData();
242
243     $retval=array();
244     if ($eta[0] == '{UAI}'.LS_SUPANN_ETABLISSEMENT_UAI) {
245         $retval[] = LS_SUPANN_ETABLISSEMENT_DN;
246     }
247
248     return $retval;
249   }
250
251 ?>