Subversion Repositories Applications.papyrus

Rev

Rev 399 | 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
// +------------------------------------------------------------------------------------------------------+
441 alexandre_ 22
// CVS : $Id: identification.php,v 1.17 2005-09-12 09:17:17 alexandre_tb 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
441 alexandre_ 41
*@version       $Revision: 1.17 $ $Date: 2005-09-12 09:17:17 $
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
        $_GEN_commun['pear_auth']->start();
99
    }
100
    // Si un formulaire nous renvoie en POST une variable "connexion", nous logons l'utilisateur.
304 jpm 101
    if (isset($_REQUEST['connexion'])) {
4 jpm 102
        $_GEN_commun['pear_auth']->login();
103
        $_SESSION['username'] = $username;
104
    }
105
}
106
 
107
// +------------------------------------------------------------------------------------------------------+
108
// |                                           LISTE de FONCTIONS                                         |
109
// +------------------------------------------------------------------------------------------------------+
110
 
111
/** Fonction afficherFormIdentification() - Retourne une formulaire pour s'identifier.
112
*
113
* Retourne un formulaire d'identificatin ou de déconnexion suivant que l'utilisateur est
114
* identifié ou pas.
115
*
116
* @param  array  tableau d'éventuel arguments présent dans la balise transmis à la fonction.
117
* @param  array  tableau global de Papyrus.
118
* @return string formulaire de connexion ou de déconnexion.
119
*/
304 jpm 120
function afficherFormIdentification($tab_arguments, &$_GEN_commun)
4 jpm 121
{
315 jpm 122
    // Initialisation de variable.
123
    $retour = '';
304 jpm 124
    $objet_pear_auth =& $GLOBALS['_GEN_commun']['pear_auth'];
125
    $objet_pear_db =& $GLOBALS['_GEN_commun']['pear_db'];
126
    $url = $GLOBALS['_GEN_commun']['url']->getURL();
441 alexandre_ 127
    $objet_url = $GLOBALS['_GEN_commun']['url'] ;
4 jpm 128
    // Récupération des valeurs pour le login et le mot de passe
129
    $mot_de_passe = (! isset($_POST['password']))    ? '' : $_POST['password'];
130
    $login        = (! isset($_POST['username']))    ? '' : $_POST['username'];
131
 
132
    // ATTENTION : Partie à supprimer une fois les mise à jour effectué dans l'annuaire de Tela Botanica
133
    // Devrait être déplacer dans l'appli inscription de Tela.
304 jpm 134
    if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->gsab_nom_table) && $GLOBALS['_GEN_commun']['info_auth_bdd']->gsab_nom_table == 'annuaire_tela') {
51 jpm 135
        verification_mot_de_passe($objet_pear_db, $mot_de_passe, $login);
136
        if (isset($_POST['connexion'])) {
304 jpm 137
            $objet_pear_auth->login();
51 jpm 138
        }
4 jpm 139
    }
140
 
141
    if (! $objet_pear_auth->getAuth()) {
388 jpm 142
        // L'utilisateur n'est pas identifié:
315 jpm 143
        $retour .= str_repeat(' ', 16).'<form id="form_connexion" class="form_identification" action="'.$url.'" method="post">'."\n";
304 jpm 144
        $retour .= str_repeat(' ', 16).'<fieldset>'."\n";
399 jpm 145
        $retour .= str_repeat(' ', 20).'<legend>'.IDEN_LG_FORM_LEGEND.'</legend>'."\n";
304 jpm 146
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 147
        $retour .= str_repeat(' ', 24).'<label for="username">'.IDEN_LG_FORM_LABEL_COURRIEL.'</label>'."\n";
148
        $retour .= str_repeat(' ', 24).'<input type="text" size="12" id="username" name="username" maxlength="80" tabindex="1" value="'.IDEN_LG_FORM_VALUE_COURRIEL.'" />'."\n";
304 jpm 149
        $retour .= str_repeat(' ', 20).''."\n";
150
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 151
        $retour .= str_repeat(' ', 24).'<label for="password">'.IDEN_LG_FORM_LABEL_MDP.'</label>'."\n";
152
        $retour .= str_repeat(' ', 24).'<input type="password" size="12" id="password" name="password" maxlength="80" tabindex="2" value="'.IDEN_LG_FORM_VALUE_MDP.'" />'."\n";
304 jpm 153
        $retour .= str_repeat(' ', 20).''."\n";
154
        $retour .= str_repeat(' ', 20).''."\n";
399 jpm 155
        $retour .= str_repeat(' ', 24).'<input type="submit" id="connexion" name="connexion" tabindex="3" value="'.IDEN_LG_FORM_VALUE_SUBMIT.'" />'."\n";
388 jpm 156
        $retour .= str_repeat(' ', 20).''."\n";
157
        // Si l'url de la page d'inscription est stockée dans les paramêtres, nous l'affichons
158
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription)) {
159
            $retour .=  '<p><a id="lien_inscription" href="'.$GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription.'">'.
160
                        IDEN_LG_INSCRIPTION_URL.
161
                        '</a></p>'."\n";
162
        }
304 jpm 163
        $retour .= str_repeat(' ', 16).'</fieldset>'."\n";
164
        $retour .= str_repeat(' ', 16).'</form>';
