1,63 → 1,66 |
<?php |
/*vim: set expandtab tabstop=4 shiftwidth=4: */ |
// +------------------------------------------------------------------------------------------------------+ |
// | PHP version 4.1 | |
// | PHP version 4.1 | |
// +------------------------------------------------------------------------------------------------------+ |
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org) | |
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org) | |
// +------------------------------------------------------------------------------------------------------+ |
// | This library is free software; you can redistribute it and/or | |
// | modify it under the terms of the GNU Lesser General Public | |
// | License as published by the Free Software Foundation; either | |
// | version 2.1 of the License, or (at your option) any later version. | |
// | | |
// | This library is distributed in the hope that it will be useful, | |
// | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
// | Lesser General Public License for more details. | |
// | | |
// | You should have received a copy of the GNU Lesser General Public | |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// | This library is free software; you can redistribute it and/or | |
// | modify it under the terms of the GNU Lesser General Public | |
// | License as published by the Free Software Foundation; either | |
// | version 2.1 of the License, or (at your option) any later version. | |
// | | |
// | This library is distributed in the hope that it will be useful, | |
// | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
// | Lesser General Public License for more details. | |
// | | |
// | You should have received a copy of the GNU Lesser General Public | |
// | License along with this library; if not, write to the Free Software | |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
// +------------------------------------------------------------------------------------------------------+ |
// CVS : $Id: inscription.php,v 1.3 2005/03/21 16:50:21 alex Exp $ |
/** |
* Inscription |
* |
* Un module d'inscription, en général ce code est spécifique à |
* un site web |
* Un module d'inscription, en général ce code est spécifique à un site web. |
* |
*@package inscription |
//Auteur original : |
*@author Alexandre GRANIER <alexandre@tela-botanica.org> |
*@author Alexandre GRANIER <alexandre@tela-botanica.org> |
//Autres auteurs : |
*@copyright Tela-Botanica 2000-2004 |
*@version $Revision: 1.3 $ $Date: 2005/03/21 16:50:21 $ |
*@author Jean-Pascal MILCENT <jpm@tela-botanica.org> |
*@copyright Tela-Botanica 2000-2004 |
*@version $Id: inscription.php,v 1.3 2005/03/21 16:50:21 alex Exp $ |
// +------------------------------------------------------------------------------------------------------+ |
*/ |
|
// +------------------------------------------------------------------------------------------------------+ |
// | ENTETE du PROGRAMME | |
// | ENTETE du PROGRAMME | |
// +------------------------------------------------------------------------------------------------------+ |
include_once PAP_CHEMIN_API_PEAR.'Mail.php' ; |
if (isset($lang)) { |
include_once "client/inscription/langues/ins_langue_$lang.inc.php" ; |
require_once PAP_CHEMIN_API_PEAR.'HTML/QuickForm.php' ; |
require_once PAP_CHEMIN_API_PEAR.'HTML/QuickForm/checkbox.php' ; |
require_once PAP_CHEMIN_API_PEAR.'HTML/QuickForm/password.php' ; |
/** Constante "dynamique" stockant la langue demandée par l'utilisateur pour l'application.*/ |
define('INS_LANGUE', substr($GLOBALS['_GEN_commun']['i18n'], 0, 2)); |
$fichier_lg = 'client/inscription/langues/ins_langue_'.INS_LANGUE.'.inc.php'; |
if (file_exists($fichier_lg)) { |
include_once $fichier_lg; |
include_once 'client/inscription/langues/ins_langue_'.INS_LANGUE.'.inc.php'; |
} else { |
include_once ("client/inscription/langues/ins_langue_fr.inc.php") ; |
include_once 'client/inscription/langues/ins_langue_fr.inc.php' ; |
} |
include_once ("client/inscription/configuration/ins_config.inc.php"); |
include_once ("client/inscription/bibliotheque/inscription.fonct.php") ; |
include_once INS_CHEMIN_FICHIER."bibliotheque/inscription.class.php" ; |
include_once 'client/inscription/configuration/ins_config.inc.php'; |
include_once 'client/inscription/bibliotheque/inscription.fonct.php'; |
include_once 'client/inscription/bibliotheque/ins_spip.fonct.php'; |
include_once INS_CHEMIN_FICHIER.'bibliotheque/inscription.class.php'; |
|
// Ajout d'une feuille de style externe |
GEN_stockerStyleExterne ('inscription', 'client/inscription/inscription.css') ; |
|
// +------------------------------------------------------------------------------------------------------+ |
// | LISTE de FONCTIONS | |
// | LISTE de FONCTIONS | |
// +------------------------------------------------------------------------------------------------------+ |
|
|
|
|
function afficherContenuTete() { |
$retour = '<h1 class="titre1_inscription">Inscription au Réseau Tela Botanica</h1>'; |
return ; |
71,200 → 74,203 |
|
/** |
* |
* @global AUTH Un pointeur vers un objet PEAR::Auth |
* @global AUTH Un pointeur vers un objet PEAR::Auth |
* @global ins_url Un pointeur vers un objet PEAR::Net_URL |
* @return string Le contenu de l'application inscription |
*/ |
|
function afficherContenuCorps() { |
|
$url = preg_replace ("/&/", "&", $GLOBALS['ins_url']->getURL()) ; |
if (!isset ($_REQUEST['action'])) $_REQUEST['action'] = "" ; |
$res = '' ; |
$est_loggue = true ; |
$url = preg_replace ("/&/", "&", $GLOBALS['ins_url']->getURL()) ; |
// Attibution de l'action par défaut à effectuer. |
if (!isset ($_REQUEST['action'])) { |
$_REQUEST['action'] = 'inscription'; |
} |
$res = '' ; |
$est_loggue = true ; |
|
// ... tentative de déconnection |
if (isset ($_GET['logout']) && $_GET['logout'] == 1) { |
$GLOBALS['AUTH']->logout() ; |
$_POST['username'] = '' ; |
$_POST['password'] = '' ; |
//return AUTH_formulaire_login() ; |
} |
|
// ...supprimer l'inscription |
if (isset ($_POST['supprimer'])) { |
$mail_utilisateur = $GLOBALS['AUTH']->getUsername(); |
$id_utilisateur = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID) ; |
$bool_inscription_lettre = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE); |
$resultat = $GLOBALS['AUTH']->removeUser($mail_utilisateur) ; |
|
if (isset ($_GET['logout']) && $_GET['logout'] == 1) { |
$GLOBALS['AUTH']->logout() ; |
$_POST['username'] = "" ; |
$_POST['password'] = "" ; |
return AUTH_formulaire_login() ; |
} |
|
// L'utilisateur a-t-il cliqué sur Supprimer inscription |
if (isset ($_POST['supprimer'])) { |
$mail_utilisateur = $GLOBALS['AUTH']->getUsername(); |
$id_utilisateur = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID) ; |
$bool_inscription_lettre = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE); |
if (PEAR::isError($resultat)) { |
die ($resultat->getMessage().'<br />'.$resultat->getDebugInfo()) ; |
} |
|
$resultat = $GLOBALS['AUTH']->removeUser($mail_utilisateur) ; |
// Suppression dans SPIP |
if (INS_UTILISE_SPIP) { |
desinscription_spip($id_utilisateur) ; |
} |
|
if (PEAR::isError($resultat)) { |
die ($resultat->getMessage().'<br />'.$resultat->getDebugInfo()) ; |
} |
// Suppression dans SPIP |
if (INS_UTILISE_SPIP) { |
desinscription_spip($id_utilisateur) ; |
} |
|
// Désinscription de la lettre d'info |
if ($bool_inscription_lettre == 1) { |
inscription_lettre(INS_MAIL_DESINSCRIPTION_LISTE) ; |
} |
$GLOBALS['AUTH']->logout() ; |
|
// Ajout d'une ligne dans les statistiques |
$requete = 'INSERT INTO '.INS_TABLE_STATISTIQUE.' SET '.INS_STATS_CHAMPS_DATE.'=NOW(), '.INS_STATS_CHAMPS_ACTION.'="del"' ; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ; |
} |
return AUTH_formulaire_login() ; |
} |
// Désinscription de la lettre d'info |
if (INS_UTILISE_LISTE) { |
if ($bool_inscription_lettre == 1) { |
inscription_lettre(INS_MAIL_DESINSCRIPTION_LISTE) ; |
} |
} |
$GLOBALS['AUTH']->logout() ; |
|
// Ajout d'une ligne dans les statistiques |
if (INS_UTILISE_STAT) { |
$requete = 'INSERT INTO '.INS_TABLE_STATISTIQUE.' SET '.INS_STATS_CHAMPS_DATE.'=NOW(), '.INS_STATS_CHAMPS_ACTION.'="del"' ; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ; |
} |
} |
//return AUTH_formulaire_login() ; |
} |
|
if ($_REQUEST['action'] == 'sendpasswd') { |
return AUTH_formulaire_login(envoie_passe()) ; |
} |
// ... envoie de mot de passe |
if ($_REQUEST['action'] == 'sendpasswd') { |
envoie_passe(); |
} |
|
// ...oublie de mot de passe |
if (preg_match('/^(?:mdp_oubli|sendpasswd)$/', $_REQUEST['action'])) { |
return message_erreur(false); |
} |
|
// ...inscription dans la base si l'utilisateur clique sur le lien du mail |
if ($_GET['action'] == 'ajouter' && isset($_GET['id']) && !$GLOBALS['AUTH']->getAuth()) { |
$requete = 'SELECT id_donnees FROM inscription_demande WHERE id_identifiant_session="'.$_GET['id'].'"' ; |
$resultat = $GLOBALS['ins_db']->query($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
} |
if ($resultat->numRows() == 0) { |
return INS_MESSAGE_EXPIRATION; |
} |
$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ; |
$donnees = unserialize (stripslashes($ligne->id_donnees)) ; |
//trigger_error(print_r($donnees, true), E_USER_WARNING); |
|
// L'utilisateur a cliqué sur Inscription ou Inscription structure ou |
if ($_REQUEST['action'] != '' || isset($_POST['modifier'])) { |
$res .= '<h1 class="titre1_inscription">'.INS_ACCUEIL_INSCRIPTION.'</h1>' ; |
$action = preg_replace ("/&/", "&", $GLOBALS['ins_url']->getURL()) ; |
$formulaire = new HTML_formulaireInscription('formulaire_inscription', 'post', $action) ; |
|
// Construction de la liste des pays |
$liste_pays = new ListeDePays($GLOBALS['ins_db']) ; |
$formulaire->construitFormulaire($action, $liste_pays->getListePays('fr')) ; |
if (isset($_POST['structure'])) { |
$formulaire->formulaireStructure() ; |
} |
if (isset($_POST['modifier'])) { |
$formulaire->addElement ('hidden', 'action', 'modifier_v') ; |
$formulaire->setDefaults(formulaire_defaults()) ; |
if ($GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE) == 1) { |
$lettre = & $formulaire->getElement('lettre') ; |
$lettre->setChecked(true) ; |
} |
} |
if ($_REQUEST['action'] == 'inscription') { |
$formulaire->addElement ('hidden', 'action', 'inscription_v') ; |
$formulaire->setDefaults (array ('pays' => 'fr', 'asso' => 3, 'activite' => 3, 'niveau' => 4, 'lettre' => 1)) ; |
$lettre = & $formulaire->getElement('lettre') ; |
$lettre->setChecked(true) ; |
} |
|
// Ajout des données dans la base |
insertion($donnees); |
|
// On loggue l'utilisateur |
$GLOBALS['AUTH']->username = $donnees['email'] ; |
$GLOBALS['AUTH']->password = $donnees['mot_de_passe'] ; |
$GLOBALS['AUTH']->login() ; |
|
// Inscription à la lettre d'information |
if (INS_UTILISE_LISTE) { |
if (isset ($donnees['lettre'])) { |
inscription_lettre(INS_MAIL_INSCRIPTION_LISTE) ; |
} |
} |
|
// On supprime la demande d'inscription |
$requete = 'DELETE FROM inscription_demande WHERE id_identifiant_session="'.$_GET['id'].'"' ; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
} |
|
// On envoi les mails d'information sur la nouvelle inscription. |
envoie_mail(); |
} |
|
if ($_REQUEST['action'] == 'inscription_v') { |
if ($formulaire->validate()) { |
$formulaire->process('demande_inscription', false) ; |
return message_inscription() ; |
} |
} |
if ($_REQUEST['action'] == 'modifier_v') { |
// On stocke l ancien mail dans un variable |
$ancien_mail = $GLOBALS['AUTH']->getUsername(); |
if ($formulaire->validate()) { |
$valeur_lettre = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE) ; |
$formulaire->process('mise_a_jour', false) ; |
} |
|
// on verifie si l email a change, si oui on desinscrit l ancien email et on inscrit le nouveau (si la case est coche) |
$nouveau_mail = $_POST['email']; |
if ($ancien_mail != $nouveau_mail) { |
// On modifie la variable username de Auth |
$GLOBALS['AUTH']->setAuth($nouveau_mail); |
if (isset($_POST['lettre'])) { |
inscription_lettre (INS_MAIL_INSCRIPTION_LISTE, $nouveau_mail) ; |
// desinscription d avec l ancien courriel |
inscription_lettre (INS_MAIL_DESINSCRIPTION_LISTE, $ancien_mail) ; |
} else { |
if ($valeur_lettre == 1) { |
inscription_lettre (INS_MAIL_DESINSCRIPTION_LISTE) ; |
} |
} |
} |
return info ($GLOBALS['AUTH']->getAuthData (INS_CHAMPS_ID)).bouton ($url) ; |
} |
return $res.$formulaire->toHTML() ; |
} |
// ... affichage d'une erreur en cas de pb |
if (!$GLOBALS['AUTH']->getAuth() && $_REQUEST['action'] != 'inscription' && $_REQUEST['action'] != 'inscription_v') { |
if (isset($_POST['username']) && $_POST['username'] != '') { |
$res .= message_erreur(); |
} |
} |
|
// L'inscription dans la base si l'utilisateur clique sur le lien du mail |
// ... la personne est identifiée nous affichons ses informations |
if ($GLOBALS['AUTH']->getAuth () && !isset($_POST['modifier']) && $_REQUEST['action'] != 'modifier_v') { |
return info().bouton($url); |
} |
|
// ...tentative d'inscription ou Inscription structure |
if (preg_match('/^(?:inscription|inscription_v|modifier_v)$/', $_REQUEST['action']) || isset($_POST['modifier'])) { |
$action = preg_replace ("/&/", "&", $GLOBALS['ins_url']->getURL()) ; |
$formulaire = new HTML_formulaireInscription('formulaire_inscription', 'post', $action) ; |
// Construction de la liste des pays |
$liste_pays = new ListeDePays($GLOBALS['ins_db']) ; |
|
if (isset($_GET['id']) && !$GLOBALS['AUTH']->getAuth()) { |
$requete = 'SELECT id_donnees FROM inscription_demande WHERE id_identifiant_session="'.$_GET['id'].'"' ; |
$resultat = $GLOBALS['ins_db']->query($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
} |
if ($resultat->numRows() == 0) { |
return INS_MESSAGE_EXPIRATION; |
} |
$ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ; |
$donnees = unserialize (stripslashes($ligne->id_donnees)) ; |
insertion ($donnees) ; |
$GLOBALS['AUTH']->username = $donnees['email'] ; |
$GLOBALS['AUTH']->password = $donnees['mot_de_passe'] ; |
|
// On loggue l'utilisateur |
$GLOBALS['AUTH']->login() ; |
|
// inscription à la lettre d'information |
if (isset ($donnees['lettre'])) { |
inscription_lettre (INS_MAIL_INSCRIPTION_LISTE) ; |
} |
// On supprime la demande d'inscription |
$requete = 'DELETE FROM inscription_demande WHERE id_identifiant_session="'.$_GET['id'].'"' ; |
$resultat = $GLOBALS['ins_db']->query ($requete) ; |
if (DB::isError ($resultat)) { |
die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ; |
} |
envoie_mail() ; |
} |
|
if (!$GLOBALS['AUTH']->getAuth() && $_REQUEST['action'] != "inscription" && $_REQUEST['action'] != 'inscription_v') { |
|
if (isset($_POST['username']) && $_POST['username'] != '') { |
$res .= message_erreur(); |
} else { |
$res .= AUTH_formulaire_login(); |
} |
} |
if ($GLOBALS['AUTH']->getAuth () && !isset($_POST['modifier'])) { |
return info ().bouton ($url); |
} |
return $res ; |
if (isset($_POST['structure'])) { |
$formulaire->formulaireStructure() ; |
} |
|
if (!isset($_POST['modifier'])) { |
$GLOBALS['ins_url']->addQueryString('action', 'mdp_oubli'); |
$url_oubli = preg_replace ('/&/', '&', $GLOBALS['ins_url']->getURL()) ; |
$GLOBALS['ins_url']->removeQueryString('action'); |
$res .= '<h1 class="titre1_inscription">'.INS_ACCUEIL_INSCRIPTION.'</h1>'; |
$res .= '<h2 class="titre2_inscription">'.INS_LAIUS_INSCRIPTION.'</h2>'."\n" ; |
$res .= '<p>'.INS_LAIUS_INSCRIPTION_2.'</p>'."\n" ; |
$res .= '<p>'.INS_TEXTE_PERDU.' <a href="'.$url_oubli.'">'.INS_MDP_PERDU_OUBLI.'</a></p>'."\n" ; |
} else { |
$formulaire->mode_ajout = false; |
$res .= '<h1 class="titre1_inscription">'.INS_ACCUEIL_INSCRIPTION.'</h1>'; |
} |
|
$formulaire->construitFormulaire($action, $liste_pays->getListePays('fr')) ; |
|
if (isset($_POST['modifier'])) { |
$formulaire->addElement ('hidden', 'action', 'modifier_v') ; |
$formulaire->setDefaults(formulaire_defaults()) ; |
if (INS_UTILISE_LISTE) { |
if ($GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE) == 1) { |
$lettre = & $formulaire->getElement('lettre') ; |
$lettre->setChecked(true) ; |
} |
} |
} else if ($_REQUEST['action'] == 'inscription') { |
$formulaire->addElement ('hidden', 'action', 'inscription_v') ; |
$formulaire->setDefaults (array ('pays' => 'fr', 'asso' => 3, 'activite' => 3, 'niveau' => 4, 'lettre' => 1)) ; |
if (INS_UTILISE_LISTE) { |
$lettre = & $formulaire->getElement('lettre') ; |
$lettre->setChecked(true) ; |
} |
} else if ($_REQUEST['action'] == 'inscription_v') { |
if ($formulaire->validate()) { |
$formulaire->process('demande_inscription', false) ; |
return message_inscription() ; |
} |
} else if ($_REQUEST['action'] == 'modifier_v') { |
if ($formulaire->validate()) { |
if (INS_UTILISE_LISTE) { |
$valeur_lettre = $GLOBALS['AUTH']->getAuthData(INS_CHAMPS_LETTRE) ; |
} |
$formulaire->process('mise_a_jour', false) ; |
} |
if (INS_UTILISE_LISTE) { |
if (isset($_POST['lettre'])) { |
if ($valeur_lettre == '') { |
inscription_lettre (INS_MAIL_INSCRIPTION_LISTE) ; |
} |
} else { |
if ($valeur_lettre == 1) { |
inscription_lettre (INS_MAIL_DESINSCRIPTION_LISTE) ; |
} |
} |
} |
return info($GLOBALS['AUTH']->getAuthData(INS_CHAMPS_ID)).bouton($url); |
} |
|
return $res.$formulaire->toHTML() ; |
} |
|
return $res ; |
} |
/* +--Fin du code ----------------------------------------------------------------------------------------+ |
* |
* $Log: inscription.php,v $ |
* Revision 1.3 2005/03/21 16:50:21 alex |
* mille et une corrction |
* |
* Revision 1.2 2005/03/11 16:55:01 alex |
* modification html |
* |
* Revision 1.3 2004/09/14 12:20:28 alex |
* déplacement de la fonction suppression vers inscription.fonct.php |
* et nettoyage du code. |
* |
* Revision 1.2 2004/09/01 16:36:37 alex |
* changement du chemin pour les include |
* |
* Revision 1.1 2004/07/06 15:42:28 alex |
* en cours |
* |
* Revision 1.5 2004/07/06 15:28:56 alex |
* en cours |
* |
* Revision 1.4 2004/06/25 14:26:03 alex |
* modification de la suppression |
* |
* Revision 1.3 2004/06/23 12:41:44 alex |
* amélioration de la gestion de la perte de mot de passe |
* |
* Revision 1.2 2004/06/18 09:18:23 alex |
* version initiale |
* |
* |
* +-- Fin du code ----------------------------------------------------------------------------------------+ |
*/ |
?> |
|
function afficherContenuPied () { |
$sortie = '<p id="ins_pied_page">'.INS_PIED_INFO. |
'<a href="mailto:'.INS_PIED_MAIL.'">'.INS_PIED_MAIL.'</a>.'. |
'</p>'; |
return $sortie; |
} |
?> |