Subversion Repositories Applications.papyrus

Rev

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

Rev Author Line No. Line
4 jpm 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
// +------------------------------------------------------------------------------------------------------+
754 ddelon 22
// CVS : $Id: identification.php,v 1.21 2006-03-02 10:49:49 ddelon Exp $
4 jpm 23
/**
24
* Applette : identification
25
*
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
17 alex 31
*
32
* A faire : remplacer le formulaire par un QuickForm
4 jpm 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
754 ddelon 41
*@version       $Revision: 1.21 $ $Date: 2006-03-02 10:49:49 $
4 jpm 42
// +------------------------------------------------------------------------------------------------------+
43
*/
44
 
45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            ENTÊTE du PROGRAMME                                       |
47
// +------------------------------------------------------------------------------------------------------+
48
$_GEN_commun['info_applette_nom_fonction'] = 'afficherFormIdentification';
49
$_GEN_commun['info_applette_balise'] = 'IDENTIFICATION';
304 jpm 50
 
51
/** Inclusion du fichier de configuration de cette applette.*/
52
require_once GEN_CHEMIN_APPLETTE.'identification/configuration/iden_config.inc.php';
53
 
54
// Inclusion des fichiers de traduction de l'applette.
55
if (file_exists(IDEN_CHEMIN_LANGUE.'iden_langue_'.$_GEN_commun['i18n'].'.inc.php')) {
56
    /** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
57
    require_once IDEN_CHEMIN_LANGUE.'iden_langue_'.$_GEN_commun['i18n'].'.inc.php';
58
} else {
59
    /** Inclusion du fichier de traduction par défaut.*/
60
    require_once IDEN_CHEMIN_LANGUE.'iden_langue_'.IDEN_I18N_DEFAUT.'.inc.php';
61
}
4 jpm 62
// +------------------------------------------------------------------------------------------------------+
63
// |                                            CORPS du PROGRAMME                                        |
64
// +------------------------------------------------------------------------------------------------------+
65
 
66
// Si le site utilise une authentification.
67
if ($_GEN_commun['info_auth']->gsa_ce_type_auth == 1) {
68
    // Si un formulaire nous renvoie en POST une variable "deconnexion", nous délogons l'utilisateur.
304 jpm 69
    if (isset($_REQUEST['deconnexion']) || isset($_REQUEST['logout'])) {
228 alex 70
        $_GEN_commun['pear_auth']->logout();
71
        // Le test suivant vérifie si une authentification SPIP est en cour, vois pap_initialise_auth.inc.php
72
        if (isset ($chemin_spip) && isset ($coauth) && $coauth == $auth_courante['gsab_id_auth_bdd']) {
73
            // On place un cookie avec une duré dépassée
74
            setcookie("spip_session", $id_session, time() - 3600*24, "/$chemin_cookie_spip/") ;
75
            setcookie("spip_admin", "@".$login, time() -3600*24, "/$chemin_cookie_spip/") ;
76
 
399 jpm 77
            $dirname = $GLOBALS['flag_ecrire'] ? 'data/' : 'ecrire/data/';
228 alex 78
            $dirname = $chemin_spip."/".$dirname ;
79
             // ne pas se zapper soi-meme
80
            if ($s = $GLOBALS['spip_session'])
81
                   $fichier_session = fichier_session($s, lire_meta('alea_ephemere'));
399 jpm 82
                $fichier_session = $chemin_spip.'/ecrire/'.$fichier_session ;
228 alex 83
            $dir = opendir($dirname);
84
            $t = time();
85
            while(($item = readdir($dir)) != '') {
86
                $chemin = "$dirname$item";
87
                if (ereg("^session_([0-9]+_)?([a-z0-9]+)\.php3$", $item, $regs)) {
88
                // Si c'est une vieille session, on jette
89
                    if (($t - filemtime($chemin)) > 48 * 3600) unlink($chemin);
90
                    // sinon voir si c'est une session du meme auteur
91
                        else if ($regs[1] == $id_auteur.'_') {
92
                            $zap_num ++;
93
                    if ($zap) unlink($chemin);
94
                    }
95
                }
96
            }
97
        }
4 jpm 98
    }
99
    // Si un formulaire nous renvoie en POST une variable "connexion", nous logons l'utilisateur.
304 jpm 100
    if (isset($_REQUEST['connexion'])) {
4 jpm 101
        $_GEN_commun['pear_auth']->login();
102
        $_SESSION['username'] = $username;
103
    }
104
}
105
 