4 jpm 165
    } else {
308 jpm 166
        // L'utilisateur est identifié. Nous affichons ses informations.
304 jpm 167
        // Affichage du prénom et nom d'une personne ou du nom de la structure en fonction des paramêtres
168
        // de l'annuaire utilisé
337 jpm 169
        $retour .= str_repeat(' ', 16).'<p id="identification_info"><span id="identification_message">'.IDEN_LG_MESSAGE.'</span> ';
315 jpm 170
        // 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 171
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_prenom) && isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_nom)) {
172
            $retour .=  '<span id="identification_prenom">'.
173
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_prenom).
174
                        '</span> '.
175
                        '<span id="identification_nom">'.
176
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_personne_nom).
177
                        '</span>';
178
        } elseif (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_structure_nom)) {
179
            $retour .=  '<span id="identification_structure">'.
180
                        $objet_pear_auth->getAuthData($GLOBALS['_GEN_commun']['info_auth_bdd']->chp_structure_nom).
181
                        '</span>';
182
        }
183
        $retour .= '</p>'."\n";
369 jpm 184
        $retour .= str_repeat(' ', 16).'<p id="iden_action">'."\n";
185
        // Si l'url de la page de modification de l'inscription est stockée dans les paramêtres, nous l'affichons
186
        if (isset($GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription_modif)) {
187
            $retour .=  str_repeat(' ', 20).'<a id="lien_inscription_modif" href="'.
188
                        $GLOBALS['_GEN_commun']['info_auth_bdd']->url_inscription_modif.'">'.
189
                        IDEN_LG_INSCRIPTION_URL_MODIF.
190
                        '</a>'."\n";
191
        }
304 jpm 192
        // Affichage du bouton de déconnexion
441 alexandre_ 193
        $objet_url->addQueryString('logout', 1) ;
194
        $retour .= str_repeat(' ', 20).'<a id="deconnexion" href="'.$objet_url->getURL().'">'.IDEN_LG_DECONNEXION.'</a>'."\n";
308 jpm 195
        $retour .= str_repeat(' ', 16).'</p>'."\n";
4 jpm 196
    }
304 jpm 197
    return $retour;
4 jpm 198
}
199
 
200
// +------------------------------------------------------------------------------------------------------+
201
// |                                            PIED du PROGRAMME                                         |
202
// +------------------------------------------------------------------------------------------------------+
203
 
204
 
205
 
206
/* +--Fin du code ----------------------------------------------------------------------------------------+
207
*
208
* $Log: not supported by cvs2svn $
441 alexandre_ 209
* Revision 1.16  2005/06/09 17:06:28  jpm
210
* Ajout de constantes de langue.
211
*
399 jpm 212
* Revision 1.15  2005/06/02 11:56:00  jpm
213
* Modification de l'affichage de l'identification.
214
*
388 jpm 215
* Revision 1.14  2005/05/19 14:00:58  jpm
216
* Déplacement du menu de modif de l'inscription.
217
*
369 jpm 218
* Revision 1.13  2005/04/14 16:37:22  jpm
219
* Ajout de la gestion de la modification de son inscription.
220
*
337 jpm 221
* Revision 1.12  2005/03/25 14:40:51  jpm
222
* Prise en compte du paramêtre url_inscription permettant de faire figurer dans l'applette inscription un lien vers la page d'inscription.
223
*
315 jpm 224
* Revision 1.11  2005/03/17 15:52:17  jpm
225
* Suppression d'un / causant un bogue.
226
*
309 jpm 227
* Revision 1.10  2005/03/15 14:47:14  jpm
228
* Utilisation d'un lien à la place d'un formulaire pour la déconnexion.
229
*
308 jpm 230
* Revision 1.9  2005/03/15 14:17:46  jpm
231
* Ajout d'un fichier de config et de traduction.
232
* Début gestion des constantes de langue.
233
*
304 jpm 234
* Revision 1.8  2005/03/10 12:50:44  alex
235
* remplacement de & par  &amp;
236
*
303 alex 237
* Revision 1.7  2005/01/07 12:43:03  alex
238
* réauction de la taille des champs texte à 12
239
*
246 alex 240
* Revision 1.6  2004/12/13 18:07:09  alex
241
* désauthentification spip presque parfaite
242
*
228 alex 243
* Revision 1.5  2004/09/23 14:31:12  jpm
244
* Correction bogue sur l'identification de l'annuaire_tela.
245
*
51 jpm 246
* Revision 1.4  2004/09/23 10:53:44  jpm
247
* Suppression de l'attribut size. Gestion via les css.
248
*
49 jpm 249
* Revision 1.3  2004/06/28 10:18:48  alex
250
* suppression de balises <p>
251
*
20 alex 252
* Revision 1.2  2004/06/21 07:37:30  alex
253
* Modification d'un label
254
*
17 alex 255
* Revision 1.1  2004/06/15 15:01:41  jpm
256
* Changement de nom et d'arborescence de Genesia en Papyrus.
257
*
4 jpm 258
* Revision 1.5  2004/05/05 06:44:15  jpm
259
* Complément des commentaires indiquant les paquetages nécessaire à l'applette.
260
*
261
* Revision 1.4  2004/05/03 11:18:55  jpm
262
* Intégration de la variable globale de Génésia dans les arguments de la fonction de l'applette.
263
*
264
* Revision 1.3  2004/05/01 17:21:16  jpm
265
* Ajout d'un fieldset et d'une légende au formulaire.
266
*
267
* Revision 1.2  2004/05/01 16:13:07  jpm
268
* Ajout du nom de la balise de l'applette dans le code de l'applette.
269
*
270
* Revision 1.1  2004/05/01 11:42:01  jpm
271
* Ajout de l'applette identification.
272
*
273
*
274
* +-- Fin du code ----------------------------------------------------------------------------------------+
275
*/
276
?>