@arvoretech/runtime-lens-mcp 1.0.0

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 (42) hide show
  1. package/.vscodeignore +21 -0
  2. package/README.md +136 -0
  3. package/agent/index.ts +263 -0
  4. package/agent/tsconfig.json +17 -0
  5. package/dist/index.d.ts +7 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +17 -0
  8. package/dist/index.js.map +1 -0
  9. package/dist/log-collector.d.ts +73 -0
  10. package/dist/log-collector.d.ts.map +1 -0
  11. package/dist/log-collector.js +349 -0
  12. package/dist/log-collector.js.map +1 -0
  13. package/dist/process-inspector.d.ts +44 -0
  14. package/dist/process-inspector.d.ts.map +1 -0
  15. package/dist/process-inspector.js +190 -0
  16. package/dist/process-inspector.js.map +1 -0
  17. package/dist/runtime-interceptor.d.ts +18 -0
  18. package/dist/runtime-interceptor.d.ts.map +1 -0
  19. package/dist/runtime-interceptor.js +133 -0
  20. package/dist/runtime-interceptor.js.map +1 -0
  21. package/dist/server.d.ts +26 -0
  22. package/dist/server.d.ts.map +1 -0
  23. package/dist/server.js +301 -0
  24. package/dist/server.js.map +1 -0
  25. package/dist/types.d.ts +280 -0
  26. package/dist/types.d.ts.map +1 -0
  27. package/dist/types.js +102 -0
  28. package/dist/types.js.map +1 -0
  29. package/eslint.config.js +41 -0
  30. package/extension/decorator.ts +144 -0
  31. package/extension/extension.ts +98 -0
  32. package/extension/runtime-bridge.ts +206 -0
  33. package/extension/tsconfig.json +17 -0
  34. package/package.json +134 -0
  35. package/src/index.ts +18 -0
  36. package/src/log-collector.ts +441 -0
  37. package/src/process-inspector.ts +235 -0
  38. package/src/runtime-interceptor.ts +152 -0
  39. package/src/server.ts +387 -0
  40. package/src/types.ts +128 -0
  41. package/tsconfig.json +20 -0
  42. package/vitest.config.ts +13 -0
