Subversion Repositories Applications.papyrus

Rev

Rev 575 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 575 Rev 603
Line 17... Line 17...
17
// |                                                                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
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                                  |
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                            |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
21
// +------------------------------------------------------------------------------------------------------+
22
// CVS : $Id: inscription.php,v 1.4 2005-10-25 14:02:21 alexandre_tb Exp $
22
// CVS : $Id: inscription.php,v 1.5 2005-11-17 18:48:02 florian Exp $
23
/**
23
/**
24
* Inscription
24
* Inscription
25
*
25
*
26
* Un module d'inscription, en général ce code est spécifique à
26
* Un module d'inscription, en général ce code est spécifique à
27
* un site web
27
* un site web
Line 30... Line 30...
30
//Auteur original :
30
//Auteur original :
31
*@author        Alexandre GRANIER <alexandre@tela-botanica.org>
31
*@author        Alexandre GRANIER <alexandre@tela-botanica.org>
32
//Autres auteurs :
32
//Autres auteurs :
33
*@author        Florian SCHMITT <florian@ecole-et-nature.org>
33
*@author        Florian SCHMITT <florian@ecole-et-nature.org>
34
*@copyright     Tela-Botanica 2000-2004
34
*@copyright     Tela-Botanica 2000-2004
35
*@version       $Revision: 1.4 $ $Date: 2005-10-25 14:02:21 $
35
*@version       $Revision: 1.5 $ $Date: 2005-11-17 18:48:02 $
36
// +------------------------------------------------------------------------------------------------------+
36
// +------------------------------------------------------------------------------------------------------+
37
*/
37
*/
Line 38... Line 38...
38
 
38
 
39
// +------------------------------------------------------------------------------------------------------+
39
// +------------------------------------------------------------------------------------------------------+
40
// |                                            ENTETE du PROGRAMME                                       |
40
// |                                            ENTETE du PROGRAMME                                       |
41
// +------------------------------------------------------------------------------------------------------+
41
// +------------------------------------------------------------------------------------------------------+
42
include_once 'configuration/bottin.config.inc.php';
-
 
43
if (!isset($GLOBALS['lang'])) {
-
 
44
    $GLOBALS['lang'] = INS_LANGUE_DEFAUT ;
-
 
45
}
-
 
46
include_once INS_CHEMIN_APPLI."langues/bottin_langue_".$GLOBALS['lang'].".inc.php" ;
-
 
47
include_once INS_CHEMIN_APPLI.'configuration/inscription.config.inc.php';
42
include_once 'configuration/bottin.config.inc.php';
48
include_once INS_CHEMIN_APPLI.'bibliotheque/inscription.fonct.php';
43
include_once INS_CHEMIN_APPLI.'bibliotheque/inscription.fonct.php';
49
include_once INS_CHEMIN_APPLI.'bibliotheque/inscription.class.php';
-
 
50
//test pour savoir si on est dans Papyrus
-
 
51
if (defined('PAP_VERSION')) {
-
 
52
	// Ajout d'une feuille de style externe
-
 
53
	GEN_stockerStyleExterne('inscription', INS_CHEMIN_APPLI.'presentations/inscription.css');
-
 
Line 54... Line 44...
54
}
44
include_once INS_CHEMIN_APPLI.'bibliotheque/inscription.class.php';
55
 
45
 
56
// +------------------------------------------------------------------------------------------------------+
46
// +------------------------------------------------------------------------------------------------------+
Line 57... Line 47...
57
// |                                           LISTE de FONCTIONS                                         |
47
// |                                           LISTE de FONCTIONS                                         |
58
// +------------------------------------------------------------------------------------------------------+
-
 
59
 
48
// +------------------------------------------------------------------------------------------------------+
60
 
49
 
