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.
- package/LICENSE +21 -0
- package/README.md +174 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +68 -0
- package/dist/index.js.map +1 -0
- package/dist/monitors/crash-android.d.ts +20 -0
- package/dist/monitors/crash-android.d.ts.map +1 -0
- package/dist/monitors/crash-android.js +134 -0
- package/dist/monitors/crash-android.js.map +1 -0
- package/dist/monitors/crash-ios.d.ts +17 -0
- package/dist/monitors/crash-ios.d.ts.map +1 -0
- package/dist/monitors/crash-ios.js +116 -0
- package/dist/monitors/crash-ios.js.map +1 -0
- package/dist/monitors/hermes.d.ts +26 -0
- package/dist/monitors/hermes.d.ts.map +1 -0
- package/dist/monitors/hermes.js +175 -0
- package/dist/monitors/hermes.js.map +1 -0
- package/dist/monitors/reactotron.d.ts +18 -0
- package/dist/monitors/reactotron.d.ts.map +1 -0
- package/dist/monitors/reactotron.js +106 -0
- package/dist/monitors/reactotron.js.map +1 -0
- package/dist/monitors/terminal.d.ts +25 -0
- package/dist/monitors/terminal.d.ts.map +1 -0
- package/dist/monitors/terminal.js +154 -0
- package/dist/monitors/terminal.js.map +1 -0
- package/dist/parsers/cdp-parser.d.ts +64 -0
- package/dist/parsers/cdp-parser.d.ts.map +1 -0
- package/dist/parsers/cdp-parser.js +115 -0
- package/dist/parsers/cdp-parser.js.map +1 -0
- package/dist/parsers/crash-parser.d.ts +5 -0
- package/dist/parsers/crash-parser.d.ts.map +1 -0
- package/dist/parsers/crash-parser.js +112 -0
- package/dist/parsers/crash-parser.js.map +1 -0
- package/dist/parsers/log-parser.d.ts +5 -0
- package/dist/parsers/log-parser.d.ts.map +1 -0
- package/dist/parsers/log-parser.js +141 -0
- package/dist/parsers/log-parser.js.map +1 -0
- package/dist/parsers/reactotron-parser.d.ts +17 -0
- package/dist/parsers/reactotron-parser.d.ts.map +1 -0
- package/dist/parsers/reactotron-parser.js +83 -0
- package/dist/parsers/reactotron-parser.js.map +1 -0
- package/dist/server.d.ts +19 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +224 -0
- package/dist/server.js.map +1 -0
- package/dist/storage/log-store.d.ts +41 -0
- package/dist/storage/log-store.d.ts.map +1 -0
- package/dist/storage/log-store.js +118 -0
- package/dist/storage/log-store.js.map +1 -0
- package/dist/storage/persistence.d.ts +26 -0
- package/dist/storage/persistence.d.ts.map +1 -0
- package/dist/storage/persistence.js +123 -0
- package/dist/storage/persistence.js.map +1 -0
- package/dist/tools/clear-logs.d.ts +8 -0
- package/dist/tools/clear-logs.d.ts.map +1 -0
- package/dist/tools/clear-logs.js +15 -0
- package/dist/tools/clear-logs.js.map +1 -0
- package/dist/tools/get-api-calls.d.ts +11 -0
- package/dist/tools/get-api-calls.d.ts.map +1 -0
- package/dist/tools/get-api-calls.js +26 -0
- package/dist/tools/get-api-calls.js.map +1 -0
- package/dist/tools/get-crashes.d.ts +11 -0
- package/dist/tools/get-crashes.d.ts.map +1 -0
- package/dist/tools/get-crashes.js +42 -0
- package/dist/tools/get-crashes.js.map +1 -0
- package/dist/tools/get-errors.d.ts +12 -0
- package/dist/tools/get-errors.d.ts.map +1 -0
- package/dist/tools/get-errors.js +52 -0
- package/dist/tools/get-errors.js.map +1 -0
- package/dist/tools/get-hermes-logs.d.ts +12 -0
- package/dist/tools/get-hermes-logs.d.ts.map +1 -0
- package/dist/tools/get-hermes-logs.js +33 -0
- package/dist/tools/get-hermes-logs.js.map +1 -0
- package/dist/tools/get-logs.d.ts +21 -0
- package/dist/tools/get-logs.d.ts.map +1 -0
- package/dist/tools/get-logs.js +50 -0
- package/dist/tools/get-logs.js.map +1 -0
- package/dist/tools/get-network.d.ts +12 -0
- package/dist/tools/get-network.d.ts.map +1 -0
- package/dist/tools/get-network.js +35 -0
- package/dist/tools/get-network.js.map +1 -0
- package/dist/tools/get-performance.d.ts +10 -0
- package/dist/tools/get-performance.d.ts.map +1 -0
- package/dist/tools/get-performance.js +32 -0
- package/dist/tools/get-performance.js.map +1 -0
- package/dist/tools/get-state.d.ts +11 -0
- package/dist/tools/get-state.d.ts.map +1 -0
- package/dist/tools/get-state.js +26 -0
- package/dist/tools/get-state.js.map +1 -0
- package/dist/tools/get-status.d.ts +20 -0
- package/dist/tools/get-status.d.ts.map +1 -0
- package/dist/tools/get-status.js +52 -0
- package/dist/tools/get-status.js.map +1 -0
- package/dist/tools/search-logs.d.ts +11 -0
- package/dist/tools/search-logs.d.ts.map +1 -0
- package/dist/tools/search-logs.js +68 -0
- package/dist/tools/search-logs.js.map +1 -0
- package/dist/types.d.ts +123 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/package.json +65 -0
- package/scripts/install.sh +33 -0
- 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":";;;;;;AAAA,4CAA2B;AAC3B,mCAAsC;AACtC,0EAAyE;AAGzE,MAAa,iBAAkB,SAAQ,qBAAY;IACzC,KAAK,CAAW;IAChB,IAAI,CAAS;IACb,EAAE,GAAqB,IAAI,CAAC;IAC5B,cAAc,GAA0B,IAAI,CAAC;IAC7C,UAAU,GAAG,KAAK,CAAC;IACnB,eAAe,GAAG,IAAI,CAAC;IAE/B,YAAY,KAAe,EAAE,IAAI,GAAG,IAAI;QACtC,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,IAAI;QACF,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;QACD,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACjB,CAAC;QACD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAEO,OAAO;QACb,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,CAAC,EAAE,CAAC,kBAAkB,EAAE,CAAC;YAC7B,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;QAClB,CAAC;QAED,IAAI,CAAC;YACH,IAAI,CAAC,EAAE,GAAG,IAAI,YAAS,CAAC,kBAAkB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAEvD,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;gBACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAoB,EAAE,EAAE;gBAC7C,IAAI,CAAC;oBACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;oBACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;gBAC1B,CAAC;gBAAC,MAAM,CAAC;oBACP,qBAAqB;gBACvB,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,OAAO;QAClC,IAAI,IAAI,CAAC,cAAc;YAAE,OAAO;QAEhC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACzB,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,CAAC;QACH,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAEO,aAAa,CAAC,GAA4B;QAChD,MAAM,MAAM,GAAG,IAAA,6CAAsB,EACnC,GAA8D,CAC/D,CAAC;QAEF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAE3B,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YACzD,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAClC,CAAC;QAED,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;YACvB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YACnE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QACxC,CAAC;QAED,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;YAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;YAC7E,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;CACF;AA7GD,8CA6GC"}
|
|
@@ -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":"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"}
|
|
@@ -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"}
|