user.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. from core.db import WordDatabase
  2. from werkzeug.security import generate_password_hash, check_password_hash
  3. import os
  4. from configure import conf
  5. from flask_login import UserMixin, AnonymousUserMixin
  6. import shutil
  7. from typing import Optional
  8. class AnonymousUser(AnonymousUserMixin):
  9. ...
  10. class UserWordDataBase(WordDatabase, UserMixin):
  11. def __init__(self, user: str, path: str):
  12. super().__init__(user, path)
  13. self.done(f'''
  14. CREATE TABLE IF NOT EXISTS User (
  15. id INTEGER PRIMARY KEY AUTOINCREMENT, -- 记录ID
  16. passwd TEXT NOT NULL -- 密码hash
  17. )''')
  18. if self.search(columns=["COUNT(ID)"], table="User")[0][0] == 0:
  19. self.insert(table="User", columns=["passwd"], values=f"'{generate_password_hash('88888888')}'") # 默认密码
  20. self.user = user
  21. def get_id(self):
  22. return self.user
  23. def check_passwd(self, passwd: str) -> bool:
  24. res = self.search(table="User", columns=["passwd"], limit=1, order_by=[("ID", "ASC")])
  25. if len(res) == 0:
  26. return False
  27. return check_password_hash(res[0][0], passwd)
  28. def set_passwd(self, passwd: str, record_id: int = 1):
  29. self.update(table="User", kw={"passwd": f"'{generate_password_hash(passwd)}'"}, where=f"id={record_id}")
  30. def delete_user(self):
  31. self.delete_self()
  32. def check_base_db():
  33. if os.path.exists(os.path.join(conf["DB_TEMPLATE"], "base.db")):
  34. return
  35. WordDatabase("base", conf["DB_TEMPLATE"])
  36. def check_template(template: str) -> bool:
  37. check_base_db()
  38. return os.path.exists(os.path.join(conf["DB_TEMPLATE"], f"{template}.db"))
  39. def create_user(template: str, name: str, passwd: str):
  40. check_base_db()
  41. if not os.path.exists(os.path.join(conf["DB_TEMPLATE"], f"{template}.db")):
  42. return 0, None
  43. if os.path.exists(os.path.join(conf["DB_PATH"], f"{name}.db")):
  44. return -1, None
  45. shutil.copy(os.path.join(conf["DB_TEMPLATE"], f"{template}.db"), os.path.join(conf["DB_PATH"], f"{name}.db"))
  46. user = UserWordDataBase(name, conf["DB_PATH"])
  47. if len(passwd) > 0:
  48. user.set_passwd(passwd)
  49. return 1, user
  50. def load_user(name: str, passwd: Optional[str]):
  51. if not os.path.exists(os.path.join(conf["DB_PATH"], f"{name}.db")):
  52. return None
  53. user = UserWordDataBase(name, conf["DB_PATH"])
  54. if passwd is None or user.check_passwd(passwd):
  55. return user
  56. return None