@teardown/cli 1.2.34 → 1.2.36

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 (41) hide show
  1. package/assets/favicon.ico +0 -0
  2. package/dist/commands/dev/dev.js +55 -0
  3. package/dist/commands/init/init-teardown.js +26 -0
  4. package/dist/index.js +20 -0
  5. package/dist/modules/dev/dev-menu/keyboard-handler.js +138 -0
  6. package/dist/modules/dev/dev-menu/open-debugger-keyboard-handler.js +105 -0
  7. package/dist/modules/dev/dev-server/cdp/cdp.adapter.js +12 -0
  8. package/dist/modules/dev/dev-server/cdp/index.js +18 -0
  9. package/dist/modules/dev/dev-server/cdp/types.js +2 -0
  10. package/dist/modules/dev/dev-server/dev-server-checker.js +72 -0
  11. package/dist/modules/dev/dev-server/dev-server.js +269 -0
  12. package/dist/modules/dev/dev-server/inspector/device.event-reporter.js +165 -0
  13. package/dist/modules/dev/dev-server/inspector/device.js +577 -0
  14. package/dist/modules/dev/dev-server/inspector/inspector.js +204 -0
  15. package/dist/modules/dev/dev-server/inspector/types.js +2 -0
  16. package/dist/modules/dev/dev-server/inspector/wss/servers/debugger-connection.server.js +61 -0
  17. package/dist/modules/dev/dev-server/inspector/wss/servers/device-connection.server.js +64 -0
  18. package/dist/modules/dev/dev-server/plugins/devtools.plugin.js +50 -0
  19. package/dist/modules/dev/dev-server/plugins/favicon.plugin.js +19 -0
  20. package/dist/modules/dev/dev-server/plugins/multipart.plugin.js +62 -0
  21. package/dist/modules/dev/dev-server/plugins/systrace.plugin.js +28 -0
  22. package/dist/modules/dev/dev-server/plugins/types.js +2 -0
  23. package/dist/modules/dev/dev-server/plugins/wss/index.js +19 -0
  24. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-api.server.js +66 -0
  25. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-debugger.server.js +128 -0
  26. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-dev-client.server.js +75 -0
  27. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-events.server.js +198 -0
  28. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-hmr.server.js +120 -0
  29. package/dist/modules/dev/dev-server/plugins/wss/servers/web-socket-message.server.js +357 -0
  30. package/dist/modules/dev/dev-server/plugins/wss/types.js +2 -0
  31. package/dist/modules/dev/dev-server/plugins/wss/web-socket-router.js +57 -0
  32. package/dist/modules/dev/dev-server/plugins/wss/web-socket-server-adapter.js +26 -0
  33. package/dist/modules/dev/dev-server/plugins/wss/web-socket-server.js +46 -0
  34. package/dist/modules/dev/dev-server/plugins/wss/wss.plugin.js +55 -0
  35. package/dist/modules/dev/dev-server/sybmolicate/sybmolicate.plugin.js +36 -0
  36. package/dist/modules/dev/dev-server/sybmolicate/types.js +2 -0
  37. package/dist/modules/dev/terminal/base.terminal.reporter.js +78 -0
  38. package/dist/modules/dev/terminal/terminal.reporter.js +76 -0
  39. package/dist/modules/dev/types.js +2 -0
  40. package/dist/modules/dev/utils/log.js +73 -0
  41. package/package.json +2 -3
