Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. <?php
  2. require_once "sql.php";
  3. require_once "utils.php";
  4. function hash_password($password)
  5. {
  6. return sha1($password);
  7. }
  8. function user_create()
  9. {
  10. $username = get_post("username");
  11. $password = get_post("password");
  12. if (strlen($username) < 3)
  13. error(422, "Username too short");
  14. if (database_exec("SELECT id FROM users WHERE `username` = :username",
  15. array(":username" => $username))->fetch() !== false)
  16. error(409, "Username already exists");
  17. database_exec("INSERT INTO users (`username`, `password`) ".
  18. "VALUES(:username, :password)", array(":username" => $username,
  19. ":password" => hash_password($password)));
  20. user_login($username);
  21. }
  22. function user_login($username = false)
  23. {
  24. $args = null;
  25. $query = "SELECT `id` FROM users WHERE `username` = :username";
  26. if ($username === false)
  27. {
  28. $username = get_post("username");
  29. $args = array(":username" => $username,
  30. ":password" => hash_password(get_post("password")));
  31. $query = $query . " AND `password` = :password";
  32. }
  33. else
  34. $args = array(":username" => $username);
  35. $u = database_exec($query, $args)->fetch();
  36. if ($u === false)
  37. error(401, "Wrong username or password");
  38. $token = hash_password(uniqid(mt_rand(), true));
  39. database_exec("INSERT INTO tokens (`token`, `user`) VALUES (:token, :user)",
  40. array(":token" => $token, ":user" => $u['id']));
  41. echo json_encode(array("username" => $username, "id" => $u["id"],
  42. "token" => $token));
  43. }
  44. ?>