Rev 2 | Blame | Last modification | View Log | RSS feed
<?phpif (!function_exists("LoadUser")){function LoadUser($name, $password = 0){global $wiki;return $wiki->LoadSingle("select * from ".$wiki->config["common_table_prefix"]."users where name = '".mysql_escape_string($name)."' ".($password === 0 ? "" : "and password = '".mysql_escape_string($password)."'")." limit 1");}}if ($_REQUEST["action"] == "logout"){$this->LogoutUser();$this->SetMessage("Vous êtes maintenant déconnecté !");$this->Redirect($this->href());}else if ($user = $this->GetUser()){// is user trying to update?if ($_REQUEST["action"] == "update"){$this->Query("update ".$this->config["common_table_prefix"]."users set "."email = '".mysql_escape_string($_POST["email"])."', "."doubleclickedit = '".mysql_escape_string($_POST["doubleclickedit"])."', "."show_comments = '".mysql_escape_string($_POST["show_comments"])."', "."revisioncount = '".mysql_escape_string($_POST["revisioncount"])."', "."changescount = '".mysql_escape_string($_POST["changescount"])."', "."motto = '".mysql_escape_string($_POST["motto"])."' "."where name = '".$user["name"]."' limit 1");$this->SetUser(LoadUser($user["name"]));// forward$this->SetMessage("Paramètres sauvegardés !");$this->Redirect($this->href());}if ($_REQUEST["action"] == "changepass"){// check password$password = $_POST["password"];if (preg_match("/ /", $password)) $error = "Les espaces ne sont pas permis dans les mots de passe.";else if (strlen($password) < 5) $error = "Password too short.";else if ($user["password"] != md5($_POST["oldpass"])) $error = "Mauvais mot de passe.";else{$this->Query("update ".$this->config["common_table_prefix"]."users set "."password = md5('".mysql_escape_string($password)."') "."where name = '".$user["name"]."'");$this->SetMessage("Mot de passe changé !");$user["password"]=md5($password);$this->SetUser($user);$this->Redirect($this->href());}}// user is logged in; display config formprint($this->FormOpen());?><input type="hidden" name="action" value="update" /><table><tr><td align="right"></td><td>Hello, <?php echo $this->Link($user["name"]) ?>!</td></tr><tr><td align="right">Votre adresse e-mail :</td><td><input name="email" value="<?php echo htmlentities($user["email"]) ?>" size="40" /></td></tr><tr><td align="right">Edition en Doublecliquant :</td><td><input type="hidden" name="doubleclickedit" value="N" /><input type="checkbox" name="doubleclickedit" value="Y" <?php echo $user["doubleclickedit"] == "Y" ? "checked=\"checked\"" : "" ?> /></td></tr><tr><td align="right">Montrer les commentaires par default :</td><td><input type="hidden" name="show_comments" value="N" /><input type="checkbox" name="show_comments" value="Y" <?php echo $user["show_comments"] == "Y" ? "checked\"checked\"" : "" ?> /></td></tr><tr><td align="right">Nombre maximum de derniers commentaires :</td><td><input name="changescount" value="<?php echo htmlentities($user["changescount"]) ?>" size="40" /></td></tr><tr><td align="right">Nombre maximum de versions :</td><td><input name="revisioncount" value="<?php echo htmlentities($user["revisioncount"]) ?>" size="40" /></td></tr><tr><td align="right">Votre devise :</td><td><input name="motto" value="<?php echo htmlentities($user["motto"]) ?>" size="40" /></td></tr><tr><td></td><td><input type="submit" value="Mise à jour" /> <input type="button" value="Déconnection" onClick="document.location='<?php echo $this->href("", "", "action=logout"); ?>'" /></td></tr><?phpprint($this->FormClose());print($this->FormOpen());?><input type="hidden" name="action" value="changepass" /><tr><td> </td><td> </td></tr><tr><td align="right"></td><td><?php echo $this->Format("Changement de mot de passe"); ?></td></tr><?phpif ($error){print("<tr><td></td><td><div class=\"error\">".$this->Format($error)."</div></td></tr>\n");}?><tr><td align="right">Votre ancien mot de passe :</td><td><input type="password" name="oldpass" size="40" /></td></tr><tr><td align="right">Nouveau mot de passe :</td><td><input type="password" name="password" size="40" /></td></tr><tr><td></td><td><input type="submit" value="Changer" size="40" /></td></tr></table><?phpprint($this->FormClose());}else{// user is not logged in// is user trying to log in or register?if ($_REQUEST["action"] == "login"){// if user name already exists, check passwordif ($existingUser = LoadUser($_POST["name"])){// check passwordif ($existingUser["password"] == md5($_POST["password"])){$this->SetUser($existingUser, $_POST["remember"]);$this->Redirect($this->href());}else{$error = "Mauvais mot de passe !";}}// otherwise, create new accountelse{$name = trim($_POST["name"]);$email = trim($_POST["email"]);$password = $_POST["password"];$confpassword = $_POST["confpassword"];// check if name is WikkiName styleif (!$this->IsWikiName($name)) $error = "Votre nom d'utilisateur dois être formaté en NomWiki.";else if (!$email) $error = "Vous devez spécifier une adresse e-mail.";else if (!preg_match("/^.+?\@.+?\..+$/", $email)) $error = "Ceci ne ressemble pas à une adresse e-mail.";else if ($confpassword != $password) $error = "Les mots de passe n'étaient pas identiques";else if (preg_match("/ /", $password)) $error = "Les espaces ne sont pas permis dans un mot de passe.";else if (strlen($password) < 5) $error = "Mot de passe trop court. Un mot de passe doit contenir au minimum 5 caractères alphanumériques.";else{$this->Query("insert into ".$this->config["common_table_prefix"]."users set "."signuptime = now(), "."name = '".mysql_escape_string($name)."', "."email = '".mysql_escape_string($email)."', "."password = md5('".mysql_escape_string($_POST["password"])."')");// log in$this->SetUser(LoadUser($name));// forward$this->Redirect($this->href());}}}print($this->FormOpen());?><input type="hidden" name="action" value="login" /><table><tr><td align="right"></td><td><?php echo $this->Format("Si vous êtes déjà enregistré, identifiez-vous ici"); ?></td></tr><?phpif ($error){print("<tr><td></td><td><div class=\"error\">".$this->Format($error)."</div></td></tr>\n");}?><tr><td align="right">Votre NomWiki :</td><td><input name="name" size="40" value="<?php echo $name ?>" /></td></tr><tr><td align="right">Mot de passe (5 caractères minimum) :</td><td><input type="password" name="password" size="40" /><input type="hidden" name="remember" value="0" /><input type="checkbox" name="remember" value="1" /> <?php echo $this->Format("Se souvenir de moi.") ?> </td></tr><tr><td></td><td><input type="submit" value="Identification" size="40" /></td></tr><tr><td align="right"></td><td width="500"><?php echo $this->Format("Les champs suivants sont à remplir si vous vous identifiez pour la première fois (vous créérez ainsi un compte)"); ?></td></tr><tr><td align="right">Confirmation du mot de passe :</td><td><input type="password" name="confpassword" size="40" /></td></tr><tr><td align="right">Adresse e-mail :</td><td><input name="email" size="40" value="<?php echo $email ?>" /></td></tr><tr><td></td><td><input type="submit" value="Nouveau compte" size="40" /></td></tr></table><?phpprint($this->FormClose());}?>