web.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. from flask import Flask
  2. from flask_login import current_user
  3. import math
  4. from sql.store import get_store_item_list, get_store_item, confirm_order
  5. from tool.typing import *
  6. from tool.page import get_page
  7. from core.garbage import GarbageType
  8. from sql import DBBit
  9. from sql.db import DB
  10. from sql.garbage import count_garbage_by_uid, get_garbage_by_uid
  11. from sql.user import find_user_by_name, find_user_by_id, get_rank_for_user, count_all_user
  12. from sql.news import write_news, get_news, get_news_count
  13. from sql.store import check_order, get_goods_from_order
  14. from . import web_user
  15. from . import web_goods
  16. class WebsiteBase:
  17. def __init__(self, app: Flask, db: DB):
  18. self._db = db
  19. self._app = app
  20. self._user = current_user # 把参函传递的user移迁为该变量
  21. @property
  22. def db(self):
  23. return self._db
  24. @property
  25. def app(self):
  26. return self._app
  27. @property
  28. def user(self):
  29. return self._user
  30. @property
  31. def rel_user(self):
  32. return self._user._get_current_object()
  33. class AuthWebsite(WebsiteBase):
  34. def load_user_by_name(self, name: uname_t, passwd: passwd_t) -> Optional["web_user.WebUser"]:
  35. user = find_user_by_name(name, passwd, self._db)
  36. if user is None:
  37. return None
  38. return web_user.WebUser(name, uid=user.get_uid())
  39. def load_user_by_id(self, uid: uid_t) -> Optional["web_user.WebUser"]:
  40. user = find_user_by_id(uid, self._db)
  41. if user is None:
  42. return None
  43. name = user.get_name()
  44. return web_user.WebUser(name, uid=uid)
  45. def get_user_garbage_count(self, uid: uid_t):
  46. return count_garbage_by_uid(uid, self._db, time_limit=False)
  47. def get_user_garbage_list(self, uid: uid_t, limit: int, offset: int = 0):
  48. garbage_list = get_garbage_by_uid(uid,
  49. columns=["UseTime", "Location", "GarbageType", "CheckResult"],
  50. limit=limit,
  51. db=self.db,
  52. offset=offset)
  53. res = []
  54. for i in garbage_list:
  55. t = i[0].strftime("%Y-%m-%d %H:%M:%S")
  56. loc = i[1]
  57. type_ = GarbageType.GarbageTypeStrList_ch[int(i[2])]
  58. if i[3] is None:
  59. result = "待确定"
  60. result_class = 'wait'
  61. elif i[3] == DBBit.BIT_1:
  62. result = "投放正确"
  63. result_class = 'pass'
  64. else:
  65. result = "投放错误"
  66. result_class = 'fail'
  67. res.append((t, loc, type_, result, result_class))
  68. return res
  69. def get_user_by_id(self, uid: uid_t):
  70. res = find_user_by_id(uid, self._db)
  71. return res
  72. class StoreWebsite(WebsiteBase):
  73. def get_store_list(self) -> Optional[List]:
  74. return get_store_item_list(self._db)
  75. def get_goods(self, goods_id: int):
  76. goods = get_store_item(goods_id, self._db) # 返回值 ["Name", "Score", "Quantity", "GoodsID"]
  77. if goods is None:
  78. return goods
  79. # 更快的写法应该是 web_goods.Goods(*goods), 但目前的写法可读性更佳
  80. return web_goods.Goods(name=goods[0], score=goods[1], quantity=goods[2], goods_id=goods[3])
  81. def check_order(self, order, uid) -> Tuple[Optional[list], Optional[str]]:
  82. if not check_order(order, uid, self._db):
  83. return None, None
  84. goods = get_goods_from_order(order, self._db)
  85. res = []
  86. for i in goods:
  87. res.append(f"#{i} {i[0]} x {i[1]}")
  88. return res, uid
  89. def confirm_order(self, order_id: int, uid: uid_t) -> bool:
  90. return confirm_order(order_id, uid, self._db)
  91. class RankWebsite(WebsiteBase):
  92. def get_rank(self, page: int, order_by: str = "DESC", url: str = "rank_up"):
  93. count = math.ceil(count_all_user(self._db) / 20)
  94. offset = 20 * (page - 1)
  95. return get_rank_for_user(self.db, 20, offset, order_by), get_page(f"rank.{url}", page, count)
  96. class NewsWebsite(WebsiteBase):
  97. def write_news(self, context: str, uid: uid_t):
  98. return write_news(context, uid, self.db)
  99. def get_news(self, page: int = 1):
  100. count = math.ceil(get_news_count(self.db) / 10)
  101. if page > count:
  102. return False, None, None
  103. res, news_list = get_news(limit=20, offset=((page - 1) * 10), db=self.db)
  104. if not res:
  105. return False, None, None
  106. return True, news_list, get_page("news.index", page, count)
  107. class Website(AuthWebsite, StoreWebsite, RankWebsite, NewsWebsite, WebsiteBase):
  108. def __init__(self, app: Flask, db: DB):
  109. super(Website, self).__init__(app, db)