Subversion Repositories Applications.papyrus

Rev

Rev 1606 | Rev 1728 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1090 florian 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
1649 florian 22
// CVS : $Id: identification.php,v 1.35 2007-10-11 14:14:22 florian Exp $
1090 florian 23
/**
24
* Applette : identification
17 alex 25
*
1090 florian 26
* Génère un formulaire les champs nécessaires pour s'identifier.
27
* Nécessite :
28
* - Variable globale de Génésia.
29
* - Pear Auth
30
* - Pear Net_URL
31
*
17 alex 32
* A faire : remplacer le formulaire par un QuickForm
1090 florian 33
*
34
*@package Applette
35
*@subpackage Identification
36
//Auteur original :
37
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
38
//Autres auteurs :
39
*@author        Aucun
40
*@copyright     Tela-Botanica 2000-2004
1649 florian 41
*@version       $Revision: 1.35 $ $Date: 2007-10-11 14:14:22 $
1090 florian 42
// +------------------------------------------------------------------------------------------------------+
43
*/
304 jpm 44
 
1090 florian 45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            ENTÊTE du PROGRAMME                                       |
47
// +------------------------------------------------------------------------------------------------------+
48
$GLOBALS['_GEN_commun']['info_applette_nom_fonction'] = 'afficherFormIdentification';
1145 jp_milcent 49
$GLOBALS['_GEN_commun']['info_applette_balise'] = 	'(?:<!-- '.$GLOBALS['_GEN_commun']['balise_prefixe'].'(IDENTIFICATION) -->|'.
1606 alexandre_ 50
													'\{\{[Ii]dentification'.
51
													'(?:\s*'.
52
														'(?:'.
53
															'(template=".*")|'.
54
														')'.
55
													')+'.
56
													'\s*\}\})';
1090 florian 57
 
304 jpm 58
/** Inclusion du fichier de configuration de cette applette.*/
1090 florian 59
require_once GEN_CHEMIN_APPLETTE.'identification'.GEN_SEP.'configuration'.GEN_SEP.'iden_config.inc.php';
304 jpm 60
 
