nonebot-plugin-bililive 2.1.4__tar.gz → 2.1.5__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/PKG-INFO +1 -1
  2. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/database/db.py +52 -12
  3. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/version.py +1 -1
  4. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/pyproject.toml +1 -1
  5. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/LICENSE +0 -0
  6. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/README.md +0 -0
  7. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/__init__.py +0 -0
  8. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/__main__.py +0 -0
  9. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/bilibili_api.py +0 -0
  10. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/cli/__init__.py +0 -0
  11. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/cli/bot.py +0 -0
  12. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/cli/utils.py +0 -0
  13. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/config.py +0 -0
  14. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/database/__init__.py +0 -0
  15. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/database/models.py +0 -0
  16. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/__init__.py +0 -0
  17. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/__init__.py +0 -0
  18. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/card.py +0 -0
  19. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/desc.py +0 -0
  20. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/display.py +0 -0
  21. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/user_profile.py +0 -0
  22. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/libs/dynamic/web.py +0 -0
  23. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/__init__.py +0 -0
  24. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/at/__init__.py +0 -0
  25. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/at/at_off.py +0 -0
  26. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/at/at_on.py +0 -0
  27. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/auto_agree.py +0 -0
  28. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/auto_delete.py +0 -0
  29. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/dynamic/__init__.py +0 -0
  30. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/dynamic/dynamic_off.py +0 -0
  31. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/dynamic/dynamic_on.py +0 -0
  32. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/help.py +0 -0
  33. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/live/__init__.py +0 -0
  34. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/live/live_now.py +0 -0
  35. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/live/live_off.py +0 -0
  36. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/live/live_on.py +0 -0
  37. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/permission/__init__.py +0 -0
  38. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/permission/permission_off.py +0 -0
  39. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/permission/permission_on.py +0 -0
  40. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/pusher/__init__.py +0 -0
  41. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/pusher/dynamic_pusher.py +0 -0
  42. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/pusher/live_pusher.py +0 -0
  43. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/sub/__init__.py +0 -0
  44. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/sub/add_sub.py +0 -0
  45. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/sub/delete_sub.py +0 -0
  46. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/plugins/sub/sub_list.py +0 -0
  47. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/utils/__init__.py +0 -0
  48. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/utils/browser.py +0 -0
  49. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/utils/captcha_solver.py +0 -0
  50. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/utils/fonts_provider.py +0 -0
  51. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/nonebot_plugin_bililive/utils/mobile.js +0 -0
  52. {nonebot_plugin_bililive-2.1.4 → nonebot_plugin_bililive-2.1.5}/tests/test_maintenance.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: nonebot-plugin-bililive
3
- Version: 2.1.4
3
+ Version: 2.1.5
4
4
  Summary: Push bilibili dynamics and live notifications to QQ with NoneBot2.
5
5
  Keywords: nonebot,nonebot2,nonebot-plugin,bilibili,onebot,onebot-v11
6
6
  Author-Email: Akiyy_Lab <2806578374@qq.com>
@@ -13,6 +13,8 @@ from .models import Group, Sub, User, Version
13
13
  uid_list = {"live": {"list": [], "index": 0}, "dynamic": {"list": [], "index": 0}}
14
14
  dynamic_offset = {}
15
15
 
16
+ _db_init_lock = asyncio.Lock()
17
+
16
18
 
17
19
  class DB:
18
20
  """数据库交互类,与增删改查无关的部分不应该在这里面实现"""
@@ -24,15 +26,18 @@ class DB:
24
26
  return Path(get_path("dynamic_offset.json"))
25
27
 
26
28
  @classmethod
27
- async def init(cls):
28
- """初始化数据库"""
29
+ def _orm_context_ok(cls) -> bool:
30
+ """_ready 与 Tortoise 1.x 全局上下文需同时成立,否则会出现 No TortoiseContext。"""
31
+ from tortoise.context import get_current_context
32
+
33
+ return cls._ready and get_current_context() is not None
34
+
35
+ @classmethod
36
+ async def _do_init(cls) -> None:
37
+ """在持有 _db_init_lock 时执行完整初始化。"""
29
38
  cls._ready = False
30
39
  config = {
31
40
  "connections": {
32
- # "bililive": {
33
- # "engine": "tortoise.backends.sqlite",
34
- # "credentials": {"file_path": get_path("data.sqlite3")},
35
- # },
36
41
  "bililive": f"sqlite://{get_path('data.sqlite3')}"
37
42
  },
38
43
  "apps": {
@@ -52,26 +57,61 @@ class DB:
52
57
  await cls.save_dynamic_offsets()
53
58
  cls._ready = True
54
59
 
60
+ @classmethod
61
+ async def init(cls):
62
+ """初始化数据库"""
63
+ async with _db_init_lock:
64
+ await cls._do_init()
65
+
55
66
  @classmethod
56
67
  async def close(cls):
57
- cls._ready = False
58
- await cls.save_dynamic_offsets()
59
- await Tortoise.close_connections()
68
+ async with _db_init_lock:
69
+ cls._ready = False
70
+ await cls.save_dynamic_offsets()
71
+ await Tortoise.close_connections()
72
+
73
+ @classmethod
74
+ async def _recover_stale_orm(cls) -> None:
75
+ """_ready 仍为 True 但 Tortoise 上下文已丢失时,关闭并重新初始化。"""
76
+ async with _db_init_lock:
77
+ from tortoise.context import get_current_context
78
+
79
+ if get_current_context() is not None:
80
+ return
81
+ if not cls._ready:
82
+ return
83
+ logger.warning(
84
+ "Tortoise ORM 上下文已失效(可能被其他代码关闭连接),"
85
+ "正在重新初始化数据库"
86
+ )
87
+ try:
88
+ await Tortoise.close_connections()
89
+ except Exception:
90
+ logger.exception("关闭 Tortoise 连接时出错,仍将尝试重新初始化")
91
+ cls._ready = False
92
+ await cls._do_init()
60
93
 
61
94
  @classmethod
62
95
  async def wait_until_ready(cls, timeout: float = 30) -> bool:
63
- if cls._ready:
96
+ if cls._orm_context_ok():
64
97
  return True
65
98
 
66
99
  waited = 0.0
67
100
  interval = 0.1
68
101
  while waited < timeout:
69
- if cls._ready:
102
+ if cls._orm_context_ok():
70
103
  return True
104
+ if cls._ready:
105
+ from tortoise.context import get_current_context
106
+
107
+ if get_current_context() is None:
108
+ await cls._recover_stale_orm()
109
+ if cls._orm_context_ok():
110
+ return True
71
111
  await asyncio.sleep(interval)
72
112
  waited += interval
73
113
 
74
- return cls._ready
114
+ return cls._orm_context_ok()
75
115
 
76
116
  @classmethod
77
117
  async def load_dynamic_offsets(cls):
@@ -1,4 +1,4 @@
1
1
  from packaging.version import Version
2
2
 
3
- __version__ = "2.1.4"
3
+ __version__ = "2.1.5"
4
4
  VERSION = Version(__version__)
@@ -39,7 +39,7 @@ dependencies = [
39
39
  "msvc-runtime>=14.34.31931; sys_platform == \"win32\"",
40
40
  ]
41
41
  dynamic = []
42
- version = "2.1.4"
42
+ version = "2.1.5"
43
43
 
44
44
  [project.license]
45
45
  text = "AGPL-3.0-or-later"