106
// +------------------------------------------------------------------------------------------------------+
107
// |                                           LISTE de FONCTIONS                                         |
108
// +------------------------------------------------------------------------------------------------------+
109
 
110
/** Fonction afficherFormIdentification() - Retourne une formulaire pour s'identifier.
111
*
112
* Retourne un formulaire d'identificatin ou de déconnexion suivant que l'utilisateur est
113
* identifié ou pas.
114
*
115
* @param  array  tableau d'éventuel arguments présent dans la balise transmis à la fonction.
116
* @param  array  tableau global de Papyrus.
117
* @return string formulaire de connexion ou de déconnexion.
118
*/
304 jpm 119
function afficherFormIdentification($tab_arguments, &$_GEN_commun)
4 jpm 120
{
315 jpm 121
    // Initialisation de variable.
122
    $retour = '';
304 jpm 123
    $objet_pear_auth =& $GLOBALS['_GEN_commun']['pear_auth'];
124
    $objet_pear_db =& $GLOBALS['_GEN_commun']['pear_db'];
125
    $url = $GLOBALS['_GEN_commun']['url']->getURL();
441 alexandre_ 126
    $objet_url = $GLOBALS['_GEN_commun']['url'] ;
4 jpm 127
    // Récupération des valeurs pour le login et le mot de passe
128
    $mot_de_passe = (! isset($_POST['password']))    ? '' : $_POST['password'];
129
    $login        = (! isset($_POST['username']))    ? '' : $_POST['username'];
130
 
131
    // ATTENTION : Partie à supprimer une fois les mise à jour effectué dans l'annuaire de Tela Botanica
132
    // Devrait être déplacer dans l'appli inscription de Tela.
304 jpm 133
    if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->gsab_nom_table) && $GLOBALS['_GEN_commun']['info_auth_bdd']->gsab_nom_table == 'annuaire_tela') {
51 jpm 134
        verification_mot_de_passe($objet_pear_db, $mot_de_passe, $login);
135
        if (isset($_POST['connexion'])) {
304 jpm 136
            $objet_pear_auth->login();
51 jpm 137
        }
4 jpm 138
    }
139
 
140
    if (! $objet_pear_auth->getAuth()) {
666 alexandre_ 141
    	// L'utilisateur a essayé de s'identifier mais a échoué
142
    	if (isset($_POST['username'])) {
143
    		$retour .= '<span class="erreur">'.IDEN_ECHEC_AUTH ;
144
    		if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription)) {
145
    			$retour .= '<a id="lien_inscription" href="'.$GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription.'">' ;
146
    			$retour .= IDEN_ICI.'</a>' ;
147
    		}
148
    		$retour .= '</span>' ;
149
    	}
388 jpm 150
        // L'utilisateur n'est pas identifié:
315 jpm 151
        $retour .= str_repeat(' ', 16).'<form id="form_connexion" class="form_identification" action="'.$url.'" method="post">'."\n";
304 jpm 152
        $retour .= str_repeat(' ', 16).'<fieldset>'."\n";
399 jpm 153
        $retour .= str_repeat(' ', 20).'<legend>'.IDEN_LG_FORM_LEGEND.'</legend>'."\n";
304 jpm 154
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 155
        $retour .= str_repeat(' ', 24).'<label for="username">'.IDEN_LG_FORM_LABEL_COURRIEL.'</label>'."\n";
467 ddelon 156
        $retour .= str_repeat(' ', 24).'<input type="text"  id="username" name="username" maxlength="80" tabindex="1" value="'.IDEN_LG_FORM_VALUE_COURRIEL.'" />'."\n";
