Dev (#75)
* fix(discord): 修复 WebSocket 连接检测并增强跨平台文件处理 修复 Discord WebSocket 连接检测逻辑,使用正确的属性检查连接状态 为跨平台消息处理添加文件类型支持,并增加详细的调试日志 优化附件处理逻辑,确保所有文件类型都能正确识别和转发 * feat(跨平台): 优化消息处理并添加纯文本提取功能 添加 extract_text_only 函数过滤非文本标记 修改翻译逻辑仅处理纯文本内容 完善附件处理和消息内容拼接 修复仅包含表情时的消息处理问题 * refactor(discord-cross): 使用模块专用日志记录器替换全局日志记录器 将各模块中的全局日志记录器替换为模块专用日志记录器,以提供更清晰的日志来源标识 同时在适配器中添加会话状态检查和重连机制,提升消息发送的可靠性
This commit is contained in:
@@ -7,7 +7,7 @@
|
||||
|
||||
实现原理:
|
||||
1. 接收 Discord 消息 (`discord.Message`)。
|
||||
2. 将其“伪装”成 OneBot 的 `GroupMessageEvent` 或 `PrivateMessageEvent`。
|
||||
2. 将其"伪装"成 OneBot 的 `GroupMessageEvent` 或 `PrivateMessageEvent`。
|
||||
3. 拦截插件调用的 `event.reply()` 方法。
|
||||
4. 将插件返回的 OneBot `MessageSegment` 转换为 Discord 格式并发送。
|
||||
"""
|
||||
@@ -227,8 +227,9 @@ class DiscordToOneBotConverter:
|
||||
Returns:
|
||||
伪装后的 OneBot 事件对象
|
||||
"""
|
||||
# 在方法内部导入 logger,避免作用域问题
|
||||
from core.utils.logger import logger
|
||||
# 在静态方法内部创建模块专用日志记录器
|
||||
from core.utils.logger import ModuleLogger
|
||||
mod_logger = ModuleLogger("DiscordConverter")
|
||||
|
||||
# 1. 提取基础信息
|
||||
user_id = discord_message.author.id
|
||||
@@ -289,36 +290,36 @@ class DiscordToOneBotConverter:
|
||||
|
||||
# 添加附件信息
|
||||
if discord_message.attachments:
|
||||
logger.debug(f"[DiscordToOneBotConverter] 检测到 {len(discord_message.attachments)} 个附件")
|
||||
mod_logger.debug(f"[DiscordToOneBotConverter] 检测到 {len(discord_message.attachments)} 个附件")
|
||||
for attachment in discord_message.attachments:
|
||||
filename = attachment.filename.lower()
|
||||
logger.debug(f"[DiscordToOneBotConverter] 处理附件: {attachment.filename}, MIME: {attachment.content_type}")
|
||||
mod_logger.debug(f"[DiscordToOneBotConverter] 处理附件: {attachment.filename}, MIME: {attachment.content_type}")
|
||||
# 检查是否是语音文件
|
||||
if filename.endswith(('.amr', '.silk', '.mp3', '.wav', '.ogg', '.m4a')):
|
||||
seg = OneBotMessageSegment.record(attachment.url)
|
||||
seg.data["filename"] = attachment.filename
|
||||
message_list.append(seg)
|
||||
raw_message += f"\n[语音: {attachment.filename}]"
|
||||
logger.debug(f"[DiscordToOneBotConverter] 识别为语音文件: {attachment.filename}")
|
||||
mod_logger.debug(f"[DiscordToOneBotConverter] 识别为语音文件: {attachment.filename}")
|
||||
elif filename.endswith(('.mp4', '.avi', '.mkv', '.mov', '.flv', '.wmv')):
|
||||
seg = OneBotMessageSegment.video(attachment.url)
|
||||
seg.data["filename"] = attachment.filename
|
||||
message_list.append(seg)
|
||||
raw_message += f"\n[视频: {attachment.filename}]"
|
||||
logger.debug(f"[DiscordToOneBotConverter] 识别为视频文件: {attachment.filename}")
|
||||
mod_logger.debug(f"[DiscordToOneBotConverter] 识别为视频文件: {attachment.filename}")
|
||||
elif filename.endswith(('.png', '.jpg', '.jpeg', '.gif', '.webp')):
|
||||
image_type = "gif" if filename.endswith('.gif') else None
|
||||
seg = OneBotMessageSegment.image(attachment.url, image_type=image_type)
|
||||
seg.data["filename"] = attachment.filename
|
||||
message_list.append(seg)
|
||||
raw_message += f"\n[图片: {attachment.filename}]"
|
||||
logger.debug(f"[DiscordToOneBotConverter] 识别为图片文件: {attachment.filename}")
|
||||
mod_logger.debug(f"[DiscordToOneBotConverter] 识别为图片文件: {attachment.filename}")
|
||||
else:
|
||||
seg = OneBotMessageSegment.file(attachment.url)
|
||||
seg.data["filename"] = attachment.filename
|
||||
message_list.append(seg)
|
||||
raw_message += f"\n[文件: {attachment.filename}]"
|
||||
logger.success(f"[DiscordToOneBotConverter] 识别为普通文件: {attachment.filename}")
|
||||
mod_logger.success(f"[DiscordToOneBotConverter] 识别为普通文件: {attachment.filename}")
|
||||
|
||||
# 添加贴纸 (Stickers) 信息
|
||||
if hasattr(discord_message, 'stickers') and discord_message.stickers:
|
||||
|
||||
Reference in New Issue
Block a user