@clawchatsai/connector 0.0.48 → 0.0.49
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.
- package/dist/index.js +35 -30
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -964,36 +964,41 @@ const plugin = {
|
|
|
964
964
|
const mediaStash = new Map();
|
|
965
965
|
// Capture MEDIA: paths from exec tool results before the gateway strips them from message text.
|
|
966
966
|
// Fires after every tool call; we filter to exec only and check for MEDIA: lines.
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
console.
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
text =
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
967
|
+
// Guard: registerTypedHook may not exist in older OpenClaw versions.
|
|
968
|
+
if (typeof api.registerTypedHook !== 'function') {
|
|
969
|
+
console.warn('[clawchats] api.registerTypedHook not available — MEDIA: path capture disabled (update OpenClaw to enable)');
|
|
970
|
+
}
|
|
971
|
+
else
|
|
972
|
+
api.registerTypedHook('after_tool_call', (event, ctx) => {
|
|
973
|
+
// Diagnostic: log every tool call so we can confirm hook fires + see real tool names
|
|
974
|
+
console.log(`[clawchats] hook:after_tool_call toolName=${String(event.toolName)} sessionKey=${String(ctx.sessionKey)}`);
|
|
975
|
+
if (event.toolName !== 'exec')
|
|
976
|
+
return;
|
|
977
|
+
// result is { content: [{ type: 'text', text: '...' }] } — extract text defensively
|
|
978
|
+
const result = event.result;
|
|
979
|
+
let text = '';
|
|
980
|
+
if (typeof result?.text === 'string') {
|
|
981
|
+
text = result.text;
|
|
982
|
+
}
|
|
983
|
+
else if (Array.isArray(result?.content)) {
|
|
984
|
+
text = result.content
|
|
985
|
+
.filter(c => c.type === 'text' && typeof c.text === 'string')
|
|
986
|
+
.map(c => c.text)
|
|
987
|
+
.join('\n');
|
|
988
|
+
}
|
|
989
|
+
else if (result != null) {
|
|
990
|
+
text = String(result);
|
|
991
|
+
}
|
|
992
|
+
const paths = [...text.matchAll(/^MEDIA:\s*(\S+)/gm)].map(m => m[1].trim());
|
|
993
|
+
if (paths.length === 0)
|
|
994
|
+
return;
|
|
995
|
+
const sessionKey = ctx.sessionKey;
|
|
996
|
+
if (!sessionKey)
|
|
997
|
+
return;
|
|
998
|
+
const existing = mediaStash.get(sessionKey) ?? [];
|
|
999
|
+
mediaStash.set(sessionKey, [...existing, ...paths]);
|
|
1000
|
+
console.log(`[clawchats] media-capture: stashed ${paths.length} path(s) for ${sessionKey}:`, paths);
|
|
1001
|
+
}, { name: 'clawchats-media-capture', description: 'Captures MEDIA: paths from exec results for inline image rendering' });
|
|
997
1002
|
// Background service: signaling + gateway bridge + future WebRTC
|
|
998
1003
|
api.registerService({
|
|
999
1004
|
id: 'connector-service',
|