wiretap-mcp 2.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 (105) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +174 -0
  3. package/dist/index.d.ts +3 -0
  4. package/dist/index.d.ts.map +1 -0
  5. package/dist/index.js +68 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/monitors/crash-android.d.ts +20 -0
  8. package/dist/monitors/crash-android.d.ts.map +1 -0
  9. package/dist/monitors/crash-android.js +134 -0
  10. package/dist/monitors/crash-android.js.map +1 -0
  11. package/dist/monitors/crash-ios.d.ts +17 -0
  12. package/dist/monitors/crash-ios.d.ts.map +1 -0
  13. package/dist/monitors/crash-ios.js +116 -0
  14. package/dist/monitors/crash-ios.js.map +1 -0
  15. package/dist/monitors/hermes.d.ts +26 -0
  16. package/dist/monitors/hermes.d.ts.map +1 -0
  17. package/dist/monitors/hermes.js +175 -0
  18. package/dist/monitors/hermes.js.map +1 -0
  19. package/dist/monitors/reactotron.d.ts +18 -0
  20. package/dist/monitors/reactotron.d.ts.map +1 -0
  21. package/dist/monitors/reactotron.js +106 -0
  22. package/dist/monitors/reactotron.js.map +1 -0
  23. package/dist/monitors/terminal.d.ts +25 -0
  24. package/dist/monitors/terminal.d.ts.map +1 -0
  25. package/dist/monitors/terminal.js +154 -0
  26. package/dist/monitors/terminal.js.map +1 -0
  27. package/dist/parsers/cdp-parser.d.ts +64 -0
  28. package/dist/parsers/cdp-parser.d.ts.map +1 -0
  29. package/dist/parsers/cdp-parser.js +115 -0
  30. package/dist/parsers/cdp-parser.js.map +1 -0
  31. package/dist/parsers/crash-parser.d.ts +5 -0
  32. package/dist/parsers/crash-parser.d.ts.map +1 -0
  33. package/dist/parsers/crash-parser.js +112 -0
  34. package/dist/parsers/crash-parser.js.map +1 -0
  35. package/dist/parsers/log-parser.d.ts +5 -0
  36. package/dist/parsers/log-parser.d.ts.map +1 -0
  37. package/dist/parsers/log-parser.js +141 -0
  38. package/dist/parsers/log-parser.js.map +1 -0
  39. package/dist/parsers/reactotron-parser.d.ts +17 -0
  40. package/dist/parsers/reactotron-parser.d.ts.map +1 -0
  41. package/dist/parsers/reactotron-parser.js +83 -0
  42. package/dist/parsers/reactotron-parser.js.map +1 -0
  43. package/dist/server.d.ts +19 -0
  44. package/dist/server.d.ts.map +1 -0
  45. package/dist/server.js +224 -0
  46. package/dist/server.js.map +1 -0
  47. package/dist/storage/log-store.d.ts +41 -0
  48. package/dist/storage/log-store.d.ts.map +1 -0
  49. package/dist/storage/log-store.js +118 -0
  50. package/dist/storage/log-store.js.map +1 -0
  51. package/dist/storage/persistence.d.ts +26 -0
  52. package/dist/storage/persistence.d.ts.map +1 -0
  53. package/dist/storage/persistence.js +123 -0
  54. package/dist/storage/persistence.js.map +1 -0
  55. package/dist/tools/clear-logs.d.ts +8 -0
  56. package/dist/tools/clear-logs.d.ts.map +1 -0
  57. package/dist/tools/clear-logs.js +15 -0
  58. package/dist/tools/clear-logs.js.map +1 -0
  59. package/dist/tools/get-api-calls.d.ts +11 -0
  60. package/dist/tools/get-api-calls.d.ts.map +1 -0
  61. package/dist/tools/get-api-calls.js +26 -0
  62. package/dist/tools/get-api-calls.js.map +1 -0
  63. package/dist/tools/get-crashes.d.ts +11 -0
  64. package/dist/tools/get-crashes.d.ts.map +1 -0
  65. package/dist/tools/get-crashes.js +42 -0
  66. package/dist/tools/get-crashes.js.map +1 -0
  67. package/dist/tools/get-errors.d.ts +12 -0
  68. package/dist/tools/get-errors.d.ts.map +1 -0
  69. package/dist/tools/get-errors.js +52 -0
  70. package/dist/tools/get-errors.js.map +1 -0
  71. package/dist/tools/get-hermes-logs.d.ts +12 -0
  72. package/dist/tools/get-hermes-logs.d.ts.map +1 -0
  73. package/dist/tools/get-hermes-logs.js +33 -0
  74. package/dist/tools/get-hermes-logs.js.map +1 -0
  75. package/dist/tools/get-logs.d.ts +21 -0
  76. package/dist/tools/get-logs.d.ts.map +1 -0
  77. package/dist/tools/get-logs.js +50 -0
  78. package/dist/tools/get-logs.js.map +1 -0
  79. package/dist/tools/get-network.d.ts +12 -0
  80. package/dist/tools/get-network.d.ts.map +1 -0
  81. package/dist/tools/get-network.js +35 -0
  82. package/dist/tools/get-network.js.map +1 -0
  83. package/dist/tools/get-performance.d.ts +10 -0
  84. package/dist/tools/get-performance.d.ts.map +1 -0
  85. package/dist/tools/get-performance.js +32 -0
  86. package/dist/tools/get-performance.js.map +1 -0
  87. package/dist/tools/get-state.d.ts +11 -0
  88. package/dist/tools/get-state.d.ts.map +1 -0
  89. package/dist/tools/get-state.js +26 -0
  90. package/dist/tools/get-state.js.map +1 -0
  91. package/dist/tools/get-status.d.ts +20 -0
  92. package/dist/tools/get-status.d.ts.map +1 -0
  93. package/dist/tools/get-status.js +52 -0
  94. package/dist/tools/get-status.js.map +1 -0
  95. package/dist/tools/search-logs.d.ts +11 -0
  96. package/dist/tools/search-logs.d.ts.map +1 -0
  97. package/dist/tools/search-logs.js +68 -0
  98. package/dist/tools/search-logs.js.map +1 -0
  99. package/dist/types.d.ts +123 -0
  100. package/dist/types.d.ts.map +1 -0
  101. package/dist/types.js +3 -0
  102. package/dist/types.js.map +1 -0
  103. package/package.json +65 -0
  104. package/scripts/install.sh +33 -0
  105. package/wiretap.config.json +8 -0