61
function afficherContenuCorps() {
50
 
62
    $url = preg_replace ('/&amp;/', '&', $GLOBALS['ins_url']->getURL()) ;
51
function afficherContenuCorps() {
Line -... Line 52...
-
 
52
    $res = '<h1>'.INS_TITRE_INSCRIPTION.'</h1>'."\n" ;
63
    $res = '<h1>'.INS_TITRE_INSCRIPTION.'</h1>'."\n" ;
53
    if (!isset($_REQUEST['action'])) {
64
    if (!isset($_REQUEST['action'])) {
54
    	$_REQUEST['action']='';
65
	$_REQUEST['action']='';
55
    }
66
    }
56
    
67
    
57
//cas de la déconnexion----------------------------------------------------------------------------------
68
    if (isset ($_GET['logout']) && $_GET['logout'] == 1) {
58
    if ($_REQUEST['action'] == 'deconnexion') {
Line 69... Line 59...
69
        $GLOBALS['AUTH']->logout() ;
59
        $GLOBALS['AUTH']->logout() ;
70
        $_POST['username'] = '' ;
60
        $_POST['username'] = '' ;
71
        $_POST['password'] = '' ;
-
 
72
        return AUTH_formulaire_login() ;
61
        $_POST['password'] = '' ;
73
    }
-
 
74
    
62
        return $res.AUTH_formulaire_login() ;
75
    // L'utilisateur a-t-il cliqué sur Supprimer inscription
63
    }
76
    if (isset ($_POST['supprimer'])) {
64
    
77
    	$id_utilisateur = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID) ;
65
//cas de la désinscription-------------------------------------------------------------------------------
78
        $resultat = $GLOBALS['AUTH']->removeUser($GLOBALS['AUTH']->getUsername()) ;
66
    if ($_REQUEST['action'] == 'supprimer') {
79
	
67
    	$resultat = $GLOBALS['AUTH']->removeUser($GLOBALS['AUTH']->getUsername()) ;	
80
        if (PEAR::isError($resultat)) {
68
        if (PEAR::isError($resultat)) {
81
        	die ($resultat->getMessage().'<br />'.$resultat->getDebugInfo()) ;
69
        	die ($resultat->getMessage().'<br />'.$resultat->getDebugInfo()) ;
82
        }
70
        }
83
        // Suppression dans SPIP
71
        // Suppression dans SPIP
84
        if (INS_UTILISE_SPIP) {
72
        if (INS_UTILISE_SPIP) {
85
            desinscription_spip($id_utilisateur) ;
73
            desinscription_spip($GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID)) ;
86
        }
-
 
87
		// Suppression dans Wikini
74
        }
88
        if (INS_UTILISE_WIKINI) {
75
		// Suppression dans Wikini
89
			$nom_wiki = $GLOBALS['AUTH']->getAuthData(INS_NOM_WIKI) ;
-
 
90
			desinscription_interwikini_users($nom_wiki) ;
76
        if (INS_UTILISE_WIKINI) {
91
        }
77
			$nom_wiki = $GLOBALS['AUTH']->getAuthData(INS_NOM_WIKI) ;
92
        
78
			desinscription_interwikini_users($nom_wiki) ;
93
        // Appel des actions desinscriptions des applications clientes
79
        }
94
        $d = dir(GEN_CHEMIN_CLIENT);
80
        // Appel des actions desinscriptions des applications clientes
95
		
-
 
-
 
81
        $d = dir(GEN_CHEMIN_CLIENT);
96
		while (false !== ($repertoire = $d->read())) {
82
		while (false !== ($repertoire = $d->read())) {
97
			if (file_exists(GEN_CHEMIN_CLIENT.$repertoire.GEN_SEP.$repertoire.'.desinscription.inc.php'))
83
			if (file_exists(GEN_CHEMIN_CLIENT.$repertoire.GEN_SEP.$repertoire.'.desinscription.inc.php'))
98
			include_once GEN_CHEMIN_CLIENT.$repertoire.GEN_SEP.$repertoire.'.desinscription.inc.php' ;   
84
			include_once GEN_CHEMIN_CLIENT.$repertoire.GEN_SEP.$repertoire.'.desinscription.inc.php' ;   
Line 99... Line 85...
99
		}
85
		}
100
		$d->close();
86
		$d->close();
101
        
87
		// Deconnection        
102
        $GLOBALS['AUTH']->logout() ;
88
        $GLOBALS['AUTH']->logout() ;
Line 103... Line 89...
103
        return $res.AUTH_formulaire_login() ;
89
        return $res.AUTH_formulaire_login() ;
104
    }
90
    }
