From 3cb945f03a789e8999c14bb50c5f43bebabf52af Mon Sep 17 00:00:00 2001 From: OsaAjani Date: Wed, 9 Dec 2015 20:39:26 +0100 Subject: [PATCH] =?UTF-8?q?Ajout=20d=C3=A9finition=20mot=20de=20passe=20no?= =?UTF-8?q?uvel=20utilisateur?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- controllers/users.php | 16 ++++++++++++++++ templates/users/add.php | 14 ++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/controllers/users.php b/controllers/users.php index 2a9e647..94f0971 100755 --- a/controllers/users.php +++ b/controllers/users.php @@ -44,6 +44,8 @@ * @param $csrf : Le jeton CSRF * @param string $_POST['email'] : L'email de l'utilisateur * @param string $_POST['email_confirm'] : Confirmation de l'email de l'utilisateur + * @param string $_POST['password'] : Le mot de passe de l'utilisateur (si vide, générer automatiquement) + * @param string $_POST['password_confirm'] : Confirmation du mot de passe de l'utilisateur * @param boolean $_POST['admin'] : Optionnel : Si l'utilisateur est admin. Par défaut non */ public function create($csrf) @@ -66,7 +68,21 @@ } $email = $_POST['email']; + $no_crypt_password = internalTools::generatePassword(rand(8,12)); + + if ($_POST['password']) + { + if ($_POST['password'] != $_POST['password_confirm']) + { + $_SESSION['errormessage'] = 'Les mots de passes fournis ne correspondent pas.'; + header('Location: ' . $this->generateUrl('users', 'add')); + return false; + } + + $no_crypt_password = $_POST['password']; + } + $password = sha1($no_crypt_password); if (!filter_var($email, FILTER_VALIDATE_EMAIL)) diff --git a/templates/users/add.php b/templates/users/add.php index 5e5b44e..201dab3 100755 --- a/templates/users/add.php +++ b/templates/users/add.php @@ -52,6 +52,20 @@ +
+ +
+ + +
+
+
+ +
+ + +
+