@@ -0,0 +1,175 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.HermesMonitor = void 0;
7
+ const ws_1 = __importDefault(require("ws"));
8
+ const events_1 = require("events");
9
+ const http_1 = require("http");
10
+ const cdp_parser_js_1 = require("../parsers/cdp-parser.js");
11
+ class HermesMonitor extends events_1.EventEmitter {
12
+ store;
13
+ metroPort;
14
+ captureNetwork;
15
+ ws = null;
16
+ reconnectTimer = null;
17
+ discoveryTimer = null;
18
+ _connected = false;
19
+ shouldReconnect = true;
20
+ pendingRequests = new Map();
21
+ cdpMessageId = 1;
22
+ constructor(store, metroPort = 8081, captureNetwork = true) {
23
+ super();
24
+ this.store = store;
25
+ this.metroPort = metroPort;
26
+ this.captureNetwork = captureNetwork;
27
+ }
28
+ get isConnected() {
29
+ return this._connected;
30
+ }
31
+ start() {
32
+ this.shouldReconnect = true;
33
+ this.startDiscovery();
34
+ }
35
+ stop() {
36
+ this.shouldReconnect = false;
37
+ if (this.reconnectTimer) {
38
+ clearTimeout(this.reconnectTimer);
39
+ this.reconnectTimer = null;
40
+ }
41
+ if (this.discoveryTimer) {
42
+ clearInterval(this.discoveryTimer);
43
+ this.discoveryTimer = null;
44
+ }
45
+ if (this.ws) {
46
+ this.ws.close();
47
+ this.ws = null;
48
+ }
49
+ this._connected = false;
50
+ }
51
+ startDiscovery() {
52
+ this.discover();
53
+ this.discoveryTimer = setInterval(() => {
54
+ if (!this._connected) {
55
+ this.discover();
56
+ }
57
+ }, 5000);
58
+ }
59
+ discover() {
60
+ const req = (0, http_1.request)({ hostname: "localhost", port: this.metroPort, path: "/json", method: "GET", timeout: 3000 }, (res) => {
61
+ let data = "";
62
+ res.on("data", (chunk) => {
63
+ data += chunk.toString();
64
+ });
65
+ res.on("end", () => {
66
+ try {
67
+ const targets = JSON.parse(data);
68
+ const target = targets.find((t) => t.webSocketDebuggerUrl && t.title !== "React Native Experimental (Improved Chrome Reloads)");
69
+ if (target) {
70
+ this.connectToTarget(target.webSocketDebuggerUrl);
71
+ }
72
+ }
73
+ catch {
74
+ // Invalid JSON from discovery
75
+ }
76
+ });
77
+ });
78
+ req.on("error", () => {
79
+ // Metro not reachable yet
80
+ });
81
+ req.on("timeout", () => {
82
+ req.destroy();
83
+ });
84
+ req.end();
85
+ }
86
+ connectToTarget(wsUrl) {
87
+ if (this._connected || this.ws)
88
+ return;
89
+ try {
90
+ this.ws = new ws_1.default(wsUrl);
91
+ this.ws.on("open", () => {
92
+ this._connected = true;
93
+ this.emit("connected");
94
+ this.enableDomains();
95
+ });
96
+ this.ws.on("message", (data) => {
97
+ try {
98
+ const msg = JSON.parse(data.toString());
99
+ this.handleMessage(msg);
100
+ }
101
+ catch {
102
+ // Invalid JSON
103
+ }
104
+ });
105
+ this.ws.on("close", () => {
106
+ this._connected = false;
107
+ this.ws = null;
108
+ this.pendingRequests.clear();
109
+ this.emit("disconnected");
110
+ this.scheduleReconnect();
111
+ });
112
+ this.ws.on("error", () => {
113
+ this._connected = false;
114
+ if (this.ws) {
115
+ this.ws.close();
116
+ this.ws = null;
117
+ }
118
+ this.scheduleReconnect();
119
+ });
120
+ }
121
+ catch {
122
+ this.scheduleReconnect();
123
+ }
124
+ }
125
+ enableDomains() {
126
+ this.sendCDP("Runtime.enable");
127
+ if (this.captureNetwork) {
128
+ this.sendCDP("Network.enable");
129
+ }
130
+ }
131
+ sendCDP(method, params) {
132
+ if (!this.ws || this.ws.readyState !== ws_1.default.OPEN)
133
+ return;
134
+ const msg = { id: this.cdpMessageId++, method, params: params ?? {} };
135
+ this.ws.send(JSON.stringify(msg));
136
+ }
137
+ scheduleReconnect() {
138
+ if (!this.shouldReconnect)
139
+ return;
140
+ if (this.reconnectTimer)
141
+ return;
142
+ this.reconnectTimer = setTimeout(() => {
143
+ this.reconnectTimer = null;
144
+ if (this.shouldReconnect) {
145
+ this.discover();
146
+ }
147
+ }, 5000);
148
+ }
149
+ handleMessage(msg) {
150
+ if (!msg.method)
151
+ return;
152
+ const event = msg;
153
+ if ((0, cdp_parser_js_1.isCDPConsoleEvent)(event)) {
154
+ const parsed = (0, cdp_parser_js_1.parseCDPConsole)(event);
155
+ const entry = this.store.hermesLogs.add(parsed);
156
+ this.emit("log", entry);
157
+ }
158
+ else if ((0, cdp_parser_js_1.isCDPRequestEvent)(event)) {
159
+ const pending = (0, cdp_parser_js_1.parseCDPRequest)(event);
160
+ this.pendingRequests.set(pending.requestId, pending);
161
+ this.emit("network-request", pending);
162
+ }
163
+ else if ((0, cdp_parser_js_1.isCDPResponseEvent)(event)) {
164
+ const typedEvent = event;
165
+ const requestId = typedEvent.params.requestId;
166
+ const pending = this.pendingRequests.get(requestId);
167
+ this.pendingRequests.delete(requestId);
168
+ const parsed = (0, cdp_parser_js_1.parseCDPResponse)(typedEvent, pending);
169
+ const entry = this.store.networkCalls.add(parsed);
170
+ this.emit("network-response", entry);
171
+ }
172
+ }
173
+ }
174
+ exports.HermesMonitor = HermesMonitor;
175
+ //# sourceMappingURL=hermes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hermes.js","sourceRoot":"","sources":["../../src/monitors/hermes.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { EventEmitter } from "events";
2
+ import { LogStore } from "../storage/log-store.js";
3
+ export declare class ReactotronMonitor extends EventEmitter {
4
+ private store;
5
+ private port;
6
+ private ws;
7
+ private reconnectTimer;
8
+ private _connected;
9
+ private shouldReconnect;
10
+ constructor(store: LogStore, port?: number);
11
+ get isConnected(): boolean;
12
+ start(): void;
13
+ stop(): void;
14
+ private connect;
15
+ private scheduleReconnect;
16
+ private handleMessage;
17
+ }
18
+ //# sourceMappingURL=reactotron.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reactotron.d.ts","sourceRoot":"","sources":["../../src/monitors/reactotron.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAEnD,qBAAa,iBAAkB,SAAQ,YAAY;IACjD,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,IAAI,CAAS;IACrB,OAAO,CAAC,EAAE,CAA0B;IACpC,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,eAAe,CAAQ;gBAEnB,KAAK,EAAE,QAAQ,EAAE,IAAI,SAAO;IAMxC,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,KAAK,IAAI,IAAI;IAKb,IAAI,IAAI,IAAI;IAaZ,OAAO,CAAC,OAAO;IAsCf,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,aAAa;CAuBtB"}
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ReactotronMonitor = void 0;
7
+ const ws_1 = __importDefault(require("ws"));
8
+ const events_1 = require("events");
9
+ const reactotron_parser_js_1 = require("../parsers/reactotron-parser.js");
10
+ class ReactotronMonitor extends events_1.EventEmitter {
11
+ store;
12
+ port;
13
+ ws = null;
14
+ reconnectTimer = null;
15
+ _connected = false;
16
+ shouldReconnect = true;
17
+ constructor(store, port = 9090) {
18
+ super();
19
+ this.store = store;
20
+ this.port = port;
21
+ }
22
+ get isConnected() {
23
+ return this._connected;
24
+ }
25
+ start() {
26
+ this.shouldReconnect = true;
27
+ this.connect();
28
+ }
29
+ stop() {
30
+ this.shouldReconnect = false;
31
+ if (this.reconnectTimer) {
32
+ clearTimeout(this.reconnectTimer);
33
+ this.reconnectTimer = null;
34
+ }
35
+ if (this.ws) {
36
+ this.ws.close();
37
+ this.ws = null;
38
+ }
39
+ this._connected = false;
40
+ }
41
+ connect() {
42
+ if (this.ws) {
43
+ this.ws.removeAllListeners();
44
+ this.ws.close();
45
+ }
46
+ try {
47
+ this.ws = new ws_1.default(`ws://localhost:${this.port}`);
48
+ this.ws.on("open", () => {
49
+ this._connected = true;
50
+ this.emit("connected");
51
+ });
52
+ this.ws.on("message", (data) => {
53
+ try {
54
+ const msg = JSON.parse(data.toString());
55
+ this.handleMessage(msg);
56
+ }
57
+ catch {
58
+ // Invalid JSON, skip
59
+ }
60
+ });
61
+ this.ws.on("close", () => {
62
+ this._connected = false;
63
+ this.emit("disconnected");
64
+ this.scheduleReconnect();
65
+ });
66
+ this.ws.on("error", () => {
67
+ this._connected = false;
68
+ this.scheduleReconnect();
69
+ });
70
+ }
71
+ catch {
72
+ this.scheduleReconnect();
73
+ }
74
+ }
75
+ scheduleReconnect() {
76
+ if (!this.shouldReconnect)
77
+ return;
78
+ if (this.reconnectTimer)
79
+ return;
80
+ this.reconnectTimer = setTimeout(() => {
81
+ this.reconnectTimer = null;
82
+ if (this.shouldReconnect) {
83
+ this.connect();
84
+ }
85
+ }, 3000);
86
+ }
87
+ handleMessage(msg) {
88
+ const parsed = (0, reactotron_parser_js_1.parseReactotronMessage)(msg);
89
+ const logEntry = this.store.reactotronLogs.add(parsed.logEntry);
90
+ this.emit("log", logEntry);
91
+ if (parsed.apiCall) {
92
+ const apiEntry = this.store.apiCalls.add(parsed.apiCall);
93
+ this.emit("api-call", apiEntry);
94
+ }
95
+ if (parsed.stateChange) {
96
+ const stateEntry = this.store.stateChanges.add(parsed.stateChange);
97
+ this.emit("state-change", stateEntry);
98
+ }
99
+ if (parsed.performanceEntry) {
100
+ const perfEntry = this.store.performanceEntries.add(parsed.performanceEntry);
101
+ this.emit("performance", perfEntry);
102
+ }
103
+ }
104
+ }
105
+ exports.ReactotronMonitor = ReactotronMonitor;
106
+ //# sourceMappingURL=reactotron.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reactotron.js","sourceRoot":"","sources":["../../src/monitors/reactotron.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { EventEmitter } from "events";
2
+ import { LogStore } from "../storage/log-store.js";
3
+ export declare class TerminalMonitor extends EventEmitter {
4
+ private store;
5
+ private filterPatterns;
6
+ private pollInterval;
7
+ private logProcess;
8
+ private detectedProcess;
9
+ private _source;
10
+ constructor(store: LogStore, filterPatterns?: string[]);
11
+ get isRunning(): boolean;
12
+ get processName(): string | null;
13
+ start(autoDetect: boolean): void;
14
+ stop(): void;
15
+ private startPolling;
16
+ private checkForProcesses;
17
+ private findRNProcesses;
18
+ private detectSource;
19
+ private startLogCapture;
20
+ private stopLogCapture;
21
+ private processLogData;
22
+ /** Manually inject a log line (useful for piping external sources) */
23
+ injectLog(line: string): void;
24
+ }
25
+ //# sourceMappingURL=terminal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"terminal.d.ts","sourceRoot":"","sources":["../../src/monitors/terminal.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AASnD,qBAAa,eAAgB,SAAQ,YAAY;IAC/C,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,cAAc,CAAW;IACjC,OAAO,CAAC,YAAY,CAA+B;IACnD,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,OAAO,CAAyC;gBAE5C,KAAK,EAAE,QAAQ,EAAE,cAAc,GAAE,MAAM,EAAO;IAM1D,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,IAAI,WAAW,IAAI,MAAM,GAAG,IAAI,CAE/B;IAED,KAAK,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAMhC,IAAI,IAAI,IAAI;IAQZ,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,iBAAiB;IAmBzB,OAAO,CAAC,eAAe;IAsBvB,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,eAAe;IA0CvB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,cAAc;IAetB,sEAAsE;IACtE,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;CAM9B"}
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TerminalMonitor = void 0;
4
+ const child_process_1 = require("child_process");
5
+ const events_1 = require("events");
6
+ const log_parser_js_1 = require("../parsers/log-parser.js");
7
+ class TerminalMonitor extends events_1.EventEmitter {
8
+ store;
9
+ filterPatterns;
10
+ pollInterval = null;
11
+ logProcess = null;
12
+ detectedProcess = null;
13
+ _source = "unknown";
14
+ constructor(store, filterPatterns = []) {
15
+ super();
16
+ this.store = store;
17
+ this.filterPatterns = filterPatterns;
18
+ }
19
+ get isRunning() {
20
+ return this.detectedProcess !== null;
21
+ }
22
+ get processName() {
23
+ return this.detectedProcess?.cmd ?? null;
24
+ }
25
+ start(autoDetect) {
26
+ if (autoDetect) {
27
+ this.startPolling();
28
+ }
29
+ }
30
+ stop() {
31
+ if (this.pollInterval) {
32
+ clearInterval(this.pollInterval);
33
+ this.pollInterval = null;
34
+ }
35
+ this.stopLogCapture();
36
+ }
37
+ startPolling() {
38
+ this.checkForProcesses();
39
+ this.pollInterval = setInterval(() => this.checkForProcesses(), 5000);
40
+ }
41
+ checkForProcesses() {
42
+ try {
43
+ const processes = this.findRNProcesses();
44
+ if (processes.length > 0 && !this.detectedProcess) {
45
+ this.detectedProcess = processes[0];
46
+ this._source = this.detectSource(this.detectedProcess.cmd);
47
+ this.emit("process-detected", this.detectedProcess);
48
+ this.startLogCapture(this.detectedProcess.pid);
49
+ }
50
+ else if (processes.length === 0 && this.detectedProcess) {
51
+ this.emit("process-lost", this.detectedProcess);
52
+ this.detectedProcess = null;
53
+ this._source = "unknown";
54
+ this.stopLogCapture();
55
+ }
56
+ }
57
+ catch {
58
+ // Silently continue polling
59
+ }
60
+ }
61
+ findRNProcesses() {
62
+ try {
63
+ const output = (0, child_process_1.execSync)("ps aux | grep -E '(react-native start|expo start|metro)' | grep -v grep", { encoding: "utf-8", timeout: 3000 });
64
+ return output
65
+ .split("\n")
66
+ .filter(Boolean)
67
+ .map((line) => {
68
+ const parts = line.trim().split(/\s+/);
69
+ const pid = parseInt(parts[1], 10);
70
+ const cmd = parts.slice(10).join(" ");
71
+ return { pid, name: parts[10] ?? "unknown", cmd };
72
+ })
73
+ .filter((p) => !isNaN(p.pid));
74
+ }
75
+ catch {
76
+ return [];
77
+ }
78
+ }
79
+ detectSource(cmd) {
80
+ if (/expo/i.test(cmd))
81
+ return "expo";
82
+ if (/metro/i.test(cmd))
83
+ return "metro";
84
+ if (/react-native/i.test(cmd))
85
+ return "react-native";
86
+ return "unknown";
87
+ }
88
+ startLogCapture(pid) {
89
+ this.stopLogCapture();
90
+ try {
91
+ // Use lsof to find the terminal of the process, then tail its output
92
+ // Fallback: attach to the process stdout via /proc or dtrace
93
+ // Most reliable cross-platform: pipe process output
94
+ this.logProcess = (0, child_process_1.spawn)("bash", [
95
+ "-c",
96
+ `
97
+ # Try to read from the process fd on macOS
98
+ if [ -d /proc/${pid}/fd ]; then
99
+ tail -f /proc/${pid}/fd/1 /proc/${pid}/fd/2 2>/dev/null
100
+ else
101
+ # macOS fallback: use log stream or dtrace for the process
102
+ # Simple approach: monitor system log for the process
103
+ log stream --process ${pid} --style compact 2>/dev/null || \
104
+ tail -f /dev/null
105
+ fi
106
+ `,
107
+ ]);
108
+ this.logProcess.stdout?.on("data", (data) => {
109
+ this.processLogData(data.toString());
110
+ });
111
+ this.logProcess.stderr?.on("data", (data) => {
112
+ this.processLogData(data.toString());
113
+ });
114
+ this.logProcess.on("error", () => {
115
+ // Process capture failed, continue without it
116
+ });
117
+ this.logProcess.on("exit", () => {
118
+ this.logProcess = null;
119
+ });
120
+ }
121
+ catch {
122
+ // Failed to start log capture
123
+ }
124
+ }
125
+ stopLogCapture() {
126
+ if (this.logProcess) {
127
+ this.logProcess.kill();
128
+ this.logProcess = null;
129
+ }
130
+ }
131
+ processLogData(data) {
132
+ const lines = data.split("\n").filter(Boolean);
133
+ for (const line of lines) {
134
+ if ((0, log_parser_js_1.shouldFilterLog)(line, this.filterPatterns))
135
+ continue;
136
+ const parsed = (0, log_parser_js_1.parseTerminalLine)(line, this._source);
137
+ const entry = this.store.terminalLogs.add(parsed);
138
+ this.emit("log", entry);
139
+ if (entry.severity === "error" || entry.isNativeCrash) {
140
+ this.emit("error", entry);
141
+ }
142
+ }
143
+ }
144
+ /** Manually inject a log line (useful for piping external sources) */
145
+ injectLog(line) {
146
+ if ((0, log_parser_js_1.shouldFilterLog)(line, this.filterPatterns))
147
+ return;
148
+ const parsed = (0, log_parser_js_1.parseTerminalLine)(line, this._source);
149
+ const entry = this.store.terminalLogs.add(parsed);
150
+ this.emit("log", entry);
151
+ }
152
+ }
153
+ exports.TerminalMonitor = TerminalMonitor;
154
+ //# sourceMappingURL=terminal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"terminal.js","sourceRoot":"","sources":["../../src/monitors/terminal.ts"],"names":[],"mappings":";;;AAAA,iDAA8D;AAC9D,mCAAsC;AACtC,4DAA8E;AAU9E,MAAa,eAAgB,SAAQ,qBAAY;IACvC,KAAK,CAAW;IAChB,cAAc,CAAW;IACzB,YAAY,GAA0B,IAAI,CAAC;IAC3C,UAAU,GAAwB,IAAI,CAAC;IACvC,eAAe,GAAuB,IAAI,CAAC;IAC3C,OAAO,GAA+B,SAAS,CAAC;IAExD,YAAY,KAAe,EAAE,iBAA2B,EAAE;QACxD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACvC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,eAAe,KAAK,IAAI,CAAC;IACvC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,IAAI,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,UAAmB;QACvB,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,CAAC;IACxE,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACzC,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;gBAClD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;gBACpC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;gBAC3D,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;gBACpD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;YACjD,CAAC;iBAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBAC1D,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;gBAChD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;gBACzB,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,4BAA4B;QAC9B,CAAC;IACH,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAA,wBAAQ,EACrB,yEAAyE,EACzE,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CACrC,CAAC;YAEF,OAAO,MAAM;iBACV,KAAK,CAAC,IAAI,CAAC;iBACX,MAAM,CAAC,OAAO,CAAC;iBACf,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;gBACZ,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACvC,MAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACnC,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACtC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,SAAS,EAAE,GAAG,EAAE,CAAC;YACpD,CAAC,CAAC;iBACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAClC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,GAAW;QAC9B,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,MAAM,CAAC;QACrC,IAAI,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,OAAO,CAAC;QACvC,IAAI,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,cAAc,CAAC;QACrD,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,eAAe,CAAC,GAAW;QACjC,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,IAAI,CAAC;YACH,qEAAqE;YACrE,6DAA6D;YAC7D,oDAAoD;YACpD,IAAI,CAAC,UAAU,GAAG,IAAA,qBAAK,EAAC,MAAM,EAAE;gBAC9B,IAAI;gBACJ;;wBAEgB,GAAG;0BACD,GAAG,eAAe,GAAG;;;;iCAId,GAAG;;;SAG3B;aACF,CAAC,CAAC;YAEH,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;gBAClD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;gBAClD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBAC/B,8CAA8C;YAChD,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;gBAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACzB,CAAC,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,8BAA8B;QAChC,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;IACH,CAAC;IAEO,cAAc,CAAC,IAAY;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAA,+BAAe,EAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC;gBAAE,SAAS;YAEzD,MAAM,MAAM,GAAG,IAAA,iCAAiB,EAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACrD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAExB,IAAI,KAAK,CAAC,QAAQ,KAAK,OAAO,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;gBACtD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;IACH,CAAC;IAED,sEAAsE;IACtE,SAAS,CAAC,IAAY;QACpB,IAAI,IAAA,+BAAe,EAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC;YAAE,OAAO;QACvD,MAAM,MAAM,GAAG,IAAA,iCAAiB,EAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC1B,CAAC;CACF;AAhKD,0CAgKC"}
@@ -0,0 +1,64 @@
1
+ import { HermesLogEntry, NetworkEntry } from "../types.js";
2
+ interface CDPConsoleEvent {
3
+ method: "Runtime.consoleAPICalled";
4
+ params: {
5
+ type: string;
6
+ args: Array<{
7
+ type: string;
8
+ value?: unknown;
9
+ description?: string;
10
+ }>;
11
+ stackTrace?: {
12
+ callFrames: Array<{
13
+ functionName: string;
14
+ url: string;
15
+ lineNumber: number;
16
+ columnNumber: number;
17
+ }>;
18
+ };
19
+ };
20
+ }
21
+ interface CDPRequestEvent {
22
+ method: "Network.requestWillBeSent";
23
+ params: {
24
+ requestId: string;
25
+ request: {
26
+ url: string;
27
+ method: string;
28
+ headers: Record<string, string>;
29
+ };
30
+ timestamp: number;
31
+ };
32
+ }
33
+ interface CDPResponseEvent {
34
+ method: "Network.responseReceived";
35
+ params: {
36
+ requestId: string;
37
+ response: {
38
+ url: string;
39
+ status: number;
40
+ mimeType: string;
41
+ headers: Record<string, string>;
42
+ };
43
+ timestamp: number;
44
+ };
45
+ }
46
+ type CDPEvent = CDPConsoleEvent | CDPRequestEvent | CDPResponseEvent | {
47
+ method: string;
48
+ params?: unknown;
49
+ };
50
+ export declare function parseCDPConsole(event: CDPConsoleEvent): Omit<HermesLogEntry, "id">;
51
+ export interface PendingRequest {
52
+ requestId: string;
53
+ method: string;
54
+ url: string;
55
+ requestHeaders: Record<string, string>;
56
+ startTime: number;
57
+ }
58
+ export declare function parseCDPRequest(event: CDPRequestEvent): PendingRequest;
59
+ export declare function parseCDPResponse(event: CDPResponseEvent, pending: PendingRequest | undefined): Omit<NetworkEntry, "id">;
60
+ export declare function isCDPConsoleEvent(msg: CDPEvent): msg is CDPConsoleEvent;
61
+ export declare function isCDPRequestEvent(msg: CDPEvent): msg is CDPRequestEvent;
62
+ export declare function isCDPResponseEvent(msg: CDPEvent): msg is CDPResponseEvent;
63
+ export {};
64
+ //# sourceMappingURL=cdp-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cdp-parser.d.ts","sourceRoot":"","sources":["../../src/parsers/cdp-parser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,YAAY,EAAe,MAAM,aAAa,CAAC;AAExE,UAAU,eAAe;IACvB,MAAM,EAAE,0BAA0B,CAAC;IACnC,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,OAAO,CAAC;YAAC,WAAW,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QACrE,UAAU,CAAC,EAAE;YACX,UAAU,EAAE,KAAK,CAAC;gBAChB,YAAY,EAAE,MAAM,CAAC;gBACrB,GAAG,EAAE,MAAM,CAAC;gBACZ,UAAU,EAAE,MAAM,CAAC;gBACnB,YAAY,EAAE,MAAM,CAAC;aACtB,CAAC,CAAC;SACJ,CAAC;KACH,CAAC;CACH;AAED,UAAU,eAAe;IACvB,MAAM,EAAE,2BAA2B,CAAC;IACpC,MAAM,EAAE;QACN,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE;YACP,GAAG,EAAE,MAAM,CAAC;YACZ,MAAM,EAAE,MAAM,CAAC;YACf,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;SACjC,CAAC;QACF,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAED,UAAU,gBAAgB;IACxB,MAAM,EAAE,0BAA0B,CAAC;IACnC,MAAM,EAAE;QACN,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE;YACR,GAAG,EAAE,MAAM,CAAC;YACZ,MAAM,EAAE,MAAM,CAAC;YACf,QAAQ,EAAE,MAAM,CAAC;YACjB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;SACjC,CAAC;QACF,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAED,KAAK,QAAQ,GAAG,eAAe,GAAG,eAAe,GAAG,gBAAgB,GAAG;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AA4C5G,wBAAgB,eAAe,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CA2BlF;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACvC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,eAAe,GAAG,cAAc,CAQtE;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,gBAAgB,EACvB,OAAO,EAAE,cAAc,GAAG,SAAS,GAClC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAiB1B;AAED,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,QAAQ,GAAG,GAAG,IAAI,eAAe,CAEvE;AAED,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,QAAQ,GAAG,GAAG,IAAI,eAAe,CAEvE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,QAAQ,GAAG,GAAG,IAAI,gBAAgB,CAEzE"}