105
    
-
 
106
    // L'utilisateur a-t-il cliqué sur Envoi de mot de passe par mail
91
    
107
    if ($_REQUEST['action'] == 'sendpasswd') {
92
//cas de l'envoi de mot de passe par mail----------------------------------------------------------------
108
        return AUTH_formulaire_login(envoie_passe()) ;
93
    if ($_REQUEST['action'] == 'sendpasswd') {
109
    }
94
        return AUTH_formulaire_login(envoie_passe()) ;
110
 
95
    }
111
    // L'utilisateur a cliqué sur Inscription ou Inscription structure
96
 
-
 
97
//cas de la saisie ou la modification de l'inscription individuelle ou structure
112
    if ($_REQUEST['action'] != '' || isset($_POST['modifier'])) {
98
    if (($_REQUEST['action'] == 'modifier')or($_REQUEST['action'] == 'inscription')) {
113
        $action = preg_replace ("/&amp;/", "&", $GLOBALS['ins_url']->getURL()) ;
99
        $formulaire = new HTML_formulaireInscription('formulaire_inscription', 'post', preg_replace('/&amp;/', '&', $GLOBALS['ins_url']->getURL()), '_self', '', 0) ;
114
        $formulaire = new HTML_formulaireInscription('formulaire_inscription', 'post', $action, '_self', '', 0) ;
100
        $formulaire->construitFormulaire(preg_replace('/&amp;/', '&', $GLOBALS['ins_url']->getURL()));
115
	$formulaire->construitFormulaire($action);
101
        if ($_REQUEST['form_structure']==1) {
Line 116... Line 102...
116
        if (isset($_POST['form_structure'])and($_POST['form_structure']==1)) {
102
            $formulaire->formulaireStructure() ;
117
            $formulaire->formulaireStructure() ;
103
        }
Line 118... Line 104...
118
        }
104
        
119
 
105
        //pour la modification d'une inscription, on charge les valeurs par défauts
120
        if (isset($_POST['modifier'])) {
106
        if ($_REQUEST['action'] == 'modifier') {
121
            $formulaire->addElement('hidden', 'action', 'modifier_v') ;
107
            $formulaire->addElement('hidden', 'action', 'modifier_v') ;
122
            $formulaire->setDefaults(formulaire_defaults()) ;
108
            $formulaire->setDefaults(formulaire_defaults()) ;
Line 136... Line 122...
136
		    if (INS_MAIL_VALIDATION_INSCRIPTION) {
122
		    if (INS_MAIL_VALIDATION_INSCRIPTION) {
137
			    $formulaire->process('demande_inscription', false) ;
123
			    $formulaire->process('demande_inscription', false) ;
138
			    return $res.INS_MESSAGE_INSCRIPTION;
124
			    return $res.INS_MESSAGE_INSCRIPTION;
139
		    } else {
125
		    } else {
140
			    $formulaire->process('inscription_validee', false) ;
126
			    $formulaire->process('inscription_validee', false) ;
141
			    return $res.info().bouton($url).deconnexion($GLOBALS['ins_url']->getURL()) ;;
127
			    return $res.info();
142
		    }
128
		    }
143
            }
129
            }
144
        }
130
        }