304 jpm 157
        $retour .= str_repeat(' ', 20).''."\n";
158
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 159
        $retour .= str_repeat(' ', 24).'<label for="password">'.IDEN_LG_FORM_LABEL_MDP.'</label>'."\n";
467 ddelon 160
        $retour .= str_repeat(' ', 24).'<input type="password" id="password" name="password" maxlength="80" tabindex="2" value="'.IDEN_LG_FORM_VALUE_MDP.'" />'."\n";
304 jpm 161
        $retour .= str_repeat(' ', 20).''."\n";
162
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 163
        $retour .= str_repeat(' ', 24).'<input type="submit" id="connexion" name="connexion" tabindex="3" value="'.IDEN_LG_FORM_VALUE_SUBMIT.'" />'."\n";
388 jpm 164
        $retour .= str_repeat(' ', 20).''."\n";
165
        // Si l'url de la page d'inscription est stockée dans les paramêtres, nous l'affichons
166
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription)) {
167
            $retour .=  '<p><a id="lien_inscription" href="'.$GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription.'">'.
168
                        IDEN_LG_INSCRIPTION_URL.
169
                        '</a></p>'."\n";
170
        }
304 jpm 171
        $retour .= str_repeat(' ', 16).'</fieldset>'."\n";
172
        $retour .= str_repeat(' ', 16).'</form>';
4 jpm 173
    } else {
308 jpm 174
        // L'utilisateur est identifié. Nous affichons ses informations.
304 jpm 175
        // Affichage du prénom et nom d'une personne ou du nom de la structure en fonction des paramêtres
176
        // de l'annuaire utilisé
337 jpm 177
        $retour .= str_repeat(' ', 16).'<p id="identification_info"><span id="identification_message">'.IDEN_LG_MESSAGE.'</span> ';
315 jpm 178
        // Si les intitulés des champs nom et prénoms d'une personne ou le nom d'une structure sont indiqués nous les affichons
304 jpm 179
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_prenom) && isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_nom)) {
180
            $retour .=  '<span id="identification_prenom">'.
181
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_prenom).
182
                        '</span> '.
183
                        '<span id="identification_nom">'.
184
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_nom).
185
                        '</span>';
186
        } elseif (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_structure_nom)) {
187
            $retour .=  '<span id="identification_structure">'.
188
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_structure_nom).
189
                        '</span>';
190
        }
191
        $retour .= '</p>'."\n";
369 jpm 192
        $retour .= str_repeat(' ', 16).'<p id="iden_action">'."\n";
193
        // Si l'url de la page de modification de l'inscription est stockée dans les paramêtres, nous l'affichons
194
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription_modif)) {
195
            $retour .=  str_repeat(' ', 20).'<a id="lien_inscription_modif" href="'.
196
                        $GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription_modif.'">'.
197
                        IDEN_LG_INSCRIPTION_URL_MODIF.
198
                        '</a>'."\n";
199
        }
304 jpm 200
        // Affichage du bouton de déconnexion
441 alexandre_ 201
        $objet_url->addQueryString('logout', 1) ;
202
        $retour .= str_repeat(' ', 20).'<a id="deconnexion" href="'.$objet_url->getURL().'">'.IDEN_LG_DECONNEXION.'</a>'."\n";
308 jpm 203
        $retour .= str_repeat(' ', 16).'</p>'."\n";
4 jpm 204
    }
304 jpm 205
    return $retour;
4 jpm 206
}
207
 
208
// +------------------------------------------------------------------------------------------------------+
209
// |                                            PIED du PROGRAMME                                         |
210
// +------------------------------------------------------------------------------------------------------+
211
 
212
 
213
 
