@mt0926/node-network-devtools 0.1.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 (73) hide show
  1. package/BUILD.md +204 -0
  2. package/LICENSE +21 -0
  3. package/README.md +310 -0
  4. package/README.zh-CN.md +310 -0
  5. package/dist/esm/adapters/nextjs.js +123 -0
  6. package/dist/esm/adapters/nextjs.js.map +1 -0
  7. package/dist/esm/cdp/cdp-bridge.js +312 -0
  8. package/dist/esm/cdp/cdp-bridge.js.map +1 -0
  9. package/dist/esm/cli.js +203 -0
  10. package/dist/esm/cli.js.map +1 -0
  11. package/dist/esm/config.js +136 -0
  12. package/dist/esm/config.js.map +1 -0
  13. package/dist/esm/context/context-manager.js +126 -0
  14. package/dist/esm/context/context-manager.js.map +1 -0
  15. package/dist/esm/gui/browser-launcher.js +165 -0
  16. package/dist/esm/gui/browser-launcher.js.map +1 -0
  17. package/dist/esm/gui/event-bridge.js +192 -0
  18. package/dist/esm/gui/event-bridge.js.map +1 -0
  19. package/dist/esm/gui/port-utils.js +80 -0
  20. package/dist/esm/gui/port-utils.js.map +1 -0
  21. package/dist/esm/gui/server.js +227 -0
  22. package/dist/esm/gui/server.js.map +1 -0
  23. package/dist/esm/gui/websocket-hub.js +326 -0
  24. package/dist/esm/gui/websocket-hub.js.map +1 -0
  25. package/dist/esm/index.js +90 -0
  26. package/dist/esm/index.js.map +1 -0
  27. package/dist/esm/interceptors/http-patcher.js +203 -0
  28. package/dist/esm/interceptors/http-patcher.js.map +1 -0
  29. package/dist/esm/interceptors/undici-patcher.js +324 -0
  30. package/dist/esm/interceptors/undici-patcher.js.map +1 -0
  31. package/dist/esm/register.js +132 -0
  32. package/dist/esm/register.js.map +1 -0
  33. package/dist/esm/store/ring-buffer.js +236 -0
  34. package/dist/esm/store/ring-buffer.js.map +1 -0
  35. package/dist/esm/test-setup.js +7 -0
  36. package/dist/esm/test-setup.js.map +1 -0
  37. package/dist/gui/assets/index.css +1 -0
  38. package/dist/gui/assets/index.js +40 -0
  39. package/dist/gui/index.html +14 -0
  40. package/dist/types/adapters/nextjs.d.ts +80 -0
  41. package/dist/types/adapters/nextjs.d.ts.map +1 -0
  42. package/dist/types/cdp/cdp-bridge.d.ts +86 -0
  43. package/dist/types/cdp/cdp-bridge.d.ts.map +1 -0
  44. package/dist/types/cli.d.ts +8 -0
  45. package/dist/types/cli.d.ts.map +1 -0
  46. package/dist/types/config.d.ts +57 -0
  47. package/dist/types/config.d.ts.map +1 -0
  48. package/dist/types/context/context-manager.d.ts +96 -0
  49. package/dist/types/context/context-manager.d.ts.map +1 -0
  50. package/dist/types/gui/browser-launcher.d.ts +52 -0
  51. package/dist/types/gui/browser-launcher.d.ts.map +1 -0
  52. package/dist/types/gui/event-bridge.d.ts +36 -0
  53. package/dist/types/gui/event-bridge.d.ts.map +1 -0
  54. package/dist/types/gui/port-utils.d.ts +25 -0
  55. package/dist/types/gui/port-utils.d.ts.map +1 -0
  56. package/dist/types/gui/server.d.ts +50 -0
  57. package/dist/types/gui/server.d.ts.map +1 -0
  58. package/dist/types/gui/websocket-hub.d.ts +67 -0
  59. package/dist/types/gui/websocket-hub.d.ts.map +1 -0
  60. package/dist/types/index.d.ts +44 -0
  61. package/dist/types/index.d.ts.map +1 -0
  62. package/dist/types/interceptors/http-patcher.d.ts +32 -0
  63. package/dist/types/interceptors/http-patcher.d.ts.map +1 -0
  64. package/dist/types/interceptors/undici-patcher.d.ts +37 -0
  65. package/dist/types/interceptors/undici-patcher.d.ts.map +1 -0
  66. package/dist/types/register.d.ts +18 -0
  67. package/dist/types/register.d.ts.map +1 -0
  68. package/dist/types/store/ring-buffer.d.ts +148 -0
  69. package/dist/types/store/ring-buffer.d.ts.map +1 -0
  70. package/dist/types/test-setup.d.ts +7 -0
  71. package/dist/types/test-setup.d.ts.map +1 -0
  72. package/package.json +103 -0
  73. package/templates/instrumentation.ts +32 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"register.js","sourceRoot":"","sources":["../../src/register.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACxF,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,KAAK,SAAS,MAAM,gBAAgB,CAAC;AAE5C,sBAAsB;AACtB,MAAM,aAAa,GAAG,OAAQ,SAAiB,CAAC,OAAO,EAAE,iBAAiB,KAAK,UAAU,CAAC;AAE1F;;GAEG;AACH,SAAS,IAAI,CAAC,OAAe;IAC3B,OAAO,CAAC,IAAI,CAAC,0CAA0C,OAAO,EAAE,CAAC,CAAC;AACpE,CAAC;AAED;;GAEG;AACH,SAAS,IAAI,CAAC,OAAe;IAC3B,OAAO,CAAC,GAAG,CAAC,0CAA0C,OAAO,EAAE,CAAC,CAAC;AACnE,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,UAAU;IACvB,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,oBAAoB;IACpB,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC1B,IAAI,CAAC,0DAA0D,CAAC,CAAC;QACjE,IAAI,CAAC,oEAAoE,CAAC,CAAC;QAC3E,IAAI,CAAC,kDAAkD,CAAC,CAAC;QACzD,OAAO;IACT,CAAC;IAED,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,IAAI,CAAC,kBAAkB,YAAY,EAAE,CAAC,CAAC;IAEvC,cAAc;IACd,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC;YACH,WAAW,CAAC,OAAO,EAAE,CAAC;YACtB,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC5B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,iBAAiB,KAAK,EAAE,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAED,sBAAsB;IACtB,IAAI,MAAM,CAAC,eAAe,EAAE,CAAC;QAC3B,IAAI,CAAC;YACH,aAAa,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAC9B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,mBAAmB,KAAK,EAAE,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;IAED,gBAAgB;IAChB,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;QACvB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,YAAY,EAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACzB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,oBAAoB,KAAK,EAAE,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,mBAAmB;IACnB,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;QACtB,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,YAAY,EAAE,CAAC;YACjC,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,KAAK,CAAC;gBAC5C,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,IAAI,EAAE,MAAM,CAAC,OAAO;aACrB,CAAC,CAAC;YAEH,kBAAkB;YAClB,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;YACrC,WAAW,CAAC,KAAK,EAAE,CAAC;YAEpB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,CAAC;YAE3B,UAAU;YACV,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACpB,IAAI,CAAC;oBACH,MAAM,WAAW,CAAC,GAAG,EAAE,EAAE,YAAY,EAAE,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;oBAC9D,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACjB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,IAAI,CAAC,YAAY,KAAK,EAAE,CAAC,CAAC;oBAC1B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC,CAAC;gBACxB,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,gBAAgB,KAAK,EAAE,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;IAED,IAAI,CAAC,6BAA6B,CAAC,CAAC;IAEpC,qBAAqB;IACrB,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,IAAI,CAAC,2BAA2B,CAAC,CAAC;QAClC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACxB,IAAI,CAAC,0BAA0B,CAAC,CAAC;QACjC,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAClD,IAAI,CAAC,oEAAoE,CAAC,CAAC;QAC3E,IAAI,CAAC,EAAE,CAAC,CAAC;QACT,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAClD,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACjC,CAAC;SAAM,CAAC;QACN,IAAI,CAAC,0CAA0C,CAAC,CAAC;QACjD,IAAI,CAAC,2CAA2C,CAAC,CAAC;IACpD,CAAC;AACH,CAAC;AAED,QAAQ;AACR,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;IAC3B,IAAI,CAAC,UAAU,KAAK,EAAE,CAAC,CAAC;AAC1B,CAAC,CAAC,CAAC;AAEH,UAAU;AACV,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,CAAC"}