145
        if ($_REQUEST['action'] == 'modifier_v') {
131
        if ($_REQUEST['action'] == 'modifier_v') {
146
            if ($formulaire->validate()) {
132
            if ($formulaire->validate()) {
Line 154... Line 140...
154
            } else {
140
            } else {
155
                if ($lettre == 1) {
141
                if ($lettre == 1) {
156
                    inscription_lettre(INS_MAIL_DESINSCRIPTION_LISTE) ;
142
                    inscription_lettre(INS_MAIL_DESINSCRIPTION_LISTE) ;
157
                }
143
                }
158
            }
144
            }
159
            return info($GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID)).bouton($url).deconnexion($GLOBALS['ins_url']->getURL()) ;
145
            return $res.info();
160
        }
146
        }
Line 161... Line 147...
161
	
147
	
162
        return $res.$formulaire->toHTML() ;
148
        return $res.$formulaire->toHTML() ;
Line 163... Line 149...
163
    }
149
    }
164
    
150
    
165
    // L'inscription dans la base si l'utilisateur clique sur le lien du mail
151
//cas de la validation par mail d'une inscription--------------------------------------------------------
166
    if ((INS_MAIL_VALIDATION_INSCRIPTION)and(isset($_GET['id']))) {
152
    if ((INS_MAIL_VALIDATION_INSCRIPTION)and(isset($_GET['id']))) {
167
	    $requete = 'select id_donnees from inscription_demande where id_identifiant_session="'.$_GET['id'].'"' ;
153
	    $requete = 'SELECT id_donnees FROM inscription_demande WHERE id_identifiant_session="'.$_GET['id'].'"' ;
168
	    $resultat = $GLOBALS['ins_db']->query($requete) ;
154
	    $resultat = $GLOBALS['ins_db']->query($requete) ;
169
	    if (DB::isError ($resultat)) {
155
	    if (DB::isError ($resultat)) {
170
		    die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
156
		    die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
Line 192... Line 178...
192
		    die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
178
		    die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
193
	    }
179
	    }
194
	    envoie_mail() ;
180
	    envoie_mail() ;
195
    }
181
    }
Line 196... Line 182...
196
    
182
    
197
    if (!$GLOBALS['AUTH']->getAuth() && $_REQUEST['action'] != "inscription" && $_REQUEST['action'] != 'inscription_v')    {    
183
    if ((!$GLOBALS['AUTH']->getAuth())&&($_REQUEST['action']!='inscription')&&($_REQUEST['action']!='inscription_v')) {    
198
        if (isset($_POST['username']) && $_POST['username'] != '') {
184
        if (isset($_POST['username']) && $_POST['username'] != '') {
199
            $res .= message_erreur() ;
185
            $res .= message_erreur() ;
200
        } else {
186
        } else {
201
            $res .= AUTH_formulaire_login() ;
187
            $res .= AUTH_formulaire_login() ;
202
        }
188
        }
Line 203... Line 189...
203
    }
189
    }
204
    
190
    
205
    //cas d'une authentification réussie
191
//cas d'une authentification réussie---------------------------------------------------------------------
206
    if ($GLOBALS['AUTH']->getAuth() && !isset($_POST['modifier'])) {
192
    if ($GLOBALS['AUTH']->getAuth() && ($_REQUEST['action']!='modifier')) {
-
 
193
            return info() ;
207
            return info().bouton($url).deconnexion($GLOBALS['ins_url']->getURL()) ;
194
    }
208
    }
195
    
Line 209... Line 196...
209
    return $res ;
196
    return $res ;
210
}
197
}
211
 
198
 
-
 
199
/* +--Fin du code ----------------------------------------------------------------------------------------+
-
 
200
*
-
 
201
* $Log: not supported by cvs2svn $
212
/* +--Fin du code ----------------------------------------------------------------------------------------+
202
* Revision 1.4  2005/10/25 14:02:21  alexandre_tb
213
*
203
* le formulaire affiche la france par défaut
214
* $Log: not supported by cvs2svn $
204
*
215
* Revision 1.3  2005/09/29 16:07:51  alexandre_tb
205
* Revision 1.3  2005/09/29 16:07:51  alexandre_tb
216
* En cours de production.
206
* En cours de production.