base.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. class Auth_Base {
  3. private $dbh;
  4. function __construct() {
  5. $this->dbh = Db::get();
  6. }
  7. function check_password($owner_uid, $password) {
  8. return false;
  9. }
  10. function authenticate($login, $password) {
  11. return false;
  12. }
  13. // Auto-creates specified user if allowed by system configuration
  14. // Can be used instead of find_user_by_login() by external auth modules
  15. function auto_create_user($login, $password = false) {
  16. if ($login && defined('AUTH_AUTO_CREATE') && AUTH_AUTO_CREATE) {
  17. $user_id = $this->find_user_by_login($login);
  18. if (!$password) $password = make_password();
  19. if (!$user_id) {
  20. $login = $this->dbh->escape_string($login);
  21. $salt = substr(bin2hex(get_random_bytes(125)), 0, 250);
  22. $pwd_hash = encrypt_password($password, $salt, true);
  23. $query = "INSERT INTO ttrss_users
  24. (login,access_level,last_login,created,pwd_hash,salt)
  25. VALUES ('$login', 0, null, NOW(), '$pwd_hash','$salt')";
  26. $this->dbh->query($query);
  27. return $this->find_user_by_login($login);
  28. } else {
  29. return $user_id;
  30. }
  31. }
  32. return $this->find_user_by_login($login);
  33. }
  34. function find_user_by_login($login) {
  35. $login = $this->dbh->escape_string($login);
  36. $result = $this->dbh->query("SELECT id FROM ttrss_users WHERE
  37. login = '$login'");
  38. if ($this->dbh->num_rows($result) > 0) {
  39. return $this->dbh->fetch_result($result, 0, "id");
  40. } else {
  41. return false;
  42. }
  43. }
  44. }
  45. ?>