agent-recorder 2.0.9 → 2.0.11

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.
Files changed (45) hide show
  1. package/package.json +1 -1
  2. package/vendor/node_modules/@agent-recorder/cli/commands/doctor.d.ts.map +1 -1
  3. package/vendor/node_modules/@agent-recorder/cli/commands/doctor.js +2 -2
  4. package/vendor/node_modules/@agent-recorder/cli/commands/doctor.js.map +1 -1
  5. package/vendor/node_modules/@agent-recorder/cli/commands/export.d.ts +3 -2
  6. package/vendor/node_modules/@agent-recorder/cli/commands/export.d.ts.map +1 -1
  7. package/vendor/node_modules/@agent-recorder/cli/commands/export.js +240 -19
  8. package/vendor/node_modules/@agent-recorder/cli/commands/export.js.map +1 -1
  9. package/vendor/node_modules/@agent-recorder/cli/commands/sessions.d.ts.map +1 -1
  10. package/vendor/node_modules/@agent-recorder/cli/commands/sessions.js +9 -17
  11. package/vendor/node_modules/@agent-recorder/cli/commands/sessions.js.map +1 -1
  12. package/vendor/node_modules/@agent-recorder/cli/commands/status.d.ts.map +1 -1
  13. package/vendor/node_modules/@agent-recorder/cli/commands/status.js +7 -4
  14. package/vendor/node_modules/@agent-recorder/cli/commands/status.js.map +1 -1
  15. package/vendor/node_modules/@agent-recorder/cli/tui/App.d.ts.map +1 -1
  16. package/vendor/node_modules/@agent-recorder/cli/tui/App.js +2 -3
  17. package/vendor/node_modules/@agent-recorder/cli/tui/App.js.map +1 -1
  18. package/vendor/node_modules/@agent-recorder/core/config.d.ts +9 -0
  19. package/vendor/node_modules/@agent-recorder/core/config.d.ts.map +1 -1
  20. package/vendor/node_modules/@agent-recorder/core/config.js +19 -0
  21. package/vendor/node_modules/@agent-recorder/core/config.js.map +1 -1
  22. package/vendor/node_modules/@agent-recorder/core/config.test.js +24 -1
  23. package/vendor/node_modules/@agent-recorder/core/config.test.js.map +1 -1
  24. package/vendor/node_modules/@agent-recorder/core/daemon-paths.d.ts +15 -0
  25. package/vendor/node_modules/@agent-recorder/core/daemon-paths.d.ts.map +1 -1
  26. package/vendor/node_modules/@agent-recorder/core/daemon-paths.js +49 -0
  27. package/vendor/node_modules/@agent-recorder/core/daemon-paths.js.map +1 -1
  28. package/vendor/node_modules/@agent-recorder/core/daemon-paths.test.js +83 -1
  29. package/vendor/node_modules/@agent-recorder/core/daemon-paths.test.js.map +1 -1
  30. package/vendor/node_modules/@agent-recorder/core/index.d.ts +1 -1
  31. package/vendor/node_modules/@agent-recorder/core/index.d.ts.map +1 -1
  32. package/vendor/node_modules/@agent-recorder/core/index.js +1 -1
  33. package/vendor/node_modules/@agent-recorder/core/index.js.map +1 -1
  34. package/vendor/node_modules/@agent-recorder/hooks/handler.js +7 -4
  35. package/vendor/node_modules/@agent-recorder/hooks/handler.js.map +1 -1
  36. package/vendor/node_modules/@agent-recorder/service/index.d.ts.map +1 -1
  37. package/vendor/node_modules/@agent-recorder/service/index.js +6 -3
  38. package/vendor/node_modules/@agent-recorder/service/index.js.map +1 -1
  39. package/vendor/node_modules/@agent-recorder/service/routes/hooks.d.ts.map +1 -1
  40. package/vendor/node_modules/@agent-recorder/service/routes/hooks.js +27 -1
  41. package/vendor/node_modules/@agent-recorder/service/routes/hooks.js.map +1 -1
  42. package/vendor/node_modules/@agent-recorder/service/server.d.ts +3 -1
  43. package/vendor/node_modules/@agent-recorder/service/server.d.ts.map +1 -1
  44. package/vendor/node_modules/@agent-recorder/service/server.js +53 -6
  45. package/vendor/node_modules/@agent-recorder/service/server.js.map +1 -1
@@ -6,6 +6,22 @@
6
6
  */
7
7
  import { randomUUID } from "node:crypto";