@@ -0,0 +1,357 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WebSocketMessageServer = void 0;
4
+ const node_url_1 = require("node:url");
5
+ const web_socket_server_1 = require("../web-socket-server");
6
+ /**
7
+ * Class for creating a WebSocket server and sending messages between development server
8
+ * and the React Native applications.
9
+ *
10
+ * Based on: https://github.com/react-native-community/cli/blob/v4.14.0/packages/cli-server-api/src/websocket/messageSocketServer.ts
11
+ *
12
+ * @category Development server
13
+ */
14
+ class WebSocketMessageServer extends web_socket_server_1.WebSocketServer {
15
+ static PROTOCOL_VERSION = 2;
16
+ /**
17
+ * Check if message is a broadcast request.
18
+ *
19
+ * @param message Message to check.
20
+ * @returns True if message is a broadcast request and should be broadcasted
21
+ * with {@link sendBroadcast}.
22
+ */
23
+ static isBroadcast(message) {
24
+ return (typeof message.method === "string" &&
25
+ message.id === undefined &&
26
+ message.target === undefined);
27
+ }
28
+ /**
29
+ * Check if message is a method request.
30
+ *
31
+ * @param message Message to check.
32
+ * @returns True if message is a request.
33
+ */
34
+ static isRequest(message) {
35
+ return (typeof message.method === "string" && typeof message.target === "string");
36
+ }
37
+ /**
38
+ * Check if message is a response with results of performing some request.
39
+ *
40
+ * @param message Message to check.
41
+ * @returns True if message is a response.
42
+ */
43
+ static isResponse(message) {
44
+ return (typeof message.id === "object" &&
45
+ typeof message.id.requestId !== "undefined" &&
46
+ typeof message.id.clientId === "string" &&
47
+ (message.result !== undefined || message.error !== undefined));
48
+ }
49
+ clients = new Map();
50
+ nextClientId = 0;
51
+ /**
52
+ * Create new instance of WebSocketMessageServer and attach it to the given Fastify instance.
53
+ * Any logging information, will be passed through standard `fastify.log` API.
54
+ *
55
+ * @param fastify Fastify instance to attach the WebSocket server to.
56
+ */
57
+ constructor(fastify) {
58
+ super(fastify, "/message");
59
+ }
60
+ /**
61
+ * Parse stringified message into a {@link ReactNativeMessage}.
62
+ *
63
+ * @param data Stringified message.
64
+ * @param binary Additional binary data if any.
65
+ * @returns Parsed message or `undefined` if parsing failed.
66
+ */
67
+ parseMessage(data, binary) {
68
+ console.log("parseMessage", data, binary);
69
+ if (binary) {
70
+ this.fastify.log.error({
71
+ msg: "Failed to parse message - expected text message, got binary",
72
+ });
73
+ return undefined;
74
+ }
75
+ try {
76
+ const message = JSON.parse(data);
77
+ if (message.version === WebSocketMessageServer.PROTOCOL_VERSION.toString()) {
78
+ return message;
79
+ }
80
+ this.fastify.log.error({
81
+ msg: "Received message had wrong protocol version",
82
+ message,
83
+ });
84
+ }
85
+ catch {
86
+ this.fastify.log.error({
87
+ msg: "Failed to parse the message as JSON",
88
+ data,
89
+ });
90
+ }
91
+ return undefined;
92
+ }
93
+ /**
94
+ * Get client's WebSocket connection for given `clientId`.
95
+ * Throws if no such client is connected.
96
+ *
97
+ * @param clientId Id of the client.
98
+ * @returns WebSocket connection.
99
+ */
100
+ getClientSocket(clientId) {
101
+ console.log("getClientSocket", clientId);
102
+ const socket = this.clients.get(clientId);
103
+ if (socket === undefined) {
104
+ throw new Error(`Could not find client with id "${clientId}"`);
105
+ }
106
+ return socket;
107
+ }
108
+ /**
109
+ * Process error by sending an error message to the client whose message caused the error
110
+ * to occur.
111
+ *
112
+ * @param clientId Id of the client whose message caused an error.
113
+ * @param message Original message which caused the error.
114
+ * @param error Concrete instance of an error that occurred.
115
+ */
116
+ handleError(clientId, message, error) {
117
+ console.log("handleError", clientId, message, error);
118
+ const errorMessage = {
119
+ id: message.id,
120
+ method: message.method,
121
+ target: message.target,
122
+ error: message.error === undefined ? "undefined" : "defined",
123
+ params: message.params === undefined ? "undefined" : "defined",
124
+ result: message.result === undefined ? "undefined" : "defined",
125
+ };
126
+ if (message.id === undefined) {
127
+ this.fastify.log.error({
128
+ msg: "Handling message failed",
129
+ clientId,
130
+ error,
131
+ errorMessage,
132
+ });
133
+ }
134
+ else {
135
+ try {
136
+ const socket = this.getClientSocket(clientId);
137
+ socket.send(JSON.stringify({
138
+ version: WebSocketMessageServer.PROTOCOL_VERSION,
139
+ error,
140
+ id: message.id,
141
+ }));
142
+ }
143
+ catch (error) {
144
+ this.fastify.log.error("Failed to reply", {
145
+ clientId,
146
+ error,
147
+ errorMessage,
148
+ });
149
+ }
150
+ }
151
+ }
152
+ /**
153
+ * Send given request `message` to it's designated client's socket based on `message.target`.
154
+ * The target client must be connected, otherwise it will throw an error.
155
+ *
156
+ * @param clientId Id of the client that requested the forward.
157
+ * @param message Message to forward.
158
+ */
159
+ forwardRequest(clientId, message) {
160
+ console.log("forwardRequest", clientId, message);
161
+ if (!message.target) {
162
+ this.fastify.log.error({
163
+ msg: "Failed to forward request - message.target is missing",
164
+ clientId,
165
+ message,
166
+ });
167
+ return;
168
+ }
169
+ const socket = this.getClientSocket(message.target);
170
+ socket.send(JSON.stringify({
171
+ version: WebSocketMessageServer.PROTOCOL_VERSION,
172
+ method: message.method,
173
+ params: message.params,
174
+ id: message.id === undefined
175
+ ? undefined
176
+ : { requestId: message.id, clientId },
177
+ }));
178
+ }
179
+ /**
180
+ * Send given response `message` to it's designated client's socket based
181
+ * on `message.id.clientId`.
182
+ * The target client must be connected, otherwise it will throw an error.
183
+ *
184
+ * @param message Message to forward.
185
+ */
186
+ forwardResponse(message) {
187
+ console.log("forwardResponse", message);
188
+ if (!message.id) {
189
+ return;
190
+ }
191
+ const socket = this.getClientSocket(message.id.clientId);
192
+ socket.send(JSON.stringify({
193
+ version: WebSocketMessageServer.PROTOCOL_VERSION,
194
+ result: message.result,
195
+ error: message.error,
196
+ id: message.id.requestId,
197
+ }));
198
+ }
199
+ /**
200
+ * Process request message targeted towards this {@link WebSocketMessageServer}
201
+ * and send back the results.
202
+ *
203
+ * @param clientId Id of the client who send the message.
204
+ * @param message The message to process by the server.
205
+ */
206
+ processServerRequest(clientId, message) {
207
+ console.log("processServerRequest", clientId, message);
208
+ let result;
209
+ switch (message.method) {
210
+ case "getid":
211
+ result = clientId;
212
+ break;
213
+ case "getpeers": {
214
+ const output = {};
215
+ this.clients.forEach((peerSocket, peerId) => {
216
+ if (clientId !== peerId) {
217
+ const { searchParams } = new node_url_1.URL(peerSocket.upgradeReq?.url || "");
218
+ output[peerId] = [...searchParams.entries()].reduce((acc, [key, value]) => {
219
+ acc[key] = value;
220
+ return acc;
221
+ }, {});
222
+ }
223
+ });
224
+ result = output;
225
+ break;
226
+ }
227
+ default:
228
+ throw new Error(`Cannot process server request - unknown method ${JSON.stringify({
229
+ clientId,
230
+ message,
231
+ })}`);
232
+ }
233
+ const socket = this.getClientSocket(clientId);
234
+ socket.send(JSON.stringify({
235
+ version: WebSocketMessageServer.PROTOCOL_VERSION,
236
+ result,
237
+ id: message.id,
238
+ }));
239
+ }
240
+ /**
241
+ * Broadcast given message to all connected clients.
242
+ *
243
+ * @param broadcasterId Id of the client who is broadcasting.
244
+ * @param message Message to broadcast.
245
+ */
246
+ sendBroadcast(broadcasterId, message) {
247
+ const forwarded = {
248
+ version: WebSocketMessageServer.PROTOCOL_VERSION,
249
+ method: message.method,
250
+ params: message.params,
251
+ };
252
+ if (this.clients.size === 0) {
253
+ this.fastify.log.warn({
254
+ msg:
255
+ // biome-ignore lint/style/useTemplate: <explanation>
256
+ "No apps connected. " +
257
+ `Sending "${message.method}" to all React Native apps failed. ` +
258
+ "Make sure your app is running in the simulator or on a phone connected via USB.",
259
+ });
260
+ }
261
+ for (const [clientId, socket] of this.clients) {
262
+ if (clientId !== broadcasterId) {
263
+ try {
264
+ socket.send(JSON.stringify(forwarded));
265
+ }
266
+ catch (error) {
267
+ this.fastify.log.error({
268
+ msg: "Failed to send broadcast",
269
+ clientId,
270
+ error,
271
+ forwarded,
272
+ });
273
+ }
274
+ }
275
+ }
276
+ }
277
+ /**
278
+ * Send method broadcast to all connected clients.
279
+ *
280
+ * @param method Method name to broadcast.
281
+ * @param params Method parameters.
282
+ */
283
+ broadcast(method, params) {
284
+ this.sendBroadcast(undefined, { method, params });
285
+ }
286
+ /**
287
+ * Process new client's WebSocket connection.
288
+ *
289
+ * @param socket Incoming WebSocket connection.
290
+ * @param request Upgrade request for the connection.
291
+ */
292
+ onConnection(socket, request) {
293
+ const clientId = `client#${this.nextClientId++}`;
294
+ const client = socket;
295
+ client.upgradeReq = request;
296
+ this.clients.set(clientId, client);
297
+ this.fastify.log.debug({ msg: "Message client connected", clientId });
298
+ const cleanup = () => {
299
+ this.fastify.log.debug({ msg: "Cleaning up message client", clientId });
300
+ socket.removeAllListeners();
301
+ this.clients.delete(clientId);
302
+ };
303
+ const onClose = (close) => {
304
+ this.fastify.log.debug({
305
+ msg: "Message client closed",
306
+ clientId,
307
+ close,
308
+ });
309
+ cleanup();
310
+ };
311
+ const onError = (error) => {
312
+ this.fastify.log.error({ msg: "Message client error", clientId, error });
313
+ cleanup();
314
+ };
315
+ socket.addEventListener("error", onError);
316
+ socket.addEventListener("close", onClose);
317
+ socket.addEventListener("message", (event) => {
318
+ const message = this.parseMessage(event.data.toString(),
319
+ // @ts-ignore
320
+ event.binary);
321
+ if (!message) {
322
+ this.fastify.log.error({
323
+ msg: "Received message not matching protocol",
324
+ clientId,
325
+ message,
326
+ });
327
+ return;
328
+ }
329
+ try {
330
+ if (WebSocketMessageServer.isBroadcast(message)) {
331
+ this.sendBroadcast(clientId, message);
332
+ }
333
+ else if (WebSocketMessageServer.isRequest(message)) {
334
+ if (message.target === "server") {
335
+ this.processServerRequest(clientId, message);
336
+ }
337
+ else {
338
+ this.forwardRequest(clientId, message);
339
+ }
340
+ }
341
+ else if (WebSocketMessageServer.isResponse(message)) {
342
+ this.forwardResponse(message);
343
+ }
344
+ else {
345
+ throw new Error(`Invalid message, did not match the protocol ${JSON.stringify({
346
+ clientId,
347
+ message,
348
+ })}`);
349
+ }
350
+ }
351
+ catch (error) {
352
+ this.handleError(clientId, message, error);
353
+ }
354
+ });
355
+ }
356
+ }
357
+ exports.WebSocketMessageServer = WebSocketMessageServer;
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WebSocketRouter = void 0;
4
+ /**
5
+ * Class for creating a WebSocket router to forward connections to the
6
+ * respective {@link WebSocketServer} as long as the connection is accepted for the upgrade by the
7
+ * server.
8
+ *
9
+ * If the connection is not accepted by any `WebSocketServer`, it will be destroyed to avoid
10
+ * creating handling connections and potentially throwing `ECONNRESET` errors.
11
+ *
12
+ * @category Development server
13
+ */
14
+ class WebSocketRouter {
15
+ fastify;
16
+ /** The list of all register WebSocket servers. */
17
+ servers = [];
18
+ /**
19
+ * Create new instance of `WebSocketRouter` and attach it to the given Fastify instance.
20
+ * Any logging information, will be passed through standard `fastify.log` API.
21
+ *
22
+ * @param fastify Fastify instance to attach the WebSocket router to.
23
+ */
24
+ constructor(fastify) {
25
+ this.fastify = fastify;
26
+ this.fastify.server.on("upgrade", (request, socket, head) => {
27
+ const { pathname } = new URL(request.url || "", "http://localhost");
28
+ let matched = false;
29
+ for (const server of this.servers) {
30
+ if (server.shouldUpgrade(pathname)) {
31
+ matched = true;
32
+ server.upgrade(request, socket, head);
33
+ break;
34
+ }
35
+ }
36
+ if (!matched) {
37
+ this.fastify.log.debug({
38
+ msg: "Destroying socket connection as no server was matched",
39
+ pathname,
40
+ });
41
+ socket.destroy();
42
+ }
43
+ });
44
+ }
45
+ /**
46
+ * Register a new {@link WebSocketServer}. New connection will now
47
+ * check if the given server will accept them and forward them.
48
+ *
49
+ * @param server WebSocket server to register.
50
+ * @returns The same instance of the WebSocket server after it's been registered.
51
+ */
52
+ registerServer(server) {
53
+ this.servers.push(server);
54
+ return server;
55
+ }
56
+ }
57
+ exports.WebSocketRouter = WebSocketRouter;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WebSocketServerAdapter = void 0;
4
+ class WebSocketServerAdapter {
5
+ fastify;
6
+ path;
7
+ server;
8
+ constructor(fastify, path, server) {
9
+ this.fastify = fastify;
10
+ this.path = path;
11
+ this.server = server;
12
+ }
13
+ shouldUpgrade(pathname) {
14
+ if (!this.server) {
15
+ this.fastify.log.warn({ msg: `No handler active for ${this.path}` });
16
+ return false;
17
+ }
18
+ return this.path === pathname;
19
+ }
20
+ upgrade(request, socket, head) {
21
+ this.server?.handleUpgrade(request, socket, head, (webSocket) => {
22
+ this.server?.emit("connection", webSocket, request);
23
+ });
24
+ }
25
+ }
26
+ exports.WebSocketServerAdapter = WebSocketServerAdapter;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WebSocketServer = void 0;
4
+ const ws_1 = require("ws");
5
+ /**
6
+ /**
7
+ * Abstract class for providing common logic (eg routing) for all WebSocket servers.
8
+ *
9
+ * @category Development server
10
+ */
11
+ class WebSocketServer {
12
+ /** An instance of the underlying WebSocket server. */
13
+ server;
14
+ /** Fastify instance from which {@link server} will receive upgrade connections. */
15
+ fastify;
16
+ paths;
17
+ /**
18
+ * Create a new instance of the WebSocketServer.
19
+ * Any logging information, will be passed through standard `fastify.log` API.
20
+ *
21
+ * @param fastify Fastify instance to which the WebSocket will be attached to.
22
+ * @param path Path on which this WebSocketServer will be accepting connections.
23
+ * @param wssOptions WebSocket Server options.
24
+ */
25
+ constructor(fastify, path, wssOptions = {}) {
26
+ this.fastify = fastify;
27
+ this.server = new ws_1.WebSocketServer({ noServer: true, ...wssOptions });
28
+ this.server.on("connection", this.onConnection.bind(this));
29
+ this.server.on("error", this.onError.bind(this));
30
+ this.server.on("message", this.onMessage.bind(this));
31
+ this.server.on("close", this.onClose.bind(this));
32
+ this.paths = Array.isArray(path) ? path : [path];
33
+ }
34
+ shouldUpgrade(pathname) {
35
+ return this.paths.includes(pathname);
36
+ }
37
+ upgrade(request, socket, head) {
38
+ this.server.handleUpgrade(request, socket, head, (webSocket) => {
39
+ this.server.emit("connection", webSocket, request);
40
+ });
41
+ }
42
+ onError(error) { }
43
+ onMessage(message) { }
44
+ onClose(socket) { }
45
+ }
46
+ exports.WebSocketServer = WebSocketServer;
@@ -0,0 +1,55 @@
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.wssPlugin = void 0;
7
+ const fastify_plugin_1 = __importDefault(require("fastify-plugin"));
8
+ const web_socket_debugger_server_1 = require("./servers/web-socket-debugger.server");
9
+ const web_socket_dev_client_server_1 = require("./servers/web-socket-dev-client.server");
10
+ const web_socket_hmr_server_1 = require("./servers/web-socket-hmr.server");
11
+ const web_socket_router_1 = require("./web-socket-router");
12
+ const web_socket_server_adapter_1 = require("./web-socket-server-adapter");
13
+ /**
14
+ * Defined in @react-native/dev-middleware
15
+ * Reference: https://github.com/facebook/react-native/blob/main/packages/dev-middleware/src/inspector-proxy/InspectorProxy.js
16
+ */
17
+ const WS_DEVICE_URL = "/inspector/device";
18
+ const WS_DEBUGGER_URL = "/inspector/debug";
19
+ const WS_NETWORK_URL = "/inspector/network";
20
+ exports.wssPlugin = (0, fastify_plugin_1.default)(async (instance, { metroConfig, metroServer, onClientConnected, endpoints, messageServer, eventsServer, apiServer, }) => {
21
+ const router = new web_socket_router_1.WebSocketRouter(instance);
22
+ const debuggerServer = new web_socket_debugger_server_1.WebSocketDebuggerServer(instance);
23
+ const devClientServer = new web_socket_dev_client_server_1.WebSocketDevClientServer(instance);
24
+ const hmrServer = new web_socket_hmr_server_1.WebSocketHMRServer(instance, {
25
+ metroConfig,
26
+ metroServer,
27
+ onClientConnected,
28
+ });
29
+ // @react-native/dev-middleware servers
30
+ const deviceConnectionServer = new web_socket_server_adapter_1.WebSocketServerAdapter(instance, WS_DEVICE_URL, endpoints[WS_DEVICE_URL]);
31
+ const debuggerConnectionServer = new web_socket_server_adapter_1.WebSocketServerAdapter(instance, WS_DEBUGGER_URL, endpoints[WS_DEBUGGER_URL]);
32
+ const networkConnectionServer = new web_socket_server_adapter_1.WebSocketServerAdapter(instance, WS_NETWORK_URL, endpoints[WS_NETWORK_URL]);
33
+ router.registerServer(debuggerServer);
34
+ router.registerServer(devClientServer);
35
+ router.registerServer(messageServer);
36
+ router.registerServer(eventsServer);
37
+ router.registerServer(apiServer);
38
+ router.registerServer(hmrServer);
39
+ router.registerServer(deviceConnectionServer);
40
+ router.registerServer(debuggerConnectionServer);
41
+ router.registerServer(networkConnectionServer);
42
+ instance.decorate("wss", {
43
+ debuggerServer,
44
+ devClientServer,
45
+ messageServer,
46
+ eventsServer,
47
+ apiServer,
48
+ hmrServer,
49
+ deviceConnectionServer,
50
+ debuggerConnectionServer,
51
+ router,
52
+ });
53
+ }, {
54
+ name: "wss-plugin",
55
+ });
@@ -0,0 +1,36 @@
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.rawBodyPlugin = exports.symbolicatePlugin = void 0;
7
+ const fastify_plugin_1 = __importDefault(require("fastify-plugin"));
8
+ exports.symbolicatePlugin = (0, fastify_plugin_1.default)(async (instance, options) => {
9
+ instance.log.info("Symbolicate plugin registered");
10
+ instance.use((request, reply, next) => {
11
+ if (request.url !== "/symbolicate") {
12
+ next();
13
+ return;
14
+ }
15
+ instance.log.info("symbolicate onRequest", request.url);
16
+ const requestWithBody = request;
17
+ requestWithBody.rawBody = "";
18
+ requestWithBody.setEncoding("utf8");
19
+ requestWithBody.on("data", (chunk) => {
20
+ requestWithBody.rawBody += chunk;
21
+ });
22
+ requestWithBody.on("end", () => {
23
+ options.onSymbolicate(requestWithBody, reply);
24
+ next();
25
+ });
26
+ });
27
+ }, {
28
+ name: "symbolicate-plugin",
29
+ dependencies: ["@fastify/sensible"],
30
+ });
31
+ exports.rawBodyPlugin = (0, fastify_plugin_1.default)((instance, options) => {
32
+ instance.addHook("preHandler", (request, reply, next) => {
33
+ // request.rawBody = "";
34
+ next();
35
+ });
36
+ });
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BaseTerminalReporter = void 0;
4
+ const metro_1 = require("metro");
5
+ class BaseTerminalReporter extends metro_1.TerminalReporter {
6
+ // constructor(terminal: Terminal) {
7
+ // super(terminal);
8
+ // }
9
+ update(event) {
10
+ // @ts-ignore
11
+ super.update(event);
12
+ }
13
+ _getElapsedTime(startTime) {
14
+ // @ts-ignore
15
+ return super._getElapsedTime(startTime);
16
+ }
17
+ _log(event) {
18
+ // @ts-ignore
19
+ super._log(event);
20
+ }
21
+ _logInitializing(port, hasReducedPerformance) {
22
+ // @ts-ignore
23
+ super._logInitializing(port, hasReducedPerformance);
24
+ }
25
+ _logInitializingFailed(port, error) {
26
+ // @ts-ignore
27
+ super._logInitializingFailed(port, error);
28
+ }
29
+ _logBundleBuildDone(buildID) {
30
+ // @ts-ignore
31
+ super._logBundleBuildDone(buildID);
32
+ }
33
+ _logBundleBuildFailed(buildID) {
34
+ // @ts-ignore
35
+ super._logBundleBuildFailed(buildID);
36
+ }
37
+ _logBundlingError(error) {
38
+ // @ts-ignore
39
+ super._logBundlingError(error);
40
+ }
41
+ _logWorkerChunk(origin, chunk) {
42
+ // @ts-ignore
43
+ super._logWorkerChunk(origin, chunk);
44
+ }
45
+ _logHmrClientError(error) {
46
+ // @ts-ignore
47
+ super._logHmrClientError(error);
48
+ }
49
+ _logWarning(message) {
50
+ // @ts-ignore
51
+ super._logWarning(message);
52
+ }
53
+ _logWatcherHealthCheckResult(result) {
54
+ // @ts-ignore
55
+ super._logWatcherHealthCheckResult(result);
56
+ }
57
+ _logWatcherStatus(status) {
58
+ // @ts-ignore
59
+ super._logWatcherStatus(status);
60
+ }
61
+ _getBundleStatusMessage(progress, phase) {
62
+ // @ts-ignore
63
+ return super._getBundleStatusMessage(progress, phase);
64
+ }
65
+ _updateBundleProgress(data) {
66
+ // @ts-ignore
67
+ super._updateBundleProgress(data);
68
+ }
69
+ _updateState(event) {
70
+ // @ts-ignore
71
+ super._updateState(event);
72
+ }
73
+ _getStatusMessage() {
74
+ // @ts-ignore
75
+ return super._getStatusMessage();
76
+ }
77
+ }
78
+ exports.BaseTerminalReporter = BaseTerminalReporter;