auth.php 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. function hashPassword($password) {
  3. return password_hash($password, ALGO_PASSWORD, OPTIONS_PASSWORD);
  4. }
  5. function checkPassword($username, $password) {
  6. $username2[0] = $username;
  7. $db = new PDO('sqlite:' . DB_PATH);
  8. $op = $db->prepare('SELECT username, password FROM users WHERE username = ?');
  9. $op->execute($username2);
  10. $dbPassword = $op->fetch()['password'];
  11. return password_verify($password, $dbPassword);
  12. }
  13. function outdatedPasswordHash($username) {
  14. $username2[0] = $username;
  15. $db = new PDO('sqlite:' . DB_PATH);
  16. $op = $db->prepare('SELECT username, password FROM users WHERE username = ?');
  17. $op->execute($username2);
  18. $dbPassword = $op->fetch()['password'];
  19. return password_needs_rehash($dbPassword, ALGO_PASSWORD, OPTIONS_PASSWORD);
  20. }
  21. function changePassword($username, $password) {
  22. $password = hashPassword($password);
  23. $db = new PDO('sqlite:' . DB_PATH);
  24. $stmt = $db->prepare("UPDATE users SET password = :password WHERE username = :username");
  25. $stmt->bindParam(':username', $username);
  26. $stmt->bindParam(':password', $password);
  27. $stmt->execute();
  28. }
  29. function antiCSRF() {
  30. if (!isset($_SERVER['HTTP_SEC_FETCH_SITE']) AND !isset($_SERVER['HTTP_ORIGIN']))
  31. exit("ERROR: Browser sent neither Sec-Fetch-Site nor Origin HTTP headers, so anti-CSRF verification can't be done.");
  32. if (isset($_SERVER['HTTP_ORIGIN']) AND $_SERVER['HTTP_ORIGIN'] !== ORIGIN)
  33. exit("ERROR: Anti-CSRF verification failed");
  34. if (isset($_SERVER['HTTP_SEC_FETCH_SITE']) AND $_SERVER['HTTP_SEC_FETCH_SITE'] !== "same-origin")
  35. exit("ERROR: Anti-CSRF verification failed");
  36. }