Rename trunk directory to public_html
[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
30 // Autres erreurs
31 LSerror :: defineError('SUPANN_01',
32   _("SUPANN Support : The attribute %{dependency} is missing. Unable to forge the attribute %{attr}.")
33 );
34       
35  /**
36   * Verification du support SUPANN par ldapSaisie
37   * 
38   * @author Benjamin Renard <brenard@easter-eggs.com>
39   *
40   * @retval boolean true si SUPANN est pleinement supporté, false sinon
41   */
42   function LSaddon_supann_support() {
43     $retval = true;
44         
45     $MUST_DEFINE_CONST= array(
46       'LS_SUPANN_LASTNAME_ATTR',
47       'LS_SUPANN_FIRSTNAME_ATTR'
48     );
49
50     foreach($MUST_DEFINE_CONST as $const) {
51       if ( (!defined($const)) || (constant($const) == "")) {
52         LSerror :: addErrorCode('SUPANN_SUPPORT_01',$const);
53         $retval=false;
54       }
55     }
56     
57     return $retval;
58   }
59
60  /**
61   * Generation du displayName
62   * 
63   * @author Benjamin Renard <brenard@easter-eggs.com>
64   *
65   * @param[in] $ldapObject L'objet ldap
66   *
67   * @retval string Le displayName ou false si il y a un problème durant la génération
68   */
69   function generate_displayName($ldapObject) {
70     if ( get_class($ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ]) != 'LSattribute' ) {
71       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_LASTNAME_ATTR, 'attr' => 'cn'));
72       return;
73     }
74     if ( get_class($ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ]) != 'LSattribute' ) {
75       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_FIRSTNAME_ATTR, 'attr' => 'cn'));
76       return;
77     }
78
79     $noms = $ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ] -> getValue();
80     $prenoms = $ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ] -> getValue();
81
82     return ($prenoms[0].' '.$noms[0]);
83   }
84   
85  /**
86   * Generation du CN
87   * 
88   * @author Benjamin Renard <brenard@easter-eggs.com>
89   *
90   * @param[in] $ldapObject L'objet ldap
91   *
92   * @retval string Le CN ou false si il y a un problème durant la génération
93   */
94   function generate_cn($ldapObject) {
95     if ( get_class($ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ]) != 'LSattribute' ) {
96       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_LASTNAME_ATTR, 'attr' => 'cn'));
97       return;
98     }
99     if ( get_class($ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ]) != 'LSattribute' ) {
100       LSerror :: addErrorCode('SUPANN_01',array('dependency' => LS_SUPANN_FIRSTNAME_ATTR, 'attr' => 'cn'));
101       return;
102     }
103
104     $noms = $ldapObject -> attrs[ LS_SUPANN_LASTNAME_ATTR ] -> getValue();
105     $prenoms = $ldapObject -> attrs[ LS_SUPANN_FIRSTNAME_ATTR ] -> getValue();
106
107     return (replaceAccents($noms[0]).' '.replaceAccents($prenoms[0]));
108   }
109   
110   
111  /**
112   * Supprime les accents d'une chaine
113   * 
114   * @param[in] $string La chaine originale
115   * 
116   * @retval string La chaine sans les accents
117   */
118   function replaceAccents($string){
119     $replaceAccent = Array(
120       "à" => "a",
121       "á" => "a",
122       "â" => "a",
123       "ã" => "a",
124       "ä" => "a",
125       "ç" => "c",
126       "è" => "e",
127       "é" => "e",
128       "ê" => "e",
129       "ë" => "e",
130       "ì" => "i",
131       "í" => "i",
132       "î" => "i",
133       "ï" => "i",
134       "ñ" => "n",
135       "ò" => "o",
136       "ó" => "o",
137       "ô" => "o",
138       "õ" => "o",
139       "ö" => "o",
140       "ù" => "u",
141       "ú" => "u",
142       "û" => "u",
143       "ü" => "u",
144       "ý" => "y",
145       "ÿ" => "y",
146       "À" => "A",
147       "Á" => "A",
148       "Â" => "A",
149       "Ã" => "A",
150       "Ä" => "A",
151       "Ç" => "C",
152       "È" => "E",
153       "É" => "E",
154       "Ê" => "E",
155       "Ë" => "E",
156       "Ì" => "I",
157       "Í" => "I",
158       "Î" => "I",
159       "Ï" => "I",
160       "Ñ" => "N",
161       "Ò" => "O",
162       "Ó" => "O",
163       "Ô" => "O",
164       "Õ" => "O",
165       "Ö" => "O",
166       "Ù" => "U",
167       "Ú" => "U",
168       "Û" => "U",
169       "Ü" => "U",
170       "Ý" => "Y"
171     );
172     return strtr($string, $replaceAccent);
173   }
174 ?>