@@ -0,0 +1,236 @@
1
+ /**
2
+ * 环形缓冲区请求存储
3
+ *
4
+ * 高效存储和查询请求数据,自动覆盖旧条目
5
+ */
6
+ import { getConfig } from '../config.js';
7
+ /**
8
+ * 环形缓冲区实现
9
+ */
10
+ class RingBufferStore {
11
+ buffer;
12
+ maxSize;
13
+ maxBodySize;
14
+ writeIndex = 0;
15
+ count = 0;
16
+ idMap = new Map();
17
+ constructor(maxSize, maxBodySize) {
18
+ const config = getConfig();
19
+ this.maxSize = maxSize ?? config.maxRequests;
20
+ this.maxBodySize = maxBodySize ?? config.maxBodySize;
21
+ this.buffer = new Array(this.maxSize).fill(undefined);
22
+ }
23
+ /**
24
+ * 截断过大的 body
25
+ */
26
+ truncateBody(body) {
27
+ if (body === undefined) {
28
+ return { body: undefined, truncated: false };
29
+ }
30
+ const size = Buffer.isBuffer(body) ? body.length : Buffer.byteLength(body);
31
+ if (size <= this.maxBodySize) {
32
+ return { body, truncated: false };
33
+ }
34
+ if (Buffer.isBuffer(body)) {
35
+ return { body: body.subarray(0, this.maxBodySize), truncated: true };
36
+ }
37
+ else {
38
+ // 对于字符串,需要小心处理 UTF-8 边界
39
+ const buffer = Buffer.from(body);
40
+ const truncated = buffer.subarray(0, this.maxBodySize);
41
+ return { body: truncated.toString('utf-8'), truncated: true };
42
+ }
43
+ }
44
+ /**
45
+ * 添加请求
46
+ */
47
+ add(request) {
48
+ // 截断请求 body
49
+ const { body: truncatedBody, truncated: bodyTruncated } = this.truncateBody(request.body);
50
+ const processedRequest = {
51
+ ...request,
52
+ body: truncatedBody,
53
+ bodyTruncated: bodyTruncated || request.bodyTruncated,
54
+ };
55
+ // 计算写入位置
56
+ const position = this.writeIndex % this.maxSize;
57
+ // 清理旧条目的索引
58
+ const oldRequest = this.buffer[position];
59
+ if (oldRequest) {
60
+ this.idMap.delete(oldRequest.id);
61
+ }
62
+ // 写入新条目
63
+ this.buffer[position] = processedRequest;
64
+ this.idMap.set(request.id, position);
65
+ this.writeIndex++;
66
+ if (this.count < this.maxSize) {
67
+ this.count++;
68
+ }
69
+ }
70
+ /**
71
+ * 更新响应数据
72
+ */
73
+ updateResponse(id, response) {
74
+ const position = this.idMap.get(id);
75
+ if (position === undefined)
76
+ return;
77
+ const request = this.buffer[position];
78
+ if (!request)
79
+ return;
80
+ // 截断响应 body
81
+ const { body: truncatedBody, truncated: bodyTruncated } = this.truncateBody(response.body);
82
+ request.response = {
83
+ ...response,
84
+ body: truncatedBody,
85
+ bodyTruncated: bodyTruncated || response.bodyTruncated,
86
+ };
87
+ }
88
+ /**
89
+ * 更新时序数据
90
+ */
91
+ updateTiming(id, timing) {
92
+ const position = this.idMap.get(id);
93
+ if (position === undefined)
94
+ return;
95
+ const request = this.buffer[position];
96
+ if (!request)
97
+ return;
98
+ request.timing = timing;
99
+ }
100
+ /**
101
+ * 更新错误数据
102
+ */
103
+ updateError(id, error) {
104
+ const position = this.idMap.get(id);
105
+ if (position === undefined)
106
+ return;
107
+ const request = this.buffer[position];
108
+ if (!request)
109
+ return;
110
+ request.error = error;
111
+ }
112
+ /**
113
+ * 根据 ID 获取请求
114
+ */
115
+ get(id) {
116
+ const position = this.idMap.get(id);
117
+ if (position === undefined)
118
+ return undefined;
119
+ return this.buffer[position];
120
+ }
121
+ /**
122
+ * 根据 TraceID 获取所有相关请求
123
+ */
124
+ getByTraceId(traceId) {
125
+ const results = [];
126
+ for (let i = 0; i < this.count; i++) {
127
+ const position = (this.writeIndex - 1 - i + this.maxSize) % this.maxSize;
128
+ const request = this.buffer[position];
129
+ if (request && request.traceId === traceId) {
130
+ results.push(request);
131
+ }
132
+ }
133
+ return results;
134
+ }
135
+ /**
136
+ * 查询请求
137
+ */
138
+ query(filter) {
139
+ const results = [];
140
+ for (let i = 0; i < this.count; i++) {
141
+ const position = (this.writeIndex - 1 - i + this.maxSize) % this.maxSize;
142
+ const request = this.buffer[position];
143
+ if (!request)
144
+ continue;
145
+ // URL 模式匹配
146
+ if (filter.urlPattern) {
147
+ const pattern = filter.urlPattern instanceof RegExp
148
+ ? filter.urlPattern
149
+ : new RegExp(filter.urlPattern);
150
+ if (!pattern.test(request.url))
151
+ continue;
152
+ }
153
+ // 状态码匹配
154
+ if (filter.statusCode !== undefined) {
155
+ if (!request.response || request.response.statusCode !== filter.statusCode)
156
+ continue;
157
+ }
158
+ // 状态码范围匹配
159
+ if (filter.statusCodeMin !== undefined) {
160
+ if (!request.response || request.response.statusCode < filter.statusCodeMin)
161
+ continue;
162
+ }
163
+ if (filter.statusCodeMax !== undefined) {
164
+ if (!request.response || request.response.statusCode > filter.statusCodeMax)
165
+ continue;
166
+ }
167
+ // 方法匹配
168
+ if (filter.method !== undefined) {
169
+ if (request.method.toUpperCase() !== filter.method.toUpperCase())
170
+ continue;
171
+ }
172
+ // TraceID 匹配
173
+ if (filter.traceId !== undefined) {
174
+ if (request.traceId !== filter.traceId)
175
+ continue;
176
+ }
177
+ results.push(request);
178
+ }
179
+ return results;
180
+ }
181
+ /**
182
+ * 清空所有请求
183
+ */
184
+ clear() {
185
+ this.buffer = new Array(this.maxSize).fill(undefined);
186
+ this.idMap.clear();
187
+ this.writeIndex = 0;
188
+ this.count = 0;
189
+ }
190
+ /**
191
+ * 获取所有请求(按时间倒序)
192
+ */
193
+ getAll() {
194
+ const results = [];
195
+ for (let i = 0; i < this.count; i++) {
196
+ const position = (this.writeIndex - 1 - i + this.maxSize) % this.maxSize;
197
+ const request = this.buffer[position];
198
+ if (request) {
199
+ results.push(request);
200
+ }
201
+ }
202
+ return results;
203
+ }
204
+ /**
205
+ * 获取当前存储的请求数量
206
+ */
207
+ size() {
208
+ return this.count;
209
+ }
210
+ }
211
+ // 全局单例
212
+ let globalStore = null;
213
+ /**
214
+ * 获取全局请求存储实例
215
+ */
216
+ export function getRequestStore() {
217
+ if (!globalStore) {
218
+ globalStore = new RingBufferStore();
219
+ }
220
+ return globalStore;
221
+ }
222
+ /**
223
+ * 重置全局请求存储(用于测试)
224
+ */
225
+ export function resetRequestStore() {
226
+ globalStore = null;
227
+ }
228
+ /**
229
+ * 创建新的请求存储实例(用于测试)
230
+ */
231
+ export function createRequestStore(maxSize, maxBodySize) {
232
+ return new RingBufferStore(maxSize, maxBodySize);
233
+ }
234
+ // 导出类型别名
235
+ export { RingBufferStore as RequestStore };
236
+ //# sourceMappingURL=ring-buffer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ring-buffer.js","sourceRoot":"","sources":["../../../src/store/ring-buffer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Vitest 测试设置文件
3
+ *
4
+ * 这个文件在每个测试文件运行前执行
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=test-setup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-setup.js","sourceRoot":"","sources":["../../src/test-setup.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
@@ -0,0 +1 @@
1
+ *,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.invisible{visibility:hidden}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.top-full{top:100%}.z-10{z-index:10}.mx-2{margin-left:.5rem;margin-right:.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-10{height:2.5rem}.h-2{height:.5rem}.h-4{height:1rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-full{height:100%}.max-h-96{max-height:24rem}.w-16{width:4rem}.w-20{width:5rem}.w-48{width:12rem}.w-96{width:24rem}.w-full{width:100%}.w-px{width:1px}.min-w-\[100px\]{min-width:100px}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-t{border-top-width:1px}.border-devtools-accent{border-color:var(--devtools-accent)}.border-devtools-border{border-color:var(--devtools-border)}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-cyan-500{--tw-bg-opacity: 1;background-color:rgb(6 182 212 / var(--tw-bg-opacity, 1))}.bg-devtools-accent{background-color:var(--devtools-accent)}.bg-devtools-bg{background-color:var(--devtools-bg)}.bg-devtools-bg-secondary{background-color:var(--devtools-bg-secondary)}.bg-devtools-bg-selected{background-color:var(--devtools-bg-selected)}.bg-devtools-border{background-color:var(--devtools-border)}.bg-devtools-warning{background-color:var(--devtools-warning)}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.p-2{padding:.5rem}.p-3{padding:.75rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-\[10px\]{font-size:10px}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.text-devtools-accent{color:var(--devtools-accent)}.text-devtools-bg{color:var(--devtools-bg)}.text-devtools-error{color:var(--devtools-error)}.text-devtools-header-name{color:var(--devtools-header-name)}.text-devtools-method{color:var(--devtools-method)}.text-devtools-success{color:var(--devtools-success)}.text-devtools-text{color:var(--devtools-text)}.text-devtools-text-secondary{color:var(--devtools-text-secondary)}.text-devtools-warning{color:var(--devtools-warning)}.placeholder-devtools-text-secondary::-moz-placeholder{color:var(--devtools-text-secondary)}.placeholder-devtools-text-secondary::placeholder{color:var(--devtools-text-secondary)}.opacity-0{opacity:0}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root,.dark{--devtools-bg: #202124;--devtools-bg-secondary: #292a2d;--devtools-bg-hover: #35363a;--devtools-bg-selected: #3c4043;--devtools-border: #3c4043;--devtools-text: #e8eaed;--devtools-text-secondary: #9aa0a6;--devtools-accent: #8ab4f8;--devtools-success: #81c995;--devtools-warning: #fdd663;--devtools-error: #f28b82;--devtools-pending: #9aa0a6;--devtools-method: #8ab4f8;--devtools-header-name: #9980ff;--scrollbar-track: #202124;--scrollbar-thumb: #5f6368;--scrollbar-thumb-hover: #80868b}.light{--devtools-bg: #ffffff;--devtools-bg-secondary: #f1f3f4;--devtools-bg-hover: #e8eaed;--devtools-bg-selected: #d2e3fc;--devtools-border: #dadce0;--devtools-text: #202124;--devtools-text-secondary: #5f6368;--devtools-accent: #1a73e8;--devtools-success: #188038;--devtools-warning: #f9ab00;--devtools-error: #d93025;--devtools-pending: #5f6368;--devtools-method: #1a73e8;--devtools-header-name: #7c4dff;--scrollbar-track: #f1f3f4;--scrollbar-thumb: #dadce0;--scrollbar-thumb-hover: #bdc1c6}html,body,#root{height:100%;margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}::-moz-selection{background:#8ab4f84d}::selection{background:#8ab4f84d}.light ::-moz-selection{background:#1a73e833}.light ::selection{background:#1a73e833}.code-block{overflow:auto;border-radius:.25rem;background-color:var(--devtools-bg-secondary);padding:.5rem;font-family:Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.875rem;line-height:1.25rem}.request-row:hover{background-color:var(--devtools-bg-hover)}.request-row.selected{background-color:var(--devtools-accent);--tw-bg-opacity: .2}.hover\:bg-devtools-bg-hover:hover{background-color:var(--devtools-bg-hover)}.hover\:text-devtools-text:hover{color:var(--devtools-text)}.focus\:border-devtools-accent:focus{border-color:var(--devtools-accent)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.group:hover .group-hover\:visible{visibility:visible}.group:hover .group-hover\:opacity-100{opacity:1}