@clawchatsai/connector 0.0.49 → 0.0.50

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.d.ts CHANGED
@@ -51,7 +51,7 @@ interface PluginApi {
51
51
  name: string;
52
52
  description?: string;
53
53
  }) => void;
54
- registerTypedHook: (hookName: string, handler: (event: Record<string, unknown>, ctx: Record<string, unknown>) => void | Promise<void>, opts?: {
54
+ on: (hookName: string, handler: (event: Record<string, unknown>, ctx: Record<string, unknown>) => void | Promise<void>, opts?: {
55
55
  name?: string;
56
56
  description?: string;
57
57
  priority?: number;
package/dist/index.js CHANGED
@@ -964,41 +964,35 @@ 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
- // 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' });
967
+ // Uses api.on() the correct public API for typed lifecycle hooks (NOT registerTypedHook).
968
+ api.on('after_tool_call', (event, ctx) => {
969
+ if (event.toolName !== 'exec' && event.toolName !== 'process')
970
+ return;
971
+ // result is { content: [{ type: 'text', text: '...' }] } — extract text defensively
972
+ const result = event.result;
973
+ let text = '';
974
+ if (typeof result?.text === 'string') {
975
+ text = result.text;
976
+ }
977
+ else if (Array.isArray(result?.content)) {
978
+ text = result.content
979
+ .filter(c => c.type === 'text' && typeof c.text === 'string')
980
+ .map(c => c.text)
981
+ .join('\n');
982
+ }
983
+ else if (result != null) {
984
+ text = String(result);
985
+ }
986
+ const paths = [...text.matchAll(/^MEDIA:\s*(\S+)/gm)].map(m => m[1].trim());
987
+ if (paths.length === 0)
988
+ return;
989
+ const sessionKey = ctx.sessionKey;
990
+ if (!sessionKey)
991
+ return;
992
+ const existing = mediaStash.get(sessionKey) ?? [];
993
+ mediaStash.set(sessionKey, [...existing, ...paths]);
994
+ console.log(`[clawchats] media-capture: stashed ${paths.length} path(s) for ${sessionKey}:`, paths);
995
+ }, { name: 'clawchats-media-capture', description: 'Captures MEDIA: paths from exec results for inline image rendering' });
1002
996
  // Background service: signaling + gateway bridge + future WebRTC
1003
997
  api.registerService({
1004
998
  id: 'connector-service',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@clawchatsai/connector",
3
- "version": "0.0.49",
3
+ "version": "0.0.50",
4
4
  "type": "module",
5
5
  "description": "ClawChats OpenClaw plugin — P2P tunnel + local API bridge",
6
6
  "main": "dist/index.js",