mirror of
https://github.com/suyiiyii/nonebot-bison.git
synced 2025-06-04 02:26:11 +08:00
🐛 添加 Cookie 时,显示 「无法获取cookie_name」 的错误提示
This commit is contained in:
parent
438b23a0b9
commit
0985705c22
@ -1,5 +1,7 @@
|
|||||||
from typing import cast
|
from typing import cast
|
||||||
|
from json import JSONDecodeError
|
||||||
|
|
||||||
|
from nonebot.log import logger
|
||||||
from nonebot.typing import T_State
|
from nonebot.typing import T_State
|
||||||
from nonebot.matcher import Matcher
|
from nonebot.matcher import Matcher
|
||||||
from nonebot.params import Arg, ArgPlainText
|
from nonebot.params import Arg, ArgPlainText
|
||||||
@ -42,7 +44,7 @@ def do_add_cookie(add_cookie: type[Matcher]):
|
|||||||
await add_cookie.finish("已中止添加cookie")
|
await add_cookie.finish("已中止添加cookie")
|
||||||
elif platform in platform_manager:
|
elif platform in platform_manager:
|
||||||
state["platform"] = platform
|
state["platform"] = platform
|
||||||
state["site"] = platform_manager[platform].site
|
state["site"] = cast(CookieSite, platform_manager[platform].site)
|
||||||
else:
|
else:
|
||||||
await add_cookie.reject("平台输入错误")
|
await add_cookie.reject("平台输入错误")
|
||||||
|
|
||||||
@ -58,12 +60,20 @@ def do_add_cookie(add_cookie: type[Matcher]):
|
|||||||
await add_cookie.reject(
|
await add_cookie.reject(
|
||||||
"无效的 Cookie,请检查后重新输入,详情见https://nonebot-bison.netlify.app/usage/cookie.html"
|
"无效的 Cookie,请检查后重新输入,详情见https://nonebot-bison.netlify.app/usage/cookie.html"
|
||||||
)
|
)
|
||||||
state["cookie"] = cookie_text
|
try:
|
||||||
|
cookie_name = await cookie_site.get_cookie_name(cookie_text)
|
||||||
|
state["cookie"] = cookie_text
|
||||||
|
state["cookie_name"] = cookie_name
|
||||||
|
except JSONDecodeError as e:
|
||||||
|
logger.error("获取 Cookie 名称失败" + str(e))
|
||||||
|
await add_cookie.reject(
|
||||||
|
"获取 Cookie 名称失败,请检查后重新输入,详情见https://nonebot-bison.netlify.app/usage/cookie.html"
|
||||||
|
)
|
||||||
|
|
||||||
@add_cookie.handle()
|
@add_cookie.handle()
|
||||||
async def add_cookie_process(state: T_State):
|
async def add_cookie_process(state: T_State):
|
||||||
client_mgr = cast(CookieClientManager, platform_manager[state["platform"]].site.client_mgr)
|
client_mgr = cast(CookieClientManager, platform_manager[state["platform"]].site.client_mgr)
|
||||||
new_cookie = await client_mgr.add_user_cookie(state["cookie"])
|
new_cookie = await client_mgr.add_user_cookie(state["cookie"], state["cookie_name"])
|
||||||
await add_cookie.finish(
|
await add_cookie.finish(
|
||||||
f"已添加 Cookie: {new_cookie.cookie_name} 到平台 {state['platform']}"
|
f"已添加 Cookie: {new_cookie.cookie_name} 到平台 {state['platform']}"
|
||||||
+ "\n请使用“关联cookie”为 Cookie 关联订阅"
|
+ "\n请使用“关联cookie”为 Cookie 关联订阅"
|
||||||
|
@ -74,7 +74,7 @@ class CookieClientManager(ClientManager):
|
|||||||
await config.add_cookie(new_anonymous_cookie)
|
await config.add_cookie(new_anonymous_cookie)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
async def add_user_cookie(cls, content: str):
|
async def add_user_cookie(cls, content: str, cookie_name=str | None) -> Cookie:
|
||||||
"""添加用户 cookie"""
|
"""添加用户 cookie"""
|
||||||
from ..platform import site_manager
|
from ..platform import site_manager
|
||||||
|
|
||||||
@ -82,7 +82,7 @@ class CookieClientManager(ClientManager):
|
|||||||
if not await cookie_site.validate_cookie(content):
|
if not await cookie_site.validate_cookie(content):
|
||||||
raise ValueError()
|
raise ValueError()
|
||||||
cookie = Cookie(site_name=cls._site_name, content=content)
|
cookie = Cookie(site_name=cls._site_name, content=content)
|
||||||
cookie.cookie_name = await cookie_site.get_cookie_name(content)
|
cookie.cookie_name = cookie_name if cookie_name else await cookie_site.get_cookie_name(content)
|
||||||
cookie.cd = cls._default_cd
|
cookie.cd = cls._default_cd
|
||||||
cookie_id = await config.add_cookie(cookie)
|
cookie_id = await config.add_cookie(cookie)
|
||||||
return await config.get_cookie_by_id(cookie_id)
|
return await config.get_cookie_by_id(cookie_id)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user