@kirigaya/openclaw-onebot 1.1.0 → 1.1.1
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.
|
@@ -6,7 +6,7 @@ import { getRawText, getTextFromSegments, getReplyMessageId, getTextFromMessageC
|
|
|
6
6
|
import { getRenderMarkdownToPlain, getCollapseDoubleNewlines, getWhitelistUserIds, getBlacklistUserIds, getOgImageRenderTheme, getNormalModeFlushIntervalMs, getNormalModeFlushChars, getTriggerKeywords, getTriggerMode, getReplyWhenWhitelistDenied, } from "../config.js";
|
|
7
7
|
import { markdownToPlain, collapseDoubleNewlines } from "../markdown.js";
|
|
8
8
|
import { markdownToImage } from "../og-image.js";
|
|
9
|
-
import { sendPrivateMsg, sendGroupMsg, sendPrivateImage, sendGroupImage, sendGroupForwardMsg, sendPrivateForwardMsg, setMsgEmojiLike, getMsg, } from "../connection.js";
|
|
9
|
+
import { sendPrivateMsg, sendGroupMsg, sendPrivateImage, sendGroupImage, sendGroupForwardMsg, sendPrivateForwardMsg, setMsgEmojiLike, getMsg, getStrangerInfo, getGroupMemberInfo, } from "../connection.js";
|
|
10
10
|
import { setActiveReplyTarget, clearActiveReplyTarget, setActiveReplySessionId, setForwardSuppressDelivery, setActiveReplySelfId } from "../reply-context.js";
|
|
11
11
|
import { loadPluginSdk, getSdk } from "../sdk.js";
|
|
12
12
|
import { handleGroupIncrease } from "./group-increase.js";
|
|
@@ -62,6 +62,40 @@ export function startForwardCleanupTimer() {
|
|
|
62
62
|
return;
|
|
63
63
|
forwardCleanupTimer = setInterval(cleanupForwardPendingSessions, FORWARD_CLEANUP_INTERVAL_MS);
|
|
64
64
|
}
|
|
65
|
+
const nicknameCache = new Map();
|
|
66
|
+
const NICKNAME_CACHE_TTL_MS = 5 * 60 * 1000; // 5 分钟
|
|
67
|
+
/**
|
|
68
|
+
* 解析发送者展示名称。
|
|
69
|
+
* 优先使用消息体自带的群名片/昵称;若缺失,则通过 OneBot API 查询并缓存。
|
|
70
|
+
* 最终格式为 nickname(qq: userId),确保 AI 上下文中同时包含昵称与 ID。
|
|
71
|
+
*/
|
|
72
|
+
async function resolveSenderNickname(userId, groupId, isGroup, senderFromMsg) {
|
|
73
|
+
const card = senderFromMsg?.card?.trim();
|
|
74
|
+
const nickname = senderFromMsg?.nickname?.trim();
|
|
75
|
+
const base = card || nickname || "";
|
|
76
|
+
if (base) {
|
|
77
|
+
return `${base}(qq: ${userId})`;
|
|
78
|
+
}
|
|
79
|
+
const cacheKey = isGroup && groupId ? `group:${groupId}:${userId}` : `user:${userId}`;
|
|
80
|
+
const cached = nicknameCache.get(cacheKey);
|
|
81
|
+
if (cached && Date.now() - cached.ts < NICKNAME_CACHE_TTL_MS) {
|
|
82
|
+
return `${cached.nickname}(qq: ${userId})`;
|
|
83
|
+
}
|
|
84
|
+
let resolved = "";
|
|
85
|
+
if (isGroup && groupId) {
|
|
86
|
+
const info = await getGroupMemberInfo(groupId, userId);
|
|
87
|
+
resolved = info?.card?.trim() || info?.nickname?.trim() || "";
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
const info = await getStrangerInfo(userId);
|
|
91
|
+
resolved = info?.nickname?.trim() || "";
|
|
92
|
+
}
|
|
93
|
+
if (resolved) {
|
|
94
|
+
nicknameCache.set(cacheKey, { nickname: resolved, ts: Date.now() });
|
|
95
|
+
return `${resolved}(qq: ${userId})`;
|
|
96
|
+
}
|
|
97
|
+
return String(userId);
|
|
98
|
+
}
|
|
65
99
|
export async function processInboundMessage(api, msg) {
|
|
66
100
|
await loadPluginSdk();
|
|
67
101
|
const { buildPendingHistoryContextFromMap, recordPendingHistoryEntry, clearHistoryEntriesIfEnabled } = getSdk();
|
|
@@ -187,11 +221,7 @@ export async function processInboundMessage(api, msg) {
|
|
|
187
221
|
}) ?? "";
|
|
188
222
|
const envelopeOptions = runtime.channel.reply?.resolveEnvelopeFormatOptions?.(cfg) ?? {};
|
|
189
223
|
const chatType = isGroup ? "group" : "direct";
|
|
190
|
-
|
|
191
|
-
const senderNickname = (isGroup ? msg.sender?.card?.trim() : undefined)
|
|
192
|
-
|| msg.sender?.nickname?.trim()
|
|
193
|
-
|| "";
|
|
194
|
-
const fromLabel = senderNickname || String(userId);
|
|
224
|
+
const fromLabel = await resolveSenderNickname(Number(userId), groupId, isGroup, msg.sender);
|
|
195
225
|
// 添加日志:打印插件接收到的原始消息内容
|
|
196
226
|
api.logger?.info?.(`[onebot] received message from user ${userId}: "${messageText}"`);
|
|
197
227
|
const formattedBody = runtime.channel.reply?.formatInboundEnvelope?.({
|