8
8
  import { insertEvent, createSession, getSessionById, allocateSequence, } from "@agent-recorder/core";
9
+ /** Truncate a string for logging */
10
+ function truncateForLog(value, maxLength = 100) {
11
+ if (value === null || value === undefined)
12
+ return "(none)";
13
+ const str = typeof value === "string" ? value : JSON.stringify(value);
14
+ if (str.length <= maxLength)
15
+ return str;
16
+ return str.slice(0, maxLength) + "...";
17
+ }
18
+ /** Format tool call for logging */
19
+ function formatToolCallLog(toolName, upstreamKey, input, output) {
20
+ const server = upstreamKey ?? "builtin";
21
+ const inputSummary = input ? truncateForLog(input, 150) : "(no input)";
22
+ const outputSummary = output ? truncateForLog(output, 150) : "(no output)";
23
+ return `[${server}] ${toolName}\n Input: ${inputSummary}\n Output: ${outputSummary}`;
24
+ }
9
25
  /** Get or create a session by ID */
10
26
  function getOrCreateSession(db, sessionId) {
11
27
  // Check if session exists
@@ -84,6 +100,11 @@ export async function registerHooksRoutes(app, options) {
84
100
  const { eventType, cleanName, upstreamKey } = parseToolName(payload.tool_name);
85
101
  const now = new Date().toISOString();
86
102
  const sequence = allocateSequence(db, session.id);
103
+ // Determine MCP method from tool input if available
104
+ let mcpMethod = "tools/call";
105
+ if (payload.tool_input?.method) {
106
+ mcpMethod = String(payload.tool_input.method);
107
+ }
87
108
  const eventInput = {
88
109
  id: randomUUID(),
89
110
  sessionId: session.id,
@@ -93,7 +114,7 @@ export async function registerHooksRoutes(app, options) {
93
114
  agentRole: "main",
94
115
  agentName: "claude-code",
95
116
  toolName: cleanName,
96
- mcpMethod: "tools/call",
117
+ mcpMethod,
97
118
  upstreamKey: upstreamKey,
98
119
  startedAt: now,
99
120
  endedAt: now,
@@ -106,6 +127,11 @@ export async function registerHooksRoutes(app, options) {
106
127
  : null,
107
128
  };
108
129
  const event = insertEvent(db, eventInput);
130
+ // Always log tool calls with details (useful for debugging)
131
+ const isMcpTool = upstreamKey && upstreamKey !== "builtin";
132
+ if (isMcpTool || debug) {
133
+ console.log(`[hooks] ${formatToolCallLog(cleanName, upstreamKey, payload.tool_input, payload.tool_response)}`);
134
+ }
109
135
  if (debug) {
110
136
  console.log(`[hooks] Recorded ${eventType}: ${cleanName} (event ${event.id})`);
111
137
  }
@@ -1 +1 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/routes/hooks.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/routes/hooks.ts"],"names":[],"mappings":"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"}
@@ -15,6 +15,8 @@ export interface CreateServerOptions {
15
15
  export declare function createServer(options: CreateServerOptions): Promise<FastifyInstance>;
16
16
  /**
17
17
  * Start the server on localhost only.
18
+ * If the preferred port is in use, tries up to 10 sequential ports.
19
+ * Returns the actual port the server bound to.
18
20
  */
19
- export declare function startServer(app: FastifyInstance, port: number): Promise<void>;
21
+ export declare function startServer(app: FastifyInstance, preferredPort: number): Promise<number>;
20
22
  //# sourceMappingURL=server.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAgB,EAAE,KAAK,eAAe,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAO3C,MAAM,WAAW,mBAAmB;IAClC,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,OAAO,EAAE,mBAAmB,GAC3B,OAAO,CAAC,eAAe,CAAC,CAkB1B;AAED;;GAEG;AACH,wBAAsB,WAAW,CAC/B,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,IAAI,CAAC,CAMf"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAgB,EAAE,KAAK,eAAe,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAO3C,MAAM,WAAW,mBAAmB;IAClC,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,OAAO,EAAE,mBAAmB,GAC3B,OAAO,CAAC,eAAe,CAAC,CAkB1B;AAwCD;;;;GAIG;AACH,wBAAsB,WAAW,CAC/B,GAAG,EAAE,eAAe,EACpB,aAAa,EAAE,MAAM,GACpB,OAAO,CAAC,MAAM,CAAC,CAwBjB"}
@@ -2,6 +2,7 @@
2
2
  * Fastify server factory.
3
3
  * Creates and configures the daemon server.
4
4
  */
5
+ import { createServer as createTcpServer } from "node:net";
5
6
  import Fastify, {} from "fastify";
6
7
  import { registerHealthRoutes } from "./routes/health.js";
7
8
  import { registerSessionsRoutes } from "./routes/sessions.js";
@@ -28,13 +29,59 @@ export async function createServer(options) {
28
29
  return app;
29
30
  }
30
31
  /**
31
- * Start the server on localhost only.
32
+ * Check if a port is available by attempting to bind a temporary server.
33
+ * This avoids calling Fastify's listen() multiple times on the same instance.
32
34
  */
33
- export async function startServer(app, port) {
34
- await app.listen({
35
- port,
36
- host: "127.0.0.1", // localhost only
35
+ function isPortAvailable(port, host) {
36
+ return new Promise((resolve) => {
37
+ const server = createTcpServer();
38
+ server.on("error", () => resolve(false));
39
+ server.on("listening", () => {
40
+ server.close(() => resolve(true));
41
+ });
42
+ server.listen(port, host);
37
43
  });
38
- console.log(`Agent Recorder daemon listening on http://127.0.0.1:${port}`);
44
+ }
45
+ /**
46
+ * Find the first available port in a range.
47
+ * Returns the port number or null if none available.
48
+ */
49
+ async function findAvailablePort(preferredPort, maxAttempts, host) {
50
+ for (let i = 0; i < maxAttempts; i++) {
51
+ const port = preferredPort + i;
52
+ // Bounds check: valid port range is 1-65535
53
+ if (port > 65535) {
54
+ return null;
55
+ }
56
+ if (await isPortAvailable(port, host)) {
57
+ return port;
58
+ }
59
+ console.log(`Port ${port} in use, trying ${port + 1}...`);
60
+ }
61
+ return null;
62
+ }
63
+ /**
64
+ * Start the server on localhost only.
65
+ * If the preferred port is in use, tries up to 10 sequential ports.
66
+ * Returns the actual port the server bound to.
67
+ */
68
+ export async function startServer(app, preferredPort) {
69
+ const maxAttempts = 10;
70
+ const host = "127.0.0.1";
71
+ // Find an available port first (avoids calling app.listen multiple times)
72
+ const port = await findAvailablePort(preferredPort, maxAttempts, host);
73
+ if (port === null) {
74
+ const maxPort = Math.min(preferredPort + maxAttempts - 1, 65535);
75
+ throw new Error(`No available port in range ${preferredPort}-${maxPort}`);
76
+ }
77
+ // Now call app.listen exactly once
78
+ await app.listen({ port, host });
79
+ if (port !== preferredPort) {
80
+ console.log(`Port ${preferredPort} in use - bound to http://${host}:${port} instead`);
81
+ }
82
+ else {
83
+ console.log(`Agent Recorder daemon listening on http://${host}:${port}`);
84
+ }
85
+ return port;
39
86
  }
40
87
  //# sourceMappingURL=server.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.js","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,OAAO,EAAE,EAAwB,MAAM,SAAS,CAAC;AAExD,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAQxD;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,OAA4B;IAE5B,MAAM,EAAE,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAEhD,MAAM,GAAG,GAAG,OAAO,CAAC;QAClB,MAAM,EAAE,IAAI;KACb,CAAC,CAAC;IAEH,kBAAkB;IAClB,MAAM,oBAAoB,CAAC,GAAG,CAAC,CAAC;IAChC,MAAM,sBAAsB,CAAC,GAAG,EAAE;QAChC,EAAE;QACF,gBAAgB,EAAE,gBAAgB,IAAI,IAAI;KAC3C,CAAC,CAAC;IACH,MAAM,oBAAoB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;IACxC,MAAM,mBAAmB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,EAAE,CAAC,CAAC;IAC9D,MAAM,mBAAmB,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,EAAE,CAAC,CAAC;IAE9D,OAAO,GAAG,CAAC;AACb,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,GAAoB,EACpB,IAAY;IAEZ,MAAM,GAAG,CAAC,MAAM,CAAC;QACf,IAAI;QACJ,IAAI,EAAE,WAAW,EAAE,iBAAiB;KACrC,CAAC,CAAC;IACH,OAAO,CAAC,GAAG,CAAC,uDAAuD,IAAI,EAAE,CAAC,CAAC;AAC7E,CAAC"}
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"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"}