61
// Inclusion des fichiers de traduction de l'applette.
1090 florian 62
if (file_exists(IDEN_CHEMIN_LANGUE.'iden_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) {
304 jpm 63
    /** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
1090 florian 64
    require_once IDEN_CHEMIN_LANGUE.'iden_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php';
304 jpm 65
} else {
66
    /** Inclusion du fichier de traduction par défaut.*/
67
    require_once IDEN_CHEMIN_LANGUE.'iden_langue_'.IDEN_I18N_DEFAUT.'.inc.php';
1090 florian 68
}
69
// +------------------------------------------------------------------------------------------------------+
70
// |                                            CORPS du PROGRAMME                                        |
71
// +------------------------------------------------------------------------------------------------------+
72
 
73
// Si le site utilise une authentification.
74
if ($GLOBALS['_GEN_commun']['info_auth']->gsa_ce_type_auth == 1) {
1172 jp_milcent 75
	$cookie_persistant_nom = session_name().'-memo';
1090 florian 76
    // Si un formulaire nous renvoie en POST une variable "deconnexion", nous délogons l'utilisateur.
1172 jp_milcent 77
    if ((isset($_REQUEST['deconnexion']) || isset($_REQUEST['logout']))) {
1090 florian 78
		$GLOBALS['_GEN_commun']['pear_auth']->logout();
1172 jp_milcent 79
		// Destruction du cookie de session de Papyrus : est ce utile?
1090 florian 80
		setcookie(session_name(), session_id(), time()-3600, '/');
1172 jp_milcent 81
		// Destruction du cookie de permanence de l'identitification de Papyrus
82
		setcookie($cookie_persistant_nom, '', time()-3600, '/');
83
		//$GLOBALS['_GEN_commun']['pear_auth']->start();
84
    } else {
85
    	if (isset($_REQUEST['connexion'])) {
86
	    	// Si un formulaire nous renvoie en POST une variable "connexion", nous logons l'utilisateur.
87
			// Nous vérifions que l'utilisateur est coché "Mémoriser mon compte"
88
			if (isset($_POST['persistant']) && $_POST['persistant'] == 'o' && IDEN_AUTH_SESSION_DUREE != 0) {
89
		        // Expiration si l'utilisateur ne referme pas son navigateur
90
				$GLOBALS['_GEN_commun']['pear_auth']->setExpire((int)IDEN_AUTH_SESSION_DUREE);
91
				// Création d'un cookie pour rendre permanente l'identification de Papyrus
92
				$cookie_val = md5($_POST['password']).$_POST['username'];
93
				setcookie($cookie_persistant_nom, $cookie_val, (int)IDEN_AUTH_SESSION_DUREE, '/');
94
			}
95
	    } else if (isset($_COOKIE[$cookie_persistant_nom])) {
96
			// Si un cookie existe, nous loggons l'utilisateur.
97
			$GLOBALS['_GEN_commun']['pear_auth']->password = substr($_COOKIE[$cookie_persistant_nom], 0, 32 );
98
			$GLOBALS['_GEN_commun']['pear_auth']->username = substr($_COOKIE[$cookie_persistant_nom], 32);
99
			// Nous sommes obligés de crypter le mot de passe
1176 jp_milcent 100
			if (isset($GLOBALS['_GEN_commun']['pear_auth']->storage_options)) {
1172 jp_milcent 101
				$GLOBALS['_GEN_commun']['pear_auth']->storage_options['cryptType'] = 'none';
1176 jp_milcent 102
    		}
103
    		if (isset($GLOBALS['_GEN_commun']['pear_auth']->storage->options)) {
1172 jp_milcent 104
				$GLOBALS['_GEN_commun']['pear_auth']->storage->options['cryptType'] = 'none';
105
			}
1176 jp_milcent 106
 
1090 florian 107
		}
1172 jp_milcent 108
		$GLOBALS['_GEN_commun']['pear_auth']->login();
1176 jp_milcent 109
		//echo '<pre>'.print_r($GLOBALS['_GEN_commun']['pear_auth'], true).'</pre>';
1172 jp_milcent 110
    }
1090 florian 111
}
112
 
113
// +------------------------------------------------------------------------------------------------------+
114
// |                                           LISTE de FONCTIONS                                         |
115
// +------------------------------------------------------------------------------------------------------+
116
 
117
/** Fonction afficherFormIdentification() - Retourne une formulaire pour s'identifier.
118
*
119
* Retourne un formulaire d'identificatin ou de déconnexion suivant que l'utilisateur est
120
* identifié ou pas.
121
*
122
* @param  array  tableau d'éventuel arguments présent dans la balise transmis à la fonction.
123
* @param  array  tableau global de Papyrus.
124
* @return string formulaire de connexion ou de déconnexion.
125
*/
126
function afficherFormIdentification($tab_arguments, $_GEN_commun)
127
{
1606 alexandre_ 128
    // Extraction des arguments s il y a
129
    $balise = $tab_arguments[0];
130
    $tab_arguments = $tab_arguments;
131
	unset($tab_arguments[0]);
132
    foreach($tab_arguments as $argument) {
133
    	if ($argument != '') {
134
	    	$tab_parametres = explode('=', $argument, 2);
135
	    	if (isset($tab_parametres[1])) $options[$tab_parametres[0]] = trim($tab_parametres[1], '"');
136
    	}
137
    }
138
    if (!isset($options['template'])) {
139
    	$options['template'] = IDEN_CHEMIN_APPLETTE.'squelettes/'.IDEN_SQUELETTE_DEFAUT;
140
    }
315 jpm 141
    // Initialisation de variable.
1090 florian 142
    $retour = '';
143
    $objet_pear_auth =& $_GEN_commun['pear_auth'];
144
    $objet_pear_db =& $_GEN_commun['pear_db'];
145
    $InfoAuthBdd =& $_GEN_commun['info_auth_bdd'];
146
    $objet_url =& $_GEN_commun['url'];
147
    $url = $objet_url->getURL();
1649 florian 148
    $objet_url->addQueryString('logout', 1);
149
    $url_deconnect = $objet_url->getURL();
150
    $objet_url->removeQueryString('logout');
1090 florian 151
    // Récupération des valeurs pour le login et le mot de passe
152
    $mot_de_passe = (! isset($_POST['password']))    ? '' : $_POST['password'];
153
    $login        = (! isset($_POST['username']))    ? '' : $_POST['username'];
154
 
155
    // ATTENTION : Partie à supprimer une fois les mise à jour effectué dans l'annuaire de Tela Botanica
156
    // Devrait être déplacer dans l'appli inscription de Tela.
157
    if (isset($InfoAuthBdd->gsab_nom_table) && $InfoAuthBdd->gsab_nom_table == 'annuaire_tela') {
51 jpm 158
        verification_mot_de_passe($objet_pear_db, $mot_de_passe, $login);
159
        if (isset($_POST['connexion'])) {
304 jpm 160
            $objet_pear_auth->login();
1090 florian 161
        }
162
    }
1606 alexandre_ 163
 
1649 florian 164
	// L'utilisateur a essayé de s'identifier mais a échoué
165
	if ($login != '') {
166
		$retour .= '<span class="erreur">'.IDEN_ECHEC_AUTH ;
167
		$url_erreur = '#';
168
		if (isset($InfoAuthBdd->url_erreur)) {
169
			$url_erreur = $InfoAuthBdd->url_erreur;
170
		} else if (isset($InfoAuthBdd->url_inscription)) {
171
			$url_erreur = $InfoAuthBdd->url_inscription;
172
		}
173
		$retour .= '<a id="lien_inscription" href="'.$url_erreur.'">'.IDEN_ICI.'</a>' ;
174
		$retour .= '</span>'."\n";
175
	}
176
	$url_inscription_aide = '';
177
	$url_page_inscription = '';
178
	$url_page_modif_inscription = '';
179
	if (isset($InfoAuthBdd->url_inscription)) {
180
    	$url_page_inscription = $InfoAuthBdd->url_inscription;
181
	}
182
	if (isset($InfoAuthBdd->url_inscription_modif)) {
183
    	$url_page_modif_inscription = $InfoAuthBdd->url_inscription_modif;
184
	}
185
	if (isset($InfoAuthBdd->url_inscription_aide)) {
186
		$url_inscription_aide = $InfoAuthBdd->url_inscription_aide;
187
	}
188
	$chp_personne_prenom='';
189
    if (isset($InfoAuthBdd->chp_personne_prenom)) {
190
        $chp_personne_prenom = $objet_pear_auth->getAuthData($InfoAuthBdd->chp_personne_prenom);
1090 florian 191
    }
1649 florian 192
    $chp_personne_nom='';
193
    if (isset($InfoAuthBdd->chp_personne_nom)) {
194
    	$chp_personne_nom = $objet_pear_auth->getAuthData($InfoAuthBdd->chp_personne_nom);
195
    }
196
    $chp_structure='';
197
    if (isset($InfoAuthBdd->chp_structure_nom)) {
198
    	$chp_structure = $objet_pear_auth->getAuthData($InfoAuthBdd->chp_structure_nom);
199
    }
200
    if ($objet_pear_auth->getAuth()) { $loggue = true; } else { $loggue = false; }
201
 
202
	ob_start();
203
	include_once $options['template'];
204
	$retour = ob_get_contents();
205
	// Arrete et detruit le buffer
206
	ob_end_clean();
207
 
1090 florian 208
    return $retour;
209
}
210
 
211
// +------------------------------------------------------------------------------------------------------+
212
// |                                            PIED du PROGRAMME                                         |
213
// +------------------------------------------------------------------------------------------------------+
214
 
215
 
216
 
217
/* +--Fin du code ----------------------------------------------------------------------------------------+
218
*
4 jpm 219
* $Log: not supported by cvs2svn $
1649 florian 220
* Revision 1.34  2007-09-18 08:40:54  alexandre_tb
221
* modification de la balise identification pour permettre de preciser un template.
222
*
1606 alexandre_ 223
* Revision 1.33  2007-08-28 14:23:35  jp_milcent
224
* Amélioration de la gestion des mots de passe perdus.
225
*
1562 jp_milcent 226
* Revision 1.32  2007-08-28 14:14:35  jp_milcent
227
* Ajout de la gestion des erreurs d'identification.
228
*
1561 jp_milcent 229
* Revision 1.31  2006-12-15 14:49:47  jp_milcent
230
* Correction bogue : le type de cryptage est stocké à 2 endroits...
231
*
1176 jp_milcent 232
* Revision 1.30  2006/12/14 15:01:05  jp_milcent
233
* Utilisation d'un système permettant de mémoriser les idenitifications.
234
* Passage à Auth 1.4.3 et DB 1.7.6.
235
*
1172 jp_milcent 236
* Revision 1.29  2006/12/12 13:53:54  jp_milcent
237
* Mise en place du nouveau format des balises d'applette.
238
*
1145 jp_milcent 239
* Revision 1.28  2006/12/12 13:26:42  jp_milcent
240
* Modification de la gestion de l'identification. Utilisation des variables de session.
241
*
1140 jp_milcent 242
* Revision 1.27  2006/12/08 18:14:57  jp_milcent
243
* Correction bogue : l'identification ne tenait pas...
244
*
1123 jp_milcent 245
* Revision 1.26  2006/12/01 16:33:40  florian
246
* Amélioration de la gestion des applettes et compatibilité avec le nouveau mode de gestion de l'inclusion des applettes.
247
*
1090 florian 248
* Revision 1.25  2006/11/20 18:40:33  jp_milcent
249
* Amélioration de la gestion des infos sur l'inscription.
250
* Ajout du paramêtre url_inscription_aide permettant d'indiquer l'url vers une page d'aide sur l'inscription.
251
*
1059 jp_milcent 252
* Revision 1.24  2006/11/20 17:42:40  jp_milcent
253
* Ajout d'un test activant ou pas la mémorisation de l'identification.
254
*
1056 jp_milcent 255
* Revision 1.23  2006/11/20 17:30:40  jp_milcent
256
* Amélioration de la gestion de l'identification.
257
* Utilisation des durées de session correcte.
258
* Suppression du code pour Spip non fonctionnel.
259
*
1055 jp_milcent 260
* Revision 1.22  2006/09/21 15:25:17  jp_milcent
261
* Nettoyage dans l'url de la querystring logout.
262
*
959 jp_milcent 263
* Revision 1.21  2006/03/02 10:49:49  ddelon
264
* Fusion branche multilinguisme dans branche principale
265
*
754 ddelon 266
* Revision 1.20  2005/12/13 11:13:35  alexandre_tb
267
* ajout d'un message si l'identification échoue
268
*
269
* Revision 1.19.2.1  2005/12/20 14:40:24  ddelon
270
* Fusion Head vers Livraison
271
*
272
* Revision 1.20  2005/12/13 11:13:35  alexandre_tb
273
* ajout d'un message si l'identification échoue
274
*
666 alexandre_ 275
* Revision 1.19  2005/10/31 17:09:28  ddelon
276
* Suppression auth start suite à deconnexion ... attention aux effets de bord
277
*
578 ddelon 278
* Revision 1.18  2005/09/27 09:07:32  ddelon
279
* size applette et squelettes
280
*
467 ddelon 281
* Revision 1.17  2005/09/12 09:17:17  alexandre_tb
282
* utilisation de l'objet Net_URL pour ajouter la variable logout dans le lien de déconnexion
283
*
441 alexandre_ 284
* Revision 1.16  2005/06/09 17:06:28  jpm
285
* Ajout de constantes de langue.
286
*
399 jpm 287
* Revision 1.15  2005/06/02 11:56:00  jpm
288
* Modification de l'affichage de l'identification.
289
*
388 jpm 290
* Revision 1.14  2005/05/19 14:00:58  jpm
291
* Déplacement du menu de modif de l'inscription.
292
*
369 jpm 293
* Revision 1.13  2005/04/14 16:37:22  jpm
294
* Ajout de la gestion de la modification de son inscription.
295
*
337 jpm 296
* Revision 1.12  2005/03/25 14:40:51  jpm
297
* Prise en compte du paramêtre url_inscription permettant de faire figurer dans l'applette inscription un lien vers la page d'inscription.
298
*
315 jpm 299
* Revision 1.11  2005/03/17 15:52:17  jpm
300
* Suppression d'un / causant un bogue.
301
*
309 jpm 302
* Revision 1.10  2005/03/15 14:47:14  jpm
303
* Utilisation d'un lien à la place d'un formulaire pour la déconnexion.
304
*
308 jpm 305
* Revision 1.9  2005/03/15 14:17:46  jpm
306
* Ajout d'un fichier de config et de traduction.
307
* Début gestion des constantes de langue.
308
*
304 jpm 309
* Revision 1.8  2005/03/10 12:50:44  alex
310
* remplacement de & par  &amp;
311
*
303 alex 312
* Revision 1.7  2005/01/07 12:43:03  alex
313
* réauction de la taille des champs texte à 12
314
*
246 alex 315
* Revision 1.6  2004/12/13 18:07:09  alex
316
* désauthentification spip presque parfaite
317
*
228 alex 318
* Revision 1.5  2004/09/23 14:31:12  jpm
319
* Correction bogue sur l'identification de l'annuaire_tela.
320
*
51 jpm 321
* Revision 1.4  2004/09/23 10:53:44  jpm
322
* Suppression de l'attribut size. Gestion via les css.
323
*
49 jpm 324
* Revision 1.3  2004/06/28 10:18:48  alex
325
* suppression de balises <p>
326
*
20 alex 327
* Revision 1.2  2004/06/21 07:37:30  alex
328
* Modification d'un label
329
*
17 alex 330
* Revision 1.1  2004/06/15 15:01:41  jpm
331
* Changement de nom et d'arborescence de Genesia en Papyrus.
332
*
4 jpm 333
* Revision 1.5  2004/05/05 06:44:15  jpm
334
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
1090 florian 335
*
336
* Revision 1.4  2004/05/03 11:18:55  jpm
337
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
338
*
339
* Revision 1.3  2004/05/01 17:21:16  jpm
340
* Ajout d'un fieldset et d'une légende au formulaire.
341
*
342
* Revision 1.2  2004/05/01 16:13:07  jpm
343
* Ajout du nom de la balise de l'applette dans le code de l'applette.
344
*
345
* Revision 1.1  2004/05/01 11:42:01  jpm
346
* Ajout de l'applette identification.
347
*
348
*
349
* +-- Fin du code ----------------------------------------------------------------------------------------+
350
*/
4 jpm 351
?>