214
/* +--Fin du code ----------------------------------------------------------------------------------------+
215
*
216
* $Log: not supported by cvs2svn $
754 ddelon 217
* Revision 1.20  2005/12/13 11:13:35  alexandre_tb
218
* ajout d'un message si l'identification échoue
219
*
220
* Revision 1.19.2.1  2005/12/20 14:40:24  ddelon
221
* Fusion Head vers Livraison
222
*
223
* Revision 1.20  2005/12/13 11:13:35  alexandre_tb
224
* ajout d'un message si l'identification échoue
225
*
666 alexandre_ 226
* Revision 1.19  2005/10/31 17:09:28  ddelon
227
* Suppression auth start suite à deconnexion ... attention aux effets de bord
228
*
578 ddelon 229
* Revision 1.18  2005/09/27 09:07:32  ddelon
230
* size applette et squelettes
231
*
467 ddelon 232
* Revision 1.17  2005/09/12 09:17:17  alexandre_tb
233
* utilisation de l'objet Net_URL pour ajouter la variable logout dans le lien de déconnexion
234
*
441 alexandre_ 235
* Revision 1.16  2005/06/09 17:06:28  jpm
236
* Ajout de constantes de langue.
237
*
399 jpm 238
* Revision 1.15  2005/06/02 11:56:00  jpm
239
* Modification de l'affichage de l'identification.
240
*
388 jpm 241
* Revision 1.14  2005/05/19 14:00:58  jpm
242
* Déplacement du menu de modif de l'inscription.
243
*
369 jpm 244
* Revision 1.13  2005/04/14 16:37:22  jpm
245
* Ajout de la gestion de la modification de son inscription.
246
*
337 jpm 247
* Revision 1.12  2005/03/25 14:40:51  jpm
248
* Prise en compte du paramêtre url_inscription permettant de faire figurer dans l'applette inscription un lien vers la page d'inscription.
249
*
315 jpm 250
* Revision 1.11  2005/03/17 15:52:17  jpm
251
* Suppression d'un / causant un bogue.
252
*
309 jpm 253
* Revision 1.10  2005/03/15 14:47:14  jpm
254
* Utilisation d'un lien à la place d'un formulaire pour la déconnexion.
255
*
308 jpm 256
* Revision 1.9  2005/03/15 14:17:46  jpm
257
* Ajout d'un fichier de config et de traduction.
258
* Début gestion des constantes de langue.
259
*
304 jpm 260
* Revision 1.8  2005/03/10 12:50:44  alex
261
* remplacement de & par  &amp;
262
*
303 alex 263
* Revision 1.7  2005/01/07 12:43:03  alex
264
* réauction de la taille des champs texte à 12
265
*
246 alex 266
* Revision 1.6  2004/12/13 18:07:09  alex
267
* désauthentification spip presque parfaite
268
*
228 alex 269
* Revision 1.5  2004/09/23 14:31:12  jpm
270
* Correction bogue sur l'identification de l'annuaire_tela.
271
*
51 jpm 272
* Revision 1.4  2004/09/23 10:53:44  jpm
273
* Suppression de l'attribut size. Gestion via les css.
274
*
49 jpm 275
* Revision 1.3  2004/06/28 10:18:48  alex
276
* suppression de balises <p>
277
*
20 alex 278
* Revision 1.2  2004/06/21 07:37:30  alex
279
* Modification d'un label
280
*
17 alex 281
* Revision 1.1  2004/06/15 15:01:41  jpm
282
* Changement de nom et d'arborescence de Genesia en Papyrus.
283
*
4 jpm 284
* Revision 1.5  2004/05/05 06:44:15  jpm
285
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
286
*
287
* Revision 1.4  2004/05/03 11:18:55  jpm
288
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
289
*
290
* Revision 1.3  2004/05/01 17:21:16  jpm
291
* Ajout d'un fieldset et d'une légende au formulaire.
292
*
293
* Revision 1.2  2004/05/01 16:13:07  jpm
294
* Ajout du nom de la balise de l'applette dans le code de l'applette.
295
*
296
* Revision 1.1  2004/05/01 11:42:01  jpm
297
* Ajout de l'applette identification.
298
*
299
*
300
* +-- Fin du code ----------------------------------------------------------------------------------------+
301
*/
302
?>