@@ -0,0 +1,349 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { readFile, readdir, stat } from "node:fs/promises";
3
+ import { join, basename } from "node:path";
4
+ const MAX_BUFFER_SIZE = 10000;
5
+ export class LogCollector {
6
+ buffer = {
7
+ logs: [],
8
+ requests: [],
9
+ metrics: [],
10
+ };
11
+ logPaths;
12
+ projectRoot;
13
+ constructor(projectRoot, logPaths) {
14
+ this.projectRoot = projectRoot || process.cwd();
15
+ this.logPaths = logPaths || [];
16
+ }
17
+ async collectFromFiles() {
18
+ const paths = this.logPaths.length > 0
19
+ ? this.logPaths
20
+ : await this.discoverLogFiles();
21
+ for (const filePath of paths) {
22
+ try {
23
+ const content = await readFile(filePath, "utf-8");
24
+ const entries = this.parseLogFile(content, filePath);
25
+ this.addLogs(entries);
26
+ }
27
+ catch {
28
+ // skip unreadable files
29
+ }
30
+ }
31
+ }
32
+ async collectFromProcess() {
33
+ const mem = process.memoryUsage();
34
+ const cpu = process.cpuUsage();
35
+ this.addMetric({
36
+ name: "memory.rss",
37
+ value: mem.rss,
38
+ unit: "bytes",
39
+ timestamp: new Date().toISOString(),
40
+ tags: { source: "process" },
41
+ });
42
+ this.addMetric({
43
+ name: "memory.heap_used",
44
+ value: mem.heapUsed,
45
+ unit: "bytes",
46
+ timestamp: new Date().toISOString(),
47
+ tags: { source: "process" },
48
+ });
49
+ this.addMetric({
50
+ name: "cpu.user",
51
+ value: cpu.user,
52
+ unit: "microseconds",
53
+ timestamp: new Date().toISOString(),
54
+ tags: { source: "process" },
55
+ });
56
+ this.addMetric({
57
+ name: "cpu.system",
58
+ value: cpu.system,
59
+ unit: "microseconds",
60
+ timestamp: new Date().toISOString(),
61
+ tags: { source: "process" },
62
+ });
63
+ }
64
+ async scanProjectStructure() {
65
+ const framework = await this.detectFramework();
66
+ const logFiles = await this.discoverLogFiles();
67
+ const configFiles = await this.discoverConfigFiles();
68
+ return { framework, logFiles, configFiles };
69
+ }
70
+ addLog(entry) {
71
+ this.buffer.logs.push({
72
+ ...entry,
73
+ id: randomUUID(),
74
+ timestamp: new Date().toISOString(),
75
+ });
76
+ this.trimBuffer("logs");
77
+ }
78
+ addLogs(entries) {
79
+ this.buffer.logs.push(...entries);
80
+ this.trimBuffer("logs");
81
+ }
82
+ addRequest(request) {
83
+ this.buffer.requests.push({
84
+ ...request,
85
+ id: randomUUID(),
86
+ timestamp: new Date().toISOString(),
87
+ });
88
+ this.trimBuffer("requests");
89
+ }
90
+ addMetric(metric) {
91
+ this.buffer.metrics.push(metric);
92
+ this.trimBuffer("metrics");
93
+ }
94
+ getLogs(options) {
95
+ let logs = [...this.buffer.logs];
96
+ if (options?.level) {
97
+ logs = logs.filter((l) => l.level === options.level);
98
+ }
99
+ if (options?.framework) {
100
+ logs = logs.filter((l) => l.framework === options.framework);
101
+ }
102
+ if (options?.source) {
103
+ logs = logs.filter((l) => l.source?.includes(options.source));
104
+ }
105
+ const limit = options?.lines || 50;
106
+ return logs.slice(-limit);
107
+ }
108
+ searchLogs(options) {
109
+ let logs = [...this.buffer.logs];
110
+ const regex = new RegExp(options.query, "i");
111
+ if (options.since) {
112
+ const sinceDate = new Date(options.since);
113
+ logs = logs.filter((l) => new Date(l.timestamp) >= sinceDate);
114
+ }
115
+ if (options.level) {
116
+ logs = logs.filter((l) => l.level === options.level);
117
+ }
118
+ if (options.framework) {
119
+ logs = logs.filter((l) => l.framework === options.framework);
120
+ }
121
+ logs = logs.filter((l) => regex.test(l.message) ||
122
+ (l.stackTrace && regex.test(l.stackTrace)) ||
123
+ (l.source && regex.test(l.source)));
124
+ return logs.slice(-(options.limit || 50));
125
+ }
126
+ getErrors(options) {
127
+ let errors = this.buffer.logs.filter((l) => l.level === "error" || l.level === "fatal");
128
+ if (options?.framework) {
129
+ errors = errors.filter((l) => l.framework === options.framework);
130
+ }
131
+ if (options?.grouped) {
132
+ const groups = new Map();
133
+ for (const error of errors) {
134
+ const key = error.message.slice(0, 100);
135
+ const existing = groups.get(key);
136
+ if (existing) {
137
+ existing.count++;
138
+ if (error.timestamp > existing.lastSeen) {
139
+ existing.lastSeen = error.timestamp;
140
+ existing.sample = error;
141
+ }
142
+ }
143
+ else {
144
+ groups.set(key, { count: 1, lastSeen: error.timestamp, sample: error });
145
+ }
146
+ }
147
+ return Array.from(groups.entries())
148
+ .map(([message, data]) => ({ message, ...data }))
149
+ .sort((a, b) => b.count - a.count)
150
+ .slice(0, options?.limit || 20);
151
+ }
152
+ return errors.slice(-(options?.limit || 20));
153
+ }
154
+ getRequests(options) {
155
+ let requests = [...this.buffer.requests];
156
+ if (options?.id) {
157
+ return requests.filter((r) => r.id === options.id);
158
+ }
159
+ if (options?.method) {
160
+ requests = requests.filter((r) => r.method.toUpperCase() === options.method.toUpperCase());
161
+ }
162
+ if (options?.urlPattern) {
163
+ const regex = new RegExp(options.urlPattern, "i");
164
+ requests = requests.filter((r) => regex.test(r.url));
165
+ }
166
+ if (options?.statusCode) {
167
+ requests = requests.filter((r) => r.statusCode === options.statusCode);
168
+ }
169
+ return requests.slice(-(options?.limit || 20));
170
+ }
171
+ getMetrics(options) {
172
+ let metrics = [...this.buffer.metrics];
173
+ if (options?.metric) {
174
+ metrics = metrics.filter((m) => m.name.includes(options.metric));
175
+ }
176
+ if (options?.since) {
177
+ const sinceDate = new Date(options.since);
178
+ metrics = metrics.filter((m) => new Date(m.timestamp) >= sinceDate);
179
+ }
180
+ return metrics.slice(-(options?.limit || 20));
181
+ }
182
+ clearLogs() {
183
+ const count = this.buffer.logs.length + this.buffer.requests.length + this.buffer.metrics.length;
184
+ this.buffer = { logs: [], requests: [], metrics: [] };
185
+ return { cleared: count };
186
+ }
187
+ getStats() {
188
+ const byLevel = {};
189
+ const byFramework = {};
190
+ for (const log of this.buffer.logs) {
191
+ byLevel[log.level] = (byLevel[log.level] || 0) + 1;
192
+ const fw = log.framework || "unknown";
193
+ byFramework[fw] = (byFramework[fw] || 0) + 1;
194
+ }
195
+ return {
196
+ totalLogs: this.buffer.logs.length,
197
+ totalRequests: this.buffer.requests.length,
198
+ totalMetrics: this.buffer.metrics.length,
199
+ byLevel,
200
+ byFramework,
201
+ };
202
+ }
203
+ parseLogFile(content, filePath) {
204
+ const lines = content.split("\n").filter(Boolean);
205
+ const entries = [];
206
+ const framework = this.inferFramework(filePath);
207
+ for (const line of lines) {
208
+ const entry = this.parseLogLine(line, filePath, framework);
209
+ if (entry)
210
+ entries.push(entry);
211
+ }
212
+ return entries;
213
+ }
214
+ parseLogLine(line, source, framework) {
215
+ const jsonMatch = this.tryParseJson(line);
216
+ if (jsonMatch) {
217
+ return {
218
+ id: randomUUID(),
219
+ timestamp: jsonMatch.timestamp || jsonMatch.time || new Date().toISOString(),
220
+ level: this.normalizeLevel(jsonMatch.level || jsonMatch.severity || "info"),
221
+ message: jsonMatch.message || jsonMatch.msg || JSON.stringify(jsonMatch),
222
+ source: basename(source),
223
+ framework,
224
+ metadata: jsonMatch,
225
+ };
226
+ }
227
+ const timestampRegex = /^(\d{4}-\d{2}-\d{2}[T ]\d{2}:\d{2}:\d{2}[.\d]*Z?)\s*/;
228
+ const levelRegex = /\b(DEBUG|INFO|WARN|ERROR|FATAL|debug|info|warn|error|fatal)\b/;
229
+ const tsMatch = line.match(timestampRegex);
230
+ const lvlMatch = line.match(levelRegex);
231
+ return {
232
+ id: randomUUID(),
233
+ timestamp: tsMatch?.[1] || new Date().toISOString(),
234
+ level: this.normalizeLevel(lvlMatch?.[1] || "info"),
235
+ message: line,
236
+ source: basename(source),
237
+ framework,
238
+ };
239
+ }
240
+ tryParseJson(line) {
241
+ try {
242
+ const parsed = JSON.parse(line.trim());
243
+ if (typeof parsed === "object" && parsed !== null)
244
+ return parsed;
245
+ }
246
+ catch {
247
+ // not JSON
248
+ }
249
+ return null;
250
+ }
251
+ normalizeLevel(level) {
252
+ const normalized = level.toLowerCase();
253
+ if (["debug", "info", "warn", "error", "fatal"].includes(normalized)) {
254
+ return normalized;
255
+ }
256
+ if (normalized === "warning")
257
+ return "warn";
258
+ if (normalized === "critical" || normalized === "emergency")
259
+ return "fatal";
260
+ if (normalized === "trace" || normalized === "verbose")
261
+ return "debug";
262
+ return "info";
263
+ }
264
+ inferFramework(filePath) {
265
+ if (filePath.includes(".next") || filePath.includes("next"))
266
+ return "nextjs";
267
+ if (filePath.includes("nest") || filePath.includes("dist/main"))
268
+ return "nestjs";
269
+ if (filePath.includes("react") || filePath.includes("src/App"))
270
+ return "react";
271
+ return "unknown";
272
+ }
273
+ async detectFramework() {
274
+ try {
275
+ const pkgPath = join(this.projectRoot, "package.json");
276
+ const content = await readFile(pkgPath, "utf-8");
277
+ const pkg = JSON.parse(content);
278
+ const deps = { ...pkg.dependencies, ...pkg.devDependencies };
279
+ if (deps["@nestjs/core"])
280
+ return "nestjs";
281
+ if (deps["next"])
282
+ return "nextjs";
283
+ if (deps["react"])
284
+ return "react";
285
+ }
286
+ catch {
287
+ // no package.json
288
+ }
289
+ return "unknown";
290
+ }
291
+ async discoverLogFiles() {
292
+ const candidates = [
293
+ "logs",
294
+ ".next/server",
295
+ "dist",
296
+ "tmp",
297
+ ];
298
+ const logFiles = [];
299
+ for (const dir of candidates) {
300
+ const fullPath = join(this.projectRoot, dir);
301
+ try {
302
+ const dirStat = await stat(fullPath);
303
+ if (!dirStat.isDirectory())
304
+ continue;
305
+ const files = await readdir(fullPath);
306
+ for (const file of files) {
307
+ if (file.endsWith(".log") || file.endsWith(".json")) {
308
+ logFiles.push(join(fullPath, file));
309
+ }
310
+ }
311
+ }
312
+ catch {
313
+ // directory doesn't exist
314
+ }
315
+ }
316
+ return logFiles;
317
+ }
318
+ async discoverConfigFiles() {
319
+ const candidates = [
320
+ "package.json",
321
+ "tsconfig.json",
322
+ "next.config.js",
323
+ "next.config.mjs",
324
+ "nest-cli.json",
325
+ ".env",
326
+ ".env.local",
327
+ "vite.config.ts",
328
+ "webpack.config.js",
329
+ ];
330
+ const found = [];
331
+ for (const file of candidates) {
332
+ try {
333
+ await stat(join(this.projectRoot, file));
334
+ found.push(file);
335
+ }
336
+ catch {
337
+ // doesn't exist
338
+ }
339
+ }
340
+ return found;
341
+ }
342
+ trimBuffer(key) {
343
+ const arr = this.buffer[key];
344
+ if (arr.length > MAX_BUFFER_SIZE) {
345
+ this.buffer[key] = arr.slice(-MAX_BUFFER_SIZE);
346
+ }
347
+ }
348
+ }
349
+ //# sourceMappingURL=log-collector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-collector.js","sourceRoot":"","sources":["../src/log-collector.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ import { ProcessInfo, Framework } from "./types.js";
2
+ interface RunningProcess {
3
+ pid: number;
4
+ command: string;
5
+ port?: number;
6
+ framework?: Framework;
7
+ }
8
+ export declare class ProcessInspector {
9
+ private readonly projectRoot;
10
+ constructor(projectRoot?: string);
11
+ getProcessInfo(): ProcessInfo;
12
+ findRunningProcesses(): Promise<RunningProcess[]>;
13
+ getPortListeners(): Promise<{
14
+ port: number;
15
+ pid: number;
16
+ process: string;
17
+ }[]>;
18
+ getEnvironmentInfo(): Promise<{
19
+ process: ProcessInfo;
20
+ runningProcesses: RunningProcess[];
21
+ ports: {
22
+ port: number;
23
+ pid: number;
24
+ process: string;
25
+ }[];
26
+ projectStructure: {
27
+ framework: Framework;
28
+ logFiles: string[];
29
+ configFiles: string[];
30
+ };
31
+ }>;
32
+ executeExpression(expression: string): Promise<{
33
+ result: string;
34
+ type: string;
35
+ }>;
36
+ private scanProject;
37
+ private detectProjectFramework;
38
+ private findConfigFiles;
39
+ private findLogFiles;
40
+ private detectFrameworkFromCommand;
41
+ private findPortForPid;
42
+ }
43
+ export {};
44
+ //# sourceMappingURL=process-inspector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"process-inspector.d.ts","sourceRoot":"","sources":["../src/process-inspector.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAoB,MAAM,YAAY,CAAC;AAItE,UAAU,cAAc;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,SAAS,CAAC;CACvB;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;gBAEzB,WAAW,CAAC,EAAE,MAAM;IAIhC,cAAc,IAAI,WAAW;IAwBvB,oBAAoB,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IA2BjD,gBAAgB,IAAI,OAAO,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IA8B7E,kBAAkB,IAAI,OAAO,CAAC;QAClC,OAAO,EAAE,WAAW,CAAC;QACrB,gBAAgB,EAAE,cAAc,EAAE,CAAC;QACnC,KAAK,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,GAAG,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,MAAM,CAAA;SAAE,EAAE,CAAC;QACxD,gBAAgB,EAAE;YAChB,SAAS,EAAE,SAAS,CAAC;YACrB,QAAQ,EAAE,MAAM,EAAE,CAAC;YACnB,WAAW,EAAE,MAAM,EAAE,CAAC;SACvB,CAAC;KACH,CAAC;IAeI,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;YAiBxE,WAAW;YAYX,sBAAsB;YAetB,eAAe;YAoBf,YAAY;IAwB1B,OAAO,CAAC,0BAA0B;YAOpB,cAAc;CAY7B"}
@@ -0,0 +1,190 @@
1
+ import { exec } from "node:child_process";
2
+ import { readFile, readdir, stat } from "node:fs/promises";
3
+ import { join } from "node:path";
4
+ import { promisify } from "node:util";
5
+ import { RuntimeLensError } from "./types.js";
6
+ const execAsync = promisify(exec);
7
+ export class ProcessInspector {
8
+ projectRoot;
9
+ constructor(projectRoot) {
10
+ this.projectRoot = projectRoot || process.cwd();
11
+ }
12
+ getProcessInfo() {
13
+ const mem = process.memoryUsage();
14
+ const cpu = process.cpuUsage();
15
+ return {
16
+ pid: process.pid,
17
+ uptime: process.uptime(),
18
+ memoryUsage: {
19
+ rss: mem.rss,
20
+ heapTotal: mem.heapTotal,
21
+ heapUsed: mem.heapUsed,
22
+ external: mem.external,
23
+ },
24
+ cpuUsage: {
25
+ user: cpu.user,
26
+ system: cpu.system,
27
+ },
28
+ nodeVersion: process.version,
29
+ platform: process.platform,
30
+ arch: process.arch,
31
+ cwd: process.cwd(),
32
+ };
33
+ }
34
+ async findRunningProcesses() {
35
+ const processes = [];
36
+ try {
37
+ const { stdout } = await execAsync("ps aux | grep -E '(node|next|nest|react-scripts)' | grep -v grep");
38
+ for (const line of stdout.split("\n").filter(Boolean)) {
39
+ const parts = line.trim().split(/\s+/);
40
+ const pid = parseInt(parts[1], 10);
41
+ const command = parts.slice(10).join(" ");
42
+ if (isNaN(pid))
43
+ continue;
44
+ const framework = this.detectFrameworkFromCommand(command);
45
+ const port = await this.findPortForPid(pid);
46
+ processes.push({ pid, command, port: port || undefined, framework });
47
+ }
48
+ }
49
+ catch {
50
+ // ps command failed
51
+ }
52
+ return processes;
53
+ }
54
+ async getPortListeners() {
55
+ const listeners = [];
56
+ try {
57
+ const { stdout } = await execAsync("lsof -iTCP -sTCP:LISTEN -P -n 2>/dev/null | grep node || true");
58
+ for (const line of stdout.split("\n").filter(Boolean)) {
59
+ const parts = line.trim().split(/\s+/);
60
+ const processName = parts[0];
61
+ const pid = parseInt(parts[1], 10);
62
+ const portRegex = /:(\d+)$/;
63
+ const portMatch = parts[8] ? portRegex.exec(parts[8]) : null;
64
+ if (!isNaN(pid) && portMatch) {
65
+ listeners.push({
66
+ port: parseInt(portMatch[1], 10),
67
+ pid,
68
+ process: processName,
69
+ });
70
+ }
71
+ }
72
+ }
73
+ catch {
74
+ // lsof failed
75
+ }
76
+ return listeners;
77
+ }
78
+ async getEnvironmentInfo() {
79
+ const [runningProcesses, ports, projectStructure] = await Promise.all([
80
+ this.findRunningProcesses(),
81
+ this.getPortListeners(),
82
+ this.scanProject(),
83
+ ]);
84
+ return {
85
+ process: this.getProcessInfo(),
86
+ runningProcesses,
87
+ ports,
88
+ projectStructure,
89
+ };
90
+ }
91
+ async executeExpression(expression) {
92
+ try {
93
+ const fn = new Function("require", `return (${expression})`);
94
+ const result = fn(require);
95
+ const type = typeof result;
96
+ return {
97
+ result: typeof result === "object" ? JSON.stringify(result, null, 2) : String(result),
98
+ type,
99
+ };
100
+ }
101
+ catch (error) {
102
+ throw new RuntimeLensError(`Expression evaluation failed: ${error instanceof Error ? error.message : String(error)}`, "EVAL_FAILED");
103
+ }
104
+ }
105
+ async scanProject() {
106
+ const framework = await this.detectProjectFramework();
107
+ const configFiles = await this.findConfigFiles();
108
+ const logFiles = await this.findLogFiles();
109
+ return { framework, logFiles, configFiles };
110
+ }
111
+ async detectProjectFramework() {
112
+ try {
113
+ const content = await readFile(join(this.projectRoot, "package.json"), "utf-8");
114
+ const pkg = JSON.parse(content);
115
+ const deps = { ...pkg.dependencies, ...pkg.devDependencies };
116
+ if (deps["@nestjs/core"])
117
+ return "nestjs";
118
+ if (deps["next"])
119
+ return "nextjs";
120
+ if (deps["react"])
121
+ return "react";
122
+ }
123
+ catch {
124
+ // no package.json
125
+ }
126
+ return "unknown";
127
+ }
128
+ async findConfigFiles() {
129
+ const candidates = [
130
+ "package.json", "tsconfig.json", "next.config.js", "next.config.mjs",
131
+ "next.config.ts", "nest-cli.json", ".env", ".env.local",
132
+ "vite.config.ts", "webpack.config.js", "tailwind.config.js",
133
+ "tailwind.config.ts", "postcss.config.js",
134
+ ];
135
+ const found = [];
136
+ for (const file of candidates) {
137
+ try {
138
+ await stat(join(this.projectRoot, file));
139
+ found.push(file);
140
+ }
141
+ catch {
142
+ // doesn't exist
143
+ }
144
+ }
145
+ return found;
146
+ }
147
+ async findLogFiles() {
148
+ const dirs = ["logs", ".next/server", "dist", "tmp"];
149
+ const logFiles = [];
150
+ for (const dir of dirs) {
151
+ try {
152
+ const fullPath = join(this.projectRoot, dir);
153
+ const dirStat = await stat(fullPath);
154
+ if (!dirStat.isDirectory())
155
+ continue;
156
+ const files = await readdir(fullPath);
157
+ for (const file of files) {
158
+ if (file.endsWith(".log")) {
159
+ logFiles.push(join(dir, file));
160
+ }
161
+ }
162
+ }
163
+ catch {
164
+ // skip
165
+ }
166
+ }
167
+ return logFiles;
168
+ }
169
+ detectFrameworkFromCommand(command) {
170
+ if (command.includes("next"))
171
+ return "nextjs";
172
+ if (command.includes("nest"))
173
+ return "nestjs";
174
+ if (command.includes("react-scripts") || command.includes("vite"))
175
+ return "react";
176
+ return "unknown";
177
+ }
178
+ async findPortForPid(pid) {
179
+ try {
180
+ const { stdout } = await execAsync(`lsof -iTCP -sTCP:LISTEN -P -n -p ${pid} 2>/dev/null | tail -1`);
181
+ const portRegex = /:(\d+)\s/;
182
+ const portMatch = portRegex.exec(stdout);
183
+ return portMatch ? parseInt(portMatch[1], 10) : null;
184
+ }
185
+ catch {
186
+ return null;
187
+ }
188
+ }
189
+ }
190
+ //# sourceMappingURL=process-inspector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"process-inspector.js","sourceRoot":"","sources":["../src/process-inspector.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { LogCollector } from "./log-collector.js";
2
+ import type { Framework } from "./types.js";
3
+ export declare class RuntimeInterceptor {
4
+ private originalConsole;
5
+ private intercepting;
6
+ private readonly collector;
7
+ private readonly framework;
8
+ constructor(collector: LogCollector, framework?: Framework);
9
+ startIntercepting(): void;
10
+ stopIntercepting(): void;
11
+ isActive(): boolean;
12
+ private interceptStderr;
13
+ private interceptUncaughtErrors;
14
+ private serialize;
15
+ private captureStack;
16
+ private inferLevel;
17
+ }
18
+ //# sourceMappingURL=runtime-interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runtime-interceptor.d.ts","sourceRoot":"","sources":["../src/runtime-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAE,SAAS,EAAY,MAAM,YAAY,CAAC;AAYtD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,eAAe,CAAkE;IACzF,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAe;IACzC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAY;gBAE1B,SAAS,EAAE,YAAY,EAAE,SAAS,GAAE,SAAqB;IAKrE,iBAAiB,IAAI,IAAI;IA4BzB,gBAAgB,IAAI,IAAI;IAaxB,QAAQ,IAAI,OAAO;IAInB,OAAO,CAAC,eAAe;IA2BvB,OAAO,CAAC,uBAAuB;IAuB/B,OAAO,CAAC,SAAS;IAejB,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,UAAU;CAQnB"}