login_reset.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. require_once 'session.php';
  3. require_once 'database.php';
  4. require_once 'twig.php';
  5. // Do not re-login if already loged in
  6. if (Session::is_valid())
  7. {
  8. header ('Location: ./login');
  9. exit ();
  10. }
  11. $db = new Database ();
  12. $db->connect ();
  13. // POST: Process form submission ===========================================
  14. if ($_SERVER['REQUEST_METHOD'] === 'POST')
  15. {
  16. // User asked to reset his password
  17. if (isset ($_POST['reset']))
  18. {
  19. if (!isset ($_POST['username']))
  20. {
  21. header ('Location: ./login');
  22. exit ();
  23. }
  24. // Make sure the user exists
  25. $user = $db->get_user ($_POST['username']);
  26. // User exists
  27. if (is_null ($user) || empty ($user))
  28. {
  29. header ('Location: ./login_reset');
  30. exit ();
  31. }
  32. // Get a new secret token
  33. $token = $db->password_reset ($user['hashId']);
  34. // Send reset token by email
  35. if (!is_null ($token))
  36. {
  37. mail ($user['email'],
  38. 'freepost: password reset',
  39. $twig->render ('login_reset_email.twig', array ('token' => $token)),
  40. 'From: freepost <noreply@freepo.st>' . "\r\n" . 'Reply-To: freepost <noreply@freepo.st>');
  41. }
  42. // Render template (tell user the password was sent)
  43. echo $twig->render (
  44. 'login_reset.twig',
  45. array ('token_sent' => true));
  46. exit ();
  47. }
  48. // Validate secret token sent by email
  49. if (isset ($_POST['validate']))
  50. {
  51. // POST form must have a token and a password
  52. if (!isset ($_POST['token']) || !isset ($_POST['password']))
  53. {
  54. header ('Location: ./login_reset');
  55. exit ();
  56. }
  57. $token = $_POST['token'];
  58. $new_password = $_POST['password'];
  59. // Check password length
  60. if (strlen ($new_password) < 8)
  61. {
  62. // Render template
  63. echo $twig->render (
  64. 'login_reset.twig',
  65. array (
  66. 'token' => $token,
  67. 'feedback' => 'Password must be at least 8 characters long'));
  68. exit ();
  69. }
  70. // Is the token valid?
  71. $user = $db->password_reset_validate ($token, $new_password);
  72. header ('Location: ./login');
  73. exit ();
  74. }
  75. }
  76. // GET: show reset form ====================================================
  77. // Form for resetting password (this is displayed when user clicks email link)
  78. if (isset ($_GET['token']))
  79. {
  80. // Render template
  81. echo $twig->render (
  82. 'login_reset.twig',
  83. array ('token' => $_GET['token']));
  84. exit ();
  85. }
  86. // Render template
  87. echo $twig->render ('login_reset.twig');