🐛 修复角色素材部分角色缺失

This commit is contained in:
omg-xtao 2022-08-31 19:24:02 +08:00 committed by GitHub
parent 83f09cd00f
commit 683c3ce4aa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 5 deletions

View File

@ -45,19 +45,40 @@ class GameStrategyService:
return artwork_info.results.image_url_list[0] return artwork_info.results.image_url_list[0]
class GameMaterialService(GameStrategyService): class GameMaterialService:
def __init__(self, cache: GameCache, collections: Optional[List[int]] = None): def __init__(self, cache: GameCache, collections: Optional[List[int]] = None):
super().__init__(cache, collections) self._cache = cache
self._hyperion = Hyperion()
self._collections = [428421, 1164644] if collections is None else collections self._collections = [428421, 1164644] if collections is None else collections
self._special = ['雷电将军', '珊瑚宫心海', '菲谢尔', '托马', '八重神子', '九条裟罗', '辛焱', '神里绫华'] self._special = ['雷电将军', '珊瑚宫心海', '菲谢尔', '托马', '八重神子', '九条裟罗', '辛焱', '神里绫华']
async def _get_material_from_hyperion(self, collection_id: int, character_name: str) -> int:
post_id: int = -1
post_full_in_collection = await self._hyperion.get_post_full_in_collection(collection_id)
if post_full_in_collection.error:
return post_id
for post_data in post_full_in_collection.data["posts"]:
topics = post_data["topics"]
for topic in topics:
if character_name == topic["name"]:
post_id = int(post_data["post"]["post_id"])
break
if post_id != -1:
break
subject = post_data["post"]["subject"]
if character_name in subject:
post_id = int(post_data["post"]["post_id"])
if post_id != -1:
break
return post_id
async def get_material(self, character_name: str) -> str: async def get_material(self, character_name: str) -> str:
cache = await self._cache.get_url_list(character_name) cache = await self._cache.get_url_list(character_name)
if len(cache) >= 1: if len(cache) >= 1:
return cache[-1] return cache[-1]
for collection_id in self._collections: for collection_id in self._collections:
post_id = await self._get_strategy_from_hyperion(collection_id, character_name) post_id = await self._get_material_from_hyperion(collection_id, character_name)
if post_id != -1: if post_id != -1:
break break
else: else:
@ -66,4 +87,11 @@ class GameMaterialService(GameStrategyService):
artwork_info = await self._hyperion.get_artwork_info(2, post_id) artwork_info = await self._hyperion.get_artwork_info(2, post_id)
await self._cache.set_url_list(character_name, artwork_info.results.image_url_list) await self._cache.set_url_list(character_name, artwork_info.results.image_url_list)
image_url_list = artwork_info.results.image_url_list image_url_list = artwork_info.results.image_url_list
return image_url_list[2] if character_name in self._special else image_url_list[1] if len(image_url_list) == 0:
return ""
elif len(image_url_list) == 1:
return image_url_list[0]
elif character_name in self._special:
return image_url_list[2]
else:
return image_url_list[1]

View File

@ -59,7 +59,7 @@ class Material(BasePlugins):
Log.info(f"用户 {user.full_name}[{user.id}] 查询角色培养素材命令请求 || 参数 {character_name}") Log.info(f"用户 {user.full_name}[{user.id}] 查询角色培养素材命令请求 || 参数 {character_name}")
await message.reply_chat_action(ChatAction.UPLOAD_PHOTO) await message.reply_chat_action(ChatAction.UPLOAD_PHOTO)
file_path = await url_to_file(url, "") file_path = await url_to_file(url, "")
caption = "From 米游社 友人A " \ caption = "From 米游社 " \
f"查看 [原图]({url})" f"查看 [原图]({url})"
await message.reply_photo(photo=open(file_path, "rb"), caption=caption, filename=f"{character_name}.png", await message.reply_photo(photo=open(file_path, "rb"), caption=caption, filename=f"{character_name}.png",
allow_sending_without_reply=True, parse_mode=ParseMode.MARKDOWN_V2) allow_sending_without_reply=True, parse_mode=ParseMode.MARKDOWN_V2)