@xbrowser/cli 0.16.0 → 1.0.2

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 (52) hide show
  1. package/README.md +17 -26
  2. package/dist/{browser-R7B255ML.js → browser-GITRHHFO.js} +4 -1
  3. package/dist/{browser-GWBH6OJK.js → browser-R56O3CW6.js} +3 -1
  4. package/dist/{browser-I2HJZ7IP.js → browser-ZJOZB5CR.js} +4 -2
  5. package/dist/cdp-driver-BE3FOMRN.js +2803 -0
  6. package/dist/cdp-driver-TOPYJIFL.js +47 -0
  7. package/dist/chunk-2SVQTI2O.js +2794 -0
  8. package/dist/{chunk-KDYXFLAC.js → chunk-ACFE6PKF.js} +1015 -121
  9. package/dist/chunk-BBMRDUYQ.js +260 -0
  10. package/dist/chunk-CAFNSGYM.js +4834 -0
  11. package/dist/{chunk-DTJRVA76.js → chunk-ETCO4SNK.js} +2 -2
  12. package/dist/{chunk-RS6YYWTK.js → chunk-JPA2ZT2R.js} +140 -72
  13. package/dist/chunk-JPHCY4TC.js +260 -0
  14. package/dist/chunk-KFQGP6VL.js +33 -0
  15. package/dist/{chunk-ITKPSIP7.js → chunk-MDAPTB7C.js} +6 -25
  16. package/dist/chunk-OZKD3W4X.js +417 -0
  17. package/dist/chunk-PPG4D2EW.js +2796 -0
  18. package/dist/{chunk-ATFTAKMN.js → chunk-Q4IGYTKR.js} +39 -7
  19. package/dist/{chunk-F3ZWFCJJ.js → chunk-QIK2I3VQ.js} +141 -72
  20. package/dist/chunk-WJRE55TN.js +83 -0
  21. package/dist/cli.js +2358 -1086
  22. package/dist/{convert-4DUWZIKH.js → convert-LB3GJTLR.js} +4 -2
  23. package/dist/{convert-EKQVHKB4.js → convert-R3XXYKC6.js} +2 -2
  24. package/dist/{daemon-client-GX2UYIW4.js → daemon-client-DRCUMNHK.js} +45 -72
  25. package/dist/{daemon-client-XWSSQBEA.js → daemon-client-UZZEHHIV.js} +8 -1
  26. package/dist/daemon-main.js +3067 -1688
  27. package/dist/{extract-JUOQQX4V.js → extract-2ZFW2MX7.js} +1 -1
  28. package/dist/{extract-EGRXZSSK.js → extract-BSYBM4MR.js} +2 -0
  29. package/dist/{filter-OLAE26HN.js → filter-KCFO4RSV.js} +2 -0
  30. package/dist/{filter-VID2GGZ7.js → filter-T7DSZ2X7.js} +1 -1
  31. package/dist/{human-interaction-W753RVJB.js → human-interaction-UKAS5ZXV.js} +2 -2
  32. package/dist/index.d.ts +745 -148
  33. package/dist/index.js +3488 -1719
  34. package/dist/launcher-QUJ4M2VS.js +19 -0
  35. package/dist/launcher-YARP45UY.js +19 -0
  36. package/dist/{network-store-YAF5OIBH.js → network-store-XGZ25FFC.js} +1 -0
  37. package/dist/{network-store-BN6QEZ7R.js → network-store-YVDNUREI.js} +1 -1
  38. package/dist/{parse-action-dsl-T3DYC33D.js → parse-action-dsl-UM333TL2.js} +1 -1
  39. package/dist/{proxy-WKGUCH2C.js → proxy-LV4BJ5RC.js} +1 -1
  40. package/dist/session-recorder-RTDGURIJ.js +8 -0
  41. package/dist/session-recorder-YI7YYM36.js +7 -0
  42. package/dist/session-replayer-GLTUICSD.js +276 -0
  43. package/dist/site-knowledge-SYC6VCDB.js +23 -0
  44. package/package.json +6 -6
  45. package/dist/chunk-2ONMTDLK.js +0 -2050
  46. package/dist/daemon-client-3IJD6X4B.js +0 -59
  47. package/dist/network-store-2S5HATEV.js +0 -194
  48. package/dist/parse-action-dsl-DRSPBALP.js +0 -72
  49. package/dist/screenshot-CWAWMXVA.js +0 -28
  50. package/dist/screenshot-MB6R7RSS.js +0 -26
  51. package/dist/session-recorder-ILSSV2UC.js +0 -6
  52. package/dist/session-recorder-XET3DNML.js +0 -7
@@ -1,59 +0,0 @@
1
- import {
2
- daemonPing,
3
- forwardChain,
4
- forwardCommandLog,
5
- forwardExec,
6
- forwardNetworkAnalyze,
7
- forwardNetworkAround,
8
- forwardNetworkClear,
9
- forwardNetworkCurl,
10
- forwardNetworkDislike,
11
- forwardNetworkExport,
12
- forwardNetworkInspect,
13
- forwardNetworkLike,
14
- forwardNetworkList,
15
- forwardNetworkReplay,
16
- forwardNetworkTop,
17
- forwardRecordCheckpoint,
18
- forwardRecordStart,
19
- forwardRecordStatus,
20
- forwardRecordStop,
21
- forwardRecordSummary,
22
- forwardReplay,
23
- forwardReplayResume,
24
- forwardSessionClose,
25
- forwardSessionCreate,
26
- forwardSessionList,
27
- forwardViewerCheckSelector,
28
- isDaemonRunning
29
- } from "./chunk-ATFTAKMN.js";
30
- import "./chunk-3RG5ZIWI.js";
31
- export {
32
- daemonPing,
33
- forwardChain,
34
- forwardCommandLog,
35
- forwardExec,
36
- forwardNetworkAnalyze,
37
- forwardNetworkAround,
38
- forwardNetworkClear,
39
- forwardNetworkCurl,
40
- forwardNetworkDislike,
41
- forwardNetworkExport,
42
- forwardNetworkInspect,
43
- forwardNetworkLike,
44
- forwardNetworkList,
45
- forwardNetworkReplay,
46
- forwardNetworkTop,
47
- forwardRecordCheckpoint,
48
- forwardRecordStart,
49
- forwardRecordStatus,
50
- forwardRecordStop,
51
- forwardRecordSummary,
52
- forwardReplay,
53
- forwardReplayResume,
54
- forwardSessionClose,
55
- forwardSessionCreate,
56
- forwardSessionList,
57
- forwardViewerCheckSelector,
58
- isDaemonRunning
59
- };
@@ -1,194 +0,0 @@
1
- // src/daemon/network-scorer.ts
2
- var DEFAULT_WEIGHTS = {
3
- method: { post: 30, get: 10, other: 5 },
4
- resourceType: { api: 20, document: 0, static: -50, other: 0 },
5
- size: { goodRange: 20, tooLarge: -10 },
6
- content: { isJson: 10, hasDataArray: 15, urlContainsApi: 10 }
7
- };
8
- var STATIC_TYPES = /* @__PURE__ */ new Set(["stylesheet", "image", "font", "media"]);
9
- var DATA_ARRAY_KEYS = /* @__PURE__ */ new Set(["data", "list", "items", "results", "records"]);
10
- function calcMethodScore(entry, weights) {
11
- const m = entry.method.toUpperCase();
12
- if (m === "POST" || m === "PUT" || m === "DELETE") return weights.method.post;
13
- if (m === "GET") return weights.method.get;
14
- return weights.method.other;
15
- }
16
- function calcResourceTypeScore(entry, weights) {
17
- const rt = entry.resourceType.toLowerCase();
18
- if (rt === "xhr" || rt === "fetch") return weights.resourceType.api;
19
- if (rt === "document") return weights.resourceType.document;
20
- if (STATIC_TYPES.has(rt)) return weights.resourceType.static;
21
- return weights.resourceType.other;
22
- }
23
- function calcSizeScore(entry, weights) {
24
- if (entry.size > 1024 * 1024) return weights.size.tooLarge;
25
- const isJson = entry.contentType.toLowerCase().includes("json");
26
- if (entry.body !== void 0 && isJson && entry.size > 0 && entry.size < 100 * 1024) {
27
- return weights.size.goodRange;
28
- }
29
- return 0;
30
- }
31
- function calcContentScore(entry, weights) {
32
- let score = 0;
33
- if (entry.contentType.toLowerCase().includes("json")) {
34
- score += weights.content.isJson;
35
- }
36
- if (typeof entry.body === "object" && entry.body !== null && !Array.isArray(entry.body)) {
37
- for (const key of Object.keys(entry.body)) {
38
- if (DATA_ARRAY_KEYS.has(key) && Array.isArray(entry.body[key])) {
39
- score += weights.content.hasDataArray;
40
- break;
41
- }
42
- }
43
- }
44
- const urlLower = entry.url.toLowerCase();
45
- if (urlLower.includes("/api/") || urlLower.includes("/v1/") || urlLower.includes("/v2/") || urlLower.includes("/graphql")) {
46
- score += weights.content.urlContainsApi;
47
- }
48
- return score;
49
- }
50
- function scoreEntry(entry, weights = DEFAULT_WEIGHTS) {
51
- const method = calcMethodScore(entry, weights);
52
- const resourceType = calcResourceTypeScore(entry, weights);
53
- const size = calcSizeScore(entry, weights);
54
- const content = calcContentScore(entry, weights);
55
- return {
56
- ...entry,
57
- score: method + resourceType + size + content,
58
- scoreBreakdown: { method, resourceType, size, content }
59
- };
60
- }
61
- function scoreEntries(entries, weights = DEFAULT_WEIGHTS, feedbackFn) {
62
- return entries.map((e) => {
63
- const scored = scoreEntry(e, weights);
64
- if (feedbackFn) {
65
- scored.score += feedbackFn(e.path, e.method);
66
- }
67
- return scored;
68
- }).sort((a, b) => b.score - a.score);
69
- }
70
-
71
- // src/daemon/network-store.ts
72
- var NetworkCaptureStore = class {
73
- stores = /* @__PURE__ */ new Map();
74
- maxEntries;
75
- constructor(maxEntries = 2e3) {
76
- this.maxEntries = maxEntries;
77
- }
78
- getStore(sessionName) {
79
- let store = this.stores.get(sessionName);
80
- if (!store) {
81
- store = { entries: [], counter: 0 };
82
- this.stores.set(sessionName, store);
83
- }
84
- return store;
85
- }
86
- add(sessionName, entry) {
87
- const store = this.getStore(sessionName);
88
- store.counter += 1;
89
- const fullEntry = { ...entry, id: store.counter };
90
- store.entries.push(fullEntry);
91
- if (store.entries.length > this.maxEntries) {
92
- store.entries.splice(0, store.entries.length - this.maxEntries);
93
- }
94
- }
95
- list(sessionName, options) {
96
- const store = this.getStore(sessionName);
97
- let entries = store.entries;
98
- if (options?.filter) {
99
- const f = options.filter.toLowerCase();
100
- entries = entries.filter(
101
- (e) => e.url.toLowerCase().includes(f) || e.path.toLowerCase().includes(f) || e.contentType.toLowerCase().includes(f)
102
- );
103
- }
104
- if (options?.method) {
105
- const m = options.method.toUpperCase();
106
- entries = entries.filter((e) => e.method === m);
107
- }
108
- const total = entries.length;
109
- const offset = options?.offset ?? 0;
110
- const limit = options?.limit ?? 50;
111
- const captures = entries.slice(offset, offset + limit);
112
- return { session: sessionName, total, captures };
113
- }
114
- inspect(sessionName, id) {
115
- const store = this.getStore(sessionName);
116
- const capture = store.entries.find((e) => e.id === id) ?? null;
117
- return { session: sessionName, capture };
118
- }
119
- clear(sessionName) {
120
- this.stores.delete(sessionName);
121
- }
122
- top(sessionName, options) {
123
- const store = this.getStore(sessionName);
124
- const feedbackFn = options?.feedbackFn;
125
- const scored = feedbackFn ? scoreEntries(store.entries, void 0, feedbackFn) : scoreEntries(store.entries);
126
- const minScore = options?.minScore ?? 0;
127
- const filtered = scored.filter((e) => e.score >= minScore);
128
- const limit = options?.limit ?? 20;
129
- return { session: sessionName, entries: filtered.slice(0, limit) };
130
- }
131
- around(sessionName, commandId, cmdLogStore, windowMs = 5e3) {
132
- const cmd = cmdLogStore.findEntry(sessionName, commandId);
133
- if (!cmd) return null;
134
- const netStore = this.getStore(sessionName);
135
- const before = netStore.entries.filter(
136
- (e) => e.timestamp >= cmd.timestamp - windowMs && e.timestamp < cmd.timestamp
137
- );
138
- const after = netStore.entries.filter(
139
- (e) => e.timestamp >= cmd.timestamp && e.timestamp < cmd.timestamp + windowMs
140
- );
141
- return { command: cmd, before, after, afterCount: after.length };
142
- }
143
- clearAll() {
144
- this.stores.clear();
145
- }
146
- };
147
- var CommandLogStore = class {
148
- stores = /* @__PURE__ */ new Map();
149
- maxEntries;
150
- constructor(maxEntries = 500) {
151
- this.maxEntries = maxEntries;
152
- }
153
- getStore(sessionName) {
154
- let store = this.stores.get(sessionName);
155
- if (!store) {
156
- store = { entries: [], counter: 0 };
157
- this.stores.set(sessionName, store);
158
- }
159
- return store;
160
- }
161
- add(sessionName, entry) {
162
- const store = this.getStore(sessionName);
163
- store.counter += 1;
164
- const fullEntry = { ...entry, id: store.counter };
165
- store.entries.push(fullEntry);
166
- if (store.entries.length > this.maxEntries) {
167
- store.entries.splice(0, store.entries.length - this.maxEntries);
168
- }
169
- }
170
- list(sessionName, options) {
171
- const store = this.getStore(sessionName);
172
- const offset = options?.offset ?? 0;
173
- const limit = options?.limit ?? 50;
174
- return store.entries.slice(offset, offset + limit);
175
- }
176
- findEntry(sessionName, id) {
177
- const store = this.stores.get(sessionName);
178
- return store?.entries.find((e) => e.id === id) ?? null;
179
- }
180
- clear(sessionName) {
181
- this.stores.delete(sessionName);
182
- }
183
- clearAll() {
184
- this.stores.clear();
185
- }
186
- };
187
- var commandLogStore = new CommandLogStore();
188
- var networkStore = new NetworkCaptureStore();
189
- export {
190
- CommandLogStore,
191
- NetworkCaptureStore,
192
- commandLogStore,
193
- networkStore
194
- };
@@ -1,72 +0,0 @@
1
- // src/lib/parse-action-dsl.ts
2
- function parseActionDsl(dsl) {
3
- const trimmed = dsl.trim();
4
- if (!trimmed) throw new Error("Empty action DSL");
5
- const spaceIndex = trimmed.indexOf(" ");
6
- const type = spaceIndex === -1 ? trimmed : trimmed.slice(0, spaceIndex);
7
- const rest = spaceIndex === -1 ? "" : trimmed.slice(spaceIndex + 1).trim();
8
- switch (type) {
9
- case "wait": {
10
- const num = Number(rest);
11
- if (rest && !isNaN(num) && Number.isFinite(num)) {
12
- return { type: "wait", milliseconds: num };
13
- }
14
- return { type: "wait", selector: rest };
15
- }
16
- case "click": {
17
- const hasAll = rest.includes("--all");
18
- const selector = rest.replace("--all", "").trim();
19
- return { type: "click", selector, ...hasAll ? { all: true } : {} };
20
- }
21
- case "write": {
22
- return { type: "write", text: rest };
23
- }
24
- case "press": {
25
- return { type: "press", key: rest };
26
- }
27
- case "scroll": {
28
- const parts = rest.split(/\s+/);
29
- let direction;
30
- let selector;
31
- for (const part of parts) {
32
- if (part === "up" || part === "down") {
33
- direction = part;
34
- } else if (part && !part.startsWith("--")) {
35
- selector = part;
36
- }
37
- }
38
- return { type: "scroll", ...direction ? { direction } : {}, ...selector ? { selector } : {} };
39
- }
40
- case "screenshot": {
41
- const fullPage = rest.includes("--full-page");
42
- const qualityMatch = rest.match(/--quality\s+(\d+)/);
43
- return {
44
- type: "screenshot",
45
- ...fullPage ? { fullPage } : {},
46
- ...qualityMatch ? { quality: Number(qualityMatch[1]) } : {}
47
- };
48
- }
49
- case "scrape": {
50
- return { type: "scrape" };
51
- }
52
- case "exec": {
53
- return { type: "executeJavascript", script: rest };
54
- }
55
- case "pdf": {
56
- const landscape = rest.includes("--landscape");
57
- const formatMatch = rest.match(/--format\s+(\S+)/);
58
- const scaleMatch = rest.match(/--scale\s+([\d.]+)/);
59
- return {
60
- type: "pdf",
61
- ...landscape ? { landscape } : {},
62
- ...formatMatch ? { format: formatMatch[1] } : {},
63
- ...scaleMatch ? { scale: Number(scaleMatch[1]) } : {}
64
- };
65
- }
66
- default:
67
- throw new Error(`Unknown action type: "${type}". Supported: wait, click, write, press, scroll, screenshot, scrape, exec, pdf`);
68
- }
69
- }
70
- export {
71
- parseActionDsl
72
- };
@@ -1,28 +0,0 @@
1
- import "./chunk-3RG5ZIWI.js";
2
-
3
- // src/hooks/screenshot.ts
4
- var screenshotHook = {
5
- name: "screenshot",
6
- async onAfterCommand(ctx) {
7
- try {
8
- const quality = parseInt(process.env.XBROWSER_SCREENSHOT_QUALITY || "40");
9
- const buffer = await ctx.page.screenshot({
10
- type: "jpeg",
11
- quality: Math.max(10, Math.min(100, quality))
12
- });
13
- const entry = {
14
- step: ctx.command,
15
- command: ctx.command,
16
- base64: buffer.toString("base64"),
17
- url: ctx.page.url(),
18
- timestamp: Date.now()
19
- };
20
- return { screenshot: entry };
21
- } catch {
22
- return void 0;
23
- }
24
- }
25
- };
26
- export {
27
- screenshotHook
28
- };
@@ -1,26 +0,0 @@
1
- // src/hooks/screenshot.ts
2
- var screenshotHook = {
3
- name: "screenshot",
4
- async onAfterCommand(ctx) {
5
- try {
6
- const quality = parseInt(process.env.XBROWSER_SCREENSHOT_QUALITY || "40");
7
- const buffer = await ctx.page.screenshot({
8
- type: "jpeg",
9
- quality: Math.max(10, Math.min(100, quality))
10
- });
11
- const entry = {
12
- step: ctx.command,
13
- command: ctx.command,
14
- base64: buffer.toString("base64"),
15
- url: ctx.page.url(),
16
- timestamp: Date.now()
17
- };
18
- return { screenshot: entry };
19
- } catch {
20
- return void 0;
21
- }
22
- }
23
- };
24
- export {
25
- screenshotHook
26
- };
@@ -1,6 +0,0 @@
1
- import {
2
- SessionRecorder
3
- } from "./chunk-KDYXFLAC.js";
4
- export {
5
- SessionRecorder
6
- };
@@ -1,7 +0,0 @@
1
- import {
2
- SessionRecorder
3
- } from "./chunk-KDYXFLAC.js";
4
- import "./chunk-3RG5ZIWI.js";
5
- export {
6
- SessionRecorder
7
- };