patchright-core 1.58.2 → 1.59.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 (285) hide show
  1. package/ThirdPartyNotices.txt +126 -650
  2. package/browsers.json +16 -14
  3. package/lib/bootstrap.js +77 -0
  4. package/lib/cli/browserActions.js +308 -0
  5. package/lib/cli/driver.js +3 -2
  6. package/lib/cli/installActions.js +171 -0
  7. package/lib/cli/program.js +47 -411
  8. package/lib/client/android.js +4 -4
  9. package/lib/client/api.js +3 -3
  10. package/lib/client/browser.js +8 -0
  11. package/lib/client/browserContext.js +22 -61
  12. package/lib/client/browserType.js +19 -51
  13. package/lib/client/cdpSession.js +6 -2
  14. package/lib/client/channelOwner.js +1 -1
  15. package/lib/client/clientHelper.js +2 -1
  16. package/lib/client/clock.js +0 -1
  17. package/lib/client/{webSocket.js → connect.js} +57 -7
  18. package/lib/client/connection.js +8 -4
  19. package/lib/client/consoleMessage.js +3 -0
  20. package/lib/client/debugger.js +57 -0
  21. package/lib/client/dialog.js +8 -1
  22. package/lib/client/disposable.js +76 -0
  23. package/lib/client/electron.js +1 -0
  24. package/lib/client/elementHandle.js +1 -4
  25. package/lib/client/events.js +3 -3
  26. package/lib/client/fetch.js +0 -1
  27. package/lib/client/frame.js +10 -23
  28. package/lib/client/harRouter.js +13 -1
  29. package/lib/client/jsHandle.js +4 -8
  30. package/lib/client/locator.js +13 -44
  31. package/lib/client/network.js +15 -16
  32. package/lib/client/page.js +41 -75
  33. package/lib/client/platform.js +0 -3
  34. package/lib/client/screencast.js +88 -0
  35. package/lib/client/selectors.js +3 -1
  36. package/lib/client/tracing.js +11 -5
  37. package/lib/client/video.js +13 -20
  38. package/lib/client/worker.js +6 -6
  39. package/lib/generated/bindingsControllerSource.js +1 -1
  40. package/lib/generated/clockSource.js +1 -1
  41. package/lib/generated/injectedScriptSource.js +1 -1
  42. package/lib/generated/pollingRecorderSource.js +1 -1
  43. package/lib/generated/storageScriptSource.js +1 -1
  44. package/lib/generated/utilityScriptSource.js +1 -1
  45. package/lib/mcpBundle.js +0 -6
  46. package/lib/mcpBundleImpl.js +91 -0
  47. package/lib/protocol/validator.js +224 -138
  48. package/lib/protocol/validatorPrimitives.js +1 -1
  49. package/lib/remote/playwrightConnection.js +10 -8
  50. package/lib/remote/playwrightPipeServer.js +100 -0
  51. package/lib/remote/playwrightServer.js +13 -8
  52. package/lib/remote/playwrightWebSocketServer.js +73 -0
  53. package/lib/remote/serverTransport.js +96 -0
  54. package/lib/server/android/android.js +2 -2
  55. package/lib/server/bidi/bidiBrowser.js +30 -8
  56. package/lib/server/bidi/bidiChromium.js +18 -5
  57. package/lib/server/bidi/bidiNetworkManager.js +39 -11
  58. package/lib/server/bidi/bidiPage.js +31 -15
  59. package/lib/server/bidi/third_party/firefoxPrefs.js +3 -1
  60. package/lib/server/browser.js +84 -21
  61. package/lib/server/browserContext.js +110 -58
  62. package/lib/server/browserType.js +14 -12
  63. package/lib/server/chromium/chromium.js +15 -12
  64. package/lib/server/chromium/chromiumSwitches.js +14 -2
  65. package/lib/server/chromium/crBrowser.js +20 -17
  66. package/lib/server/chromium/crCoverage.js +1 -13
  67. package/lib/server/chromium/crDevTools.js +1 -0
  68. package/lib/server/chromium/crNetworkManager.js +12 -267
  69. package/lib/server/chromium/crPage.js +67 -199
  70. package/lib/server/chromium/crServiceWorker.js +7 -14
  71. package/lib/server/clock.js +33 -41
  72. package/lib/server/console.js +5 -1
  73. package/lib/server/debugController.js +12 -6
  74. package/lib/server/debugger.js +40 -47
  75. package/lib/server/deviceDescriptorsSource.json +137 -137
  76. package/lib/server/dispatchers/browserContextDispatcher.js +29 -30
  77. package/lib/server/dispatchers/browserDispatcher.js +11 -5
  78. package/lib/server/dispatchers/browserTypeDispatcher.js +7 -0
  79. package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -1
  80. package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
  81. package/lib/server/dispatchers/dispatcher.js +1 -1
  82. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  83. package/lib/server/dispatchers/electronDispatcher.js +2 -1
  84. package/lib/server/dispatchers/frameDispatcher.js +6 -6
  85. package/lib/server/dispatchers/jsHandleDispatcher.js +2 -2
  86. package/lib/server/dispatchers/localUtilsDispatcher.js +37 -1
  87. package/lib/server/dispatchers/networkDispatchers.js +6 -5
  88. package/lib/server/dispatchers/pageDispatcher.js +101 -38
  89. package/lib/server/dispatchers/webSocketRouteDispatcher.js +4 -5
  90. package/lib/server/disposable.js +41 -0
  91. package/lib/server/dom.js +44 -26
  92. package/lib/server/download.js +3 -2
  93. package/lib/server/electron/electron.js +12 -7
  94. package/lib/server/firefox/ffBrowser.js +9 -19
  95. package/lib/server/firefox/ffInput.js +21 -5
  96. package/lib/server/firefox/ffNetworkManager.js +2 -2
  97. package/lib/server/firefox/ffPage.js +24 -27
  98. package/lib/server/frameSelectors.js +5 -172
  99. package/lib/server/frames.js +234 -687
  100. package/lib/server/har/harRecorder.js +2 -2
  101. package/lib/server/har/harTracer.js +5 -4
  102. package/lib/server/input.js +49 -4
  103. package/lib/server/instrumentation.js +5 -0
  104. package/lib/server/javascript.js +6 -26
  105. package/lib/server/launchApp.js +1 -3
  106. package/lib/server/localUtils.js +6 -6
  107. package/lib/server/network.js +9 -8
  108. package/lib/server/overlay.js +138 -0
  109. package/lib/server/page.js +157 -105
  110. package/lib/server/progress.js +6 -0
  111. package/lib/server/recorder/recorderApp.js +9 -8
  112. package/lib/server/recorder.js +76 -40
  113. package/lib/server/registry/index.js +55 -82
  114. package/lib/server/registry/nativeDeps.js +1 -0
  115. package/lib/server/screencast.js +90 -143
  116. package/lib/server/screenshotter.js +0 -6
  117. package/lib/server/trace/recorder/snapshotter.js +8 -17
  118. package/lib/server/trace/recorder/snapshotterInjected.js +82 -20
  119. package/lib/server/trace/recorder/tracing.js +87 -44
  120. package/lib/server/trace/viewer/traceViewer.js +3 -4
  121. package/lib/server/usKeyboardLayout.js +7 -0
  122. package/lib/server/utils/comparators.js +1 -1
  123. package/lib/server/utils/disposable.js +32 -0
  124. package/lib/server/utils/eventsHelper.js +3 -1
  125. package/lib/server/utils/fileUtils.js +16 -2
  126. package/lib/server/utils/happyEyeballs.js +15 -12
  127. package/lib/server/utils/hostPlatform.js +0 -15
  128. package/lib/server/utils/httpServer.js +5 -3
  129. package/lib/server/utils/network.js +2 -1
  130. package/lib/server/utils/nodePlatform.js +0 -6
  131. package/lib/server/utils/processLauncher.js +8 -6
  132. package/lib/server/utils/zipFile.js +2 -2
  133. package/lib/server/videoRecorder.js +82 -12
  134. package/lib/server/webkit/wkBrowser.js +1 -6
  135. package/lib/server/webkit/wkPage.js +27 -25
  136. package/lib/server/webkit/wkWorkers.js +2 -1
  137. package/lib/serverRegistry.js +156 -0
  138. package/lib/tools/backend/browserBackend.js +79 -0
  139. package/lib/tools/backend/common.js +63 -0
  140. package/lib/tools/backend/config.js +41 -0
  141. package/lib/tools/backend/console.js +66 -0
  142. package/lib/tools/backend/context.js +296 -0
  143. package/lib/tools/backend/cookies.js +152 -0
  144. package/lib/tools/backend/devtools.js +69 -0
  145. package/lib/tools/backend/dialogs.js +59 -0
  146. package/lib/tools/backend/evaluate.js +64 -0
  147. package/lib/tools/backend/files.js +60 -0
  148. package/lib/tools/backend/form.js +64 -0
  149. package/lib/tools/backend/keyboard.js +155 -0
  150. package/lib/tools/backend/logFile.js +95 -0
  151. package/lib/tools/backend/mouse.js +168 -0
  152. package/lib/tools/backend/navigate.js +106 -0
  153. package/lib/tools/backend/network.js +135 -0
  154. package/lib/tools/backend/pdf.js +48 -0
  155. package/lib/tools/backend/response.js +305 -0
  156. package/lib/tools/backend/route.js +140 -0
  157. package/lib/tools/backend/runCode.js +77 -0
  158. package/lib/tools/backend/screenshot.js +88 -0
  159. package/lib/tools/backend/sessionLog.js +74 -0
  160. package/lib/tools/backend/snapshot.js +208 -0
  161. package/lib/tools/backend/storage.js +68 -0
  162. package/lib/tools/backend/tab.js +445 -0
  163. package/lib/tools/backend/tabs.js +67 -0
  164. package/lib/tools/backend/tool.js +47 -0
  165. package/lib/tools/backend/tools.js +102 -0
  166. package/lib/tools/backend/tracing.js +78 -0
  167. package/lib/tools/backend/utils.js +83 -0
  168. package/lib/tools/backend/verify.js +151 -0
  169. package/lib/tools/backend/video.js +98 -0
  170. package/lib/tools/backend/wait.js +63 -0
  171. package/lib/tools/backend/webstorage.js +223 -0
  172. package/lib/tools/cli-client/cli.js +6 -0
  173. package/lib/tools/cli-client/help.json +399 -0
  174. package/lib/tools/cli-client/minimist.js +128 -0
  175. package/lib/tools/cli-client/program.js +350 -0
  176. package/lib/tools/cli-client/registry.js +176 -0
  177. package/lib/tools/cli-client/session.js +289 -0
  178. package/lib/tools/cli-client/skill/SKILL.md +328 -0
  179. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  180. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  181. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  182. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  183. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  184. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  185. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  186. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  187. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  188. package/lib/tools/cli-daemon/command.js +73 -0
  189. package/lib/tools/cli-daemon/commands.js +956 -0
  190. package/lib/tools/cli-daemon/daemon.js +157 -0
  191. package/lib/tools/cli-daemon/helpGenerator.js +177 -0
  192. package/lib/tools/cli-daemon/program.js +129 -0
  193. package/lib/tools/dashboard/appIcon.png +0 -0
  194. package/lib/tools/dashboard/dashboardApp.js +284 -0
  195. package/lib/tools/dashboard/dashboardController.js +296 -0
  196. package/lib/tools/exports.js +60 -0
  197. package/lib/tools/mcp/browserFactory.js +233 -0
  198. package/lib/tools/mcp/cdpRelay.js +352 -0
  199. package/lib/tools/mcp/cli-stub.js +7 -0
  200. package/lib/tools/mcp/config.d.js +16 -0
  201. package/lib/tools/mcp/config.js +446 -0
  202. package/lib/tools/mcp/configIni.js +189 -0
  203. package/lib/tools/mcp/extensionContextFactory.js +55 -0
  204. package/lib/tools/mcp/index.js +62 -0
  205. package/lib/tools/mcp/log.js +35 -0
  206. package/lib/tools/mcp/program.js +107 -0
  207. package/lib/tools/mcp/protocol.js +28 -0
  208. package/lib/tools/mcp/watchdog.js +44 -0
  209. package/lib/tools/trace/SKILL.md +171 -0
  210. package/lib/{server/trace/viewer/traceParser.js → tools/trace/installSkill.js} +15 -39
  211. package/lib/tools/trace/traceActions.js +142 -0
  212. package/lib/tools/trace/traceAttachments.js +69 -0
  213. package/lib/tools/trace/traceCli.js +87 -0
  214. package/lib/tools/trace/traceConsole.js +97 -0
  215. package/lib/tools/trace/traceErrors.js +55 -0
  216. package/lib/tools/trace/traceOpen.js +69 -0
  217. package/lib/tools/trace/traceParser.js +96 -0
  218. package/lib/tools/trace/traceRequests.js +182 -0
  219. package/lib/tools/trace/traceScreenshot.js +68 -0
  220. package/lib/tools/trace/traceSnapshot.js +149 -0
  221. package/lib/tools/trace/traceUtils.js +153 -0
  222. package/lib/tools/utils/connect.js +32 -0
  223. package/lib/tools/utils/mcp/http.js +152 -0
  224. package/lib/tools/utils/mcp/server.js +230 -0
  225. package/lib/tools/utils/mcp/tool.js +47 -0
  226. package/lib/tools/utils/socketConnection.js +108 -0
  227. package/lib/utils/isomorphic/formatUtils.js +64 -0
  228. package/lib/utils/isomorphic/jsonSchema.js +89 -0
  229. package/lib/utils/isomorphic/mimeType.js +7 -2
  230. package/lib/utils/isomorphic/protocolFormatter.js +2 -2
  231. package/lib/utils/isomorphic/protocolMetainfo.js +127 -106
  232. package/lib/utils/isomorphic/stringUtils.js +3 -3
  233. package/lib/utils/isomorphic/timeoutRunner.js +3 -3
  234. package/lib/utils/isomorphic/trace/snapshotRenderer.js +35 -42
  235. package/lib/utils/isomorphic/trace/traceLoader.js +15 -14
  236. package/lib/utils/isomorphic/trace/traceModel.js +3 -2
  237. package/lib/utils/isomorphic/trace/traceModernizer.js +1 -0
  238. package/lib/utils/isomorphic/urlMatch.js +54 -1
  239. package/lib/utils/isomorphic/utilityScriptSerializers.js +11 -0
  240. package/lib/utils.js +6 -2
  241. package/lib/utilsBundle.js +3 -21
  242. package/lib/utilsBundleImpl/index.js +132 -133
  243. package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
  244. package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
  245. package/lib/vite/dashboard/index.html +28 -0
  246. package/lib/vite/htmlReport/index.html +2 -70
  247. package/lib/vite/htmlReport/report.css +1 -0
  248. package/lib/vite/htmlReport/report.js +72 -0
  249. package/lib/vite/recorder/assets/{codeMirrorModule-CFUTFUO7.js → codeMirrorModule-C8KMvO9L.js} +20 -20
  250. package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
  251. package/lib/vite/recorder/index.html +1 -1
  252. package/lib/vite/traceViewer/assets/{codeMirrorModule-BVA4h_ZY.js → codeMirrorModule-DS0FLvoc.js} +20 -20
  253. package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
  254. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  255. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  256. package/lib/vite/traceViewer/{index.BtyWtaE-.js → index.Dtstcb7U.js} +1 -1
  257. package/lib/vite/traceViewer/index.html +4 -4
  258. package/lib/vite/traceViewer/sw.bundle.js +4 -4
  259. package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
  260. package/lib/vite/traceViewer/uiMode.html +3 -3
  261. package/lib/zipBundleImpl.js +2 -2
  262. package/lib/zodBundle.js +39 -0
  263. package/lib/zodBundleImpl.js +40 -0
  264. package/package.json +6 -1
  265. package/types/protocol.d.ts +947 -51
  266. package/types/types.d.ts +854 -74
  267. package/lib/client/pageAgent.js +0 -64
  268. package/lib/mcpBundleImpl/index.js +0 -147
  269. package/lib/server/agent/actionRunner.js +0 -335
  270. package/lib/server/agent/actions.js +0 -128
  271. package/lib/server/agent/codegen.js +0 -111
  272. package/lib/server/agent/context.js +0 -150
  273. package/lib/server/agent/expectTools.js +0 -156
  274. package/lib/server/agent/pageAgent.js +0 -204
  275. package/lib/server/agent/performTools.js +0 -262
  276. package/lib/server/agent/tool.js +0 -109
  277. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  278. package/lib/server/pageBinding.js +0 -87
  279. package/lib/utils/isomorphic/oldUtilityScriptSerializers.js +0 -248
  280. package/lib/vite/recorder/assets/index-CVkBxsGf.js +0 -193
  281. package/lib/vite/traceViewer/assets/defaultSettingsView-CjfmcdOz.js +0 -266
  282. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  283. package/lib/vite/traceViewer/uiMode.fyrXARf2.js +0 -5
  284. /package/lib/{server/utils → utils/isomorphic}/imageUtils.js +0 -0
  285. /package/lib/utils/isomorphic/{traceUtils.js → trace/traceUtils.js} +0 -0
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var minimist_exports = {};
20
+ __export(minimist_exports, {
21
+ minimist: () => minimist
22
+ });
23
+ module.exports = __toCommonJS(minimist_exports);
24
+ function minimist(args, opts) {
25
+ if (!opts)
26
+ opts = {};
27
+ const bools = {};
28
+ const strings = {};
29
+ for (const key of toArray(opts.boolean))
30
+ bools[key] = true;
31
+ for (const key of toArray(opts.string))
32
+ strings[key] = true;
33
+ const argv = { _: [] };
34
+ function setArg(key, val) {
35
+ if (argv[key] === void 0 || bools[key] || typeof argv[key] === "boolean")
36
+ argv[key] = val;
37
+ else if (Array.isArray(argv[key]))
38
+ argv[key].push(val);
39
+ else
40
+ argv[key] = [argv[key], val];
41
+ }
42
+ let notFlags = [];
43
+ const doubleDashIndex = args.indexOf("--");
44
+ if (doubleDashIndex !== -1) {
45
+ notFlags = args.slice(doubleDashIndex + 1);
46
+ args = args.slice(0, doubleDashIndex);
47
+ }
48
+ for (let i = 0; i < args.length; i++) {
49
+ const arg = args[i];
50
+ let key;
51
+ let next;
52
+ if (/^--.+=/.test(arg)) {
53
+ const m = arg.match(/^--([^=]+)=([\s\S]*)$/);
54
+ key = m[1];
55
+ if (bools[key])
56
+ throw new Error(`boolean option '--${key}' should not be passed with '=value', use '--${key}' or '--no-${key}' instead`);
57
+ setArg(key, m[2]);
58
+ } else if (/^--no-.+/.test(arg)) {
59
+ key = arg.match(/^--no-(.+)/)[1];
60
+ setArg(key, false);
61
+ } else if (/^--.+/.test(arg)) {
62
+ key = arg.match(/^--(.+)/)[1];
63
+ next = args[i + 1];
64
+ if (next !== void 0 && !/^(-|--)[^-]/.test(next) && !bools[key]) {
65
+ setArg(key, next);
66
+ i += 1;
67
+ } else if (/^(true|false)$/.test(next)) {
68
+ setArg(key, next === "true");
69
+ i += 1;
70
+ } else {
71
+ setArg(key, strings[key] ? "" : true);
72
+ }
73
+ } else if (/^-[^-]+/.test(arg)) {
74
+ const letters = arg.slice(1, -1).split("");
75
+ let broken = false;
76
+ for (let j = 0; j < letters.length; j++) {
77
+ next = arg.slice(j + 2);
78
+ if (next === "-") {
79
+ setArg(letters[j], next);
80
+ continue;
81
+ }
82
+ if (/[A-Za-z]/.test(letters[j]) && next[0] === "=") {
83
+ setArg(letters[j], next.slice(1));
84
+ broken = true;
85
+ break;
86
+ }
87
+ if (/[A-Za-z]/.test(letters[j]) && /-?\d+(\.\d*)?(e-?\d+)?$/.test(next)) {
88
+ setArg(letters[j], next);
89
+ broken = true;
90
+ break;
91
+ }
92
+ if (letters[j + 1] && letters[j + 1].match(/\W/)) {
93
+ setArg(letters[j], arg.slice(j + 2));
94
+ broken = true;
95
+ break;
96
+ } else {
97
+ setArg(letters[j], strings[letters[j]] ? "" : true);
98
+ }
99
+ }
100
+ key = arg.slice(-1)[0];
101
+ if (!broken && key !== "-") {
102
+ if (args[i + 1] && !/^(-|--)[^-]/.test(args[i + 1]) && !bools[key]) {
103
+ setArg(key, args[i + 1]);
104
+ i += 1;
105
+ } else if (args[i + 1] && /^(true|false)$/.test(args[i + 1])) {
106
+ setArg(key, args[i + 1] === "true");
107
+ i += 1;
108
+ } else {
109
+ setArg(key, strings[key] ? "" : true);
110
+ }
111
+ }
112
+ } else {
113
+ argv._.push(arg);
114
+ }
115
+ }
116
+ for (const k of notFlags)
117
+ argv._.push(k);
118
+ return argv;
119
+ }
120
+ function toArray(value) {
121
+ if (!value)
122
+ return [];
123
+ return Array.isArray(value) ? value : [value];
124
+ }
125
+ // Annotate the CommonJS export names for ESM import in node:
126
+ 0 && (module.exports = {
127
+ minimist
128
+ });
@@ -0,0 +1,350 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var program_exports = {};
30
+ __export(program_exports, {
31
+ calculateSha1: () => calculateSha1,
32
+ program: () => program
33
+ });
34
+ module.exports = __toCommonJS(program_exports);
35
+ var import_child_process = require("child_process");
36
+ var import_crypto = __toESM(require("crypto"));
37
+ var import_os = __toESM(require("os"));
38
+ var import_path = __toESM(require("path"));
39
+ var import_registry = require("./registry");
40
+ var import_session = require("./session");
41
+ var import_serverRegistry = require("../../serverRegistry");
42
+ var import_minimist = require("./minimist");
43
+ const globalOptions = [
44
+ "endpoint",
45
+ "browser",
46
+ "config",
47
+ "extension",
48
+ "headed",
49
+ "help",
50
+ "persistent",
51
+ "profile",
52
+ "session",
53
+ "version"
54
+ ];
55
+ const booleanOptions = [
56
+ "all",
57
+ "help",
58
+ "version"
59
+ ];
60
+ async function program(options) {
61
+ const clientInfo = (0, import_registry.createClientInfo)();
62
+ const help = require("./help.json");
63
+ const argv = process.argv.slice(2);
64
+ const boolean = [...help.booleanOptions, ...booleanOptions];
65
+ const args = (0, import_minimist.minimist)(argv, { boolean, string: ["_"] });
66
+ if (args.s) {
67
+ args.session = args.s;
68
+ delete args.s;
69
+ }
70
+ const commandName = args._?.[0];
71
+ if (args.version || args.v) {
72
+ console.log(options?.embedderVersion ?? clientInfo.version);
73
+ process.exit(0);
74
+ }
75
+ const command = commandName && help.commands[commandName];
76
+ if (args.help || args.h) {
77
+ if (command) {
78
+ console.log(command.help);
79
+ } else {
80
+ console.log("playwright-cli - run playwright mcp commands from terminal\n");
81
+ console.log(help.global);
82
+ }
83
+ process.exit(0);
84
+ }
85
+ if (!command) {
86
+ console.error(`Unknown command: ${commandName}
87
+ `);
88
+ console.log(help.global);
89
+ process.exit(1);
90
+ }
91
+ validateFlags(args, command);
92
+ const registry = await import_registry.Registry.load();
93
+ const sessionName = (0, import_registry.resolveSessionName)(args.session);
94
+ switch (commandName) {
95
+ case "list": {
96
+ await listSessions(registry, clientInfo, !!args.all);
97
+ return;
98
+ }
99
+ case "close-all": {
100
+ const entries = registry.entries(clientInfo);
101
+ for (const entry of entries)
102
+ await new import_session.Session(entry).stop(true);
103
+ return;
104
+ }
105
+ case "delete-data": {
106
+ const entry = registry.entry(clientInfo, sessionName);
107
+ if (!entry) {
108
+ console.log(`No user data found for browser '${sessionName}'.`);
109
+ return;
110
+ }
111
+ await new import_session.Session(entry).deleteData();
112
+ return;
113
+ }
114
+ case "kill-all": {
115
+ await killAllDaemons();
116
+ return;
117
+ }
118
+ case "open": {
119
+ await startSession(sessionName, registry, clientInfo, args);
120
+ return;
121
+ }
122
+ case "attach": {
123
+ const attachTarget = args._[1];
124
+ const attachSessionName = (0, import_registry.explicitSessionName)(args.session) ?? attachTarget;
125
+ args.endpoint = attachTarget;
126
+ args.session = attachSessionName;
127
+ await startSession(attachSessionName, registry, clientInfo, args);
128
+ return;
129
+ }
130
+ case "close":
131
+ const closeEntry = registry.entry(clientInfo, sessionName);
132
+ const session = closeEntry ? new import_session.Session(closeEntry) : void 0;
133
+ if (!session || !await session.canConnect()) {
134
+ console.log(`Browser '${sessionName}' is not open.`);
135
+ return;
136
+ }
137
+ await session.stop();
138
+ return;
139
+ case "install":
140
+ await runInitWorkspace(args);
141
+ return;
142
+ case "install-browser":
143
+ await installBrowser();
144
+ return;
145
+ case "show": {
146
+ const daemonScript = require.resolve("../dashboard/dashboardApp.js");
147
+ const child = (0, import_child_process.spawn)(process.execPath, [daemonScript], {
148
+ detached: true,
149
+ stdio: "ignore"
150
+ });
151
+ child.unref();
152
+ return;
153
+ }
154
+ default: {
155
+ const entry = registry.entry(clientInfo, sessionName);
156
+ if (!entry) {
157
+ console.log(`The browser '${sessionName}' is not open, please run open first`);
158
+ console.log("");
159
+ console.log(` playwright-cli${sessionName !== "default" ? ` -s=${sessionName}` : ""} open [params]`);
160
+ process.exit(1);
161
+ }
162
+ await runInSession(entry, clientInfo, args);
163
+ }
164
+ }
165
+ }
166
+ async function startSession(sessionName, registry, clientInfo, args) {
167
+ const entry = registry.entry(clientInfo, sessionName);
168
+ if (entry)
169
+ await new import_session.Session(entry).stop(true);
170
+ await import_session.Session.startDaemon(clientInfo, args);
171
+ const newEntry = await registry.loadEntry(clientInfo, sessionName);
172
+ await runInSession(newEntry, clientInfo, args);
173
+ }
174
+ async function runInSession(entry, clientInfo, args) {
175
+ for (const globalOption of globalOptions)
176
+ delete args[globalOption];
177
+ const session = new import_session.Session(entry);
178
+ const result = await session.run(clientInfo, args);
179
+ console.log(result.text);
180
+ }
181
+ async function runInitWorkspace(args) {
182
+ const cliPath = require.resolve("../cli-daemon/program.js");
183
+ const daemonArgs = [cliPath, "--init-workspace", ...args.skills ? ["--init-skills", String(args.skills)] : []];
184
+ await new Promise((resolve, reject) => {
185
+ const child = (0, import_child_process.spawn)(process.execPath, daemonArgs, {
186
+ stdio: "inherit",
187
+ cwd: process.cwd()
188
+ });
189
+ child.on("close", (code) => {
190
+ if (code === 0)
191
+ resolve();
192
+ else
193
+ reject(new Error(`Workspace initialization failed with exit code ${code}`));
194
+ });
195
+ });
196
+ }
197
+ async function installBrowser() {
198
+ const { program: program2 } = require("../../cli/program");
199
+ const argv = process.argv.map((arg) => arg === "install-browser" ? "install" : arg);
200
+ program2.parse(argv);
201
+ }
202
+ async function killAllDaemons() {
203
+ const platform = import_os.default.platform();
204
+ let killed = 0;
205
+ try {
206
+ if (platform === "win32") {
207
+ const result = (0, import_child_process.execSync)(
208
+ `powershell -NoProfile -NonInteractive -Command "Get-CimInstance Win32_Process | Where-Object { $_.CommandLine -like '*run-mcp-server*' -or $_.CommandLine -like '*run-cli-server*' -or $_.CommandLine -like '*cli-daemon*' } | ForEach-Object { Stop-Process -Id $_.ProcessId -Force -ErrorAction SilentlyContinue; $_.ProcessId }"`,
209
+ { encoding: "utf-8" }
210
+ );
211
+ const pids = result.split("\n").map((line) => line.trim()).filter((line) => /^\d+$/.test(line));
212
+ for (const pid of pids)
213
+ console.log(`Killed daemon process ${pid}`);
214
+ killed = pids.length;
215
+ } else {
216
+ const result = (0, import_child_process.execSync)("ps aux", { encoding: "utf-8" });
217
+ const lines = result.split("\n");
218
+ for (const line of lines) {
219
+ if (line.includes("run-mcp-server") || line.includes("run-cli-server") || line.includes("cli-daemon")) {
220
+ const parts = line.trim().split(/\s+/);
221
+ const pid = parts[1];
222
+ if (pid && /^\d+$/.test(pid)) {
223
+ try {
224
+ process.kill(parseInt(pid, 10), "SIGKILL");
225
+ console.log(`Killed daemon process ${pid}`);
226
+ killed++;
227
+ } catch {
228
+ }
229
+ }
230
+ }
231
+ }
232
+ }
233
+ } catch (e) {
234
+ }
235
+ if (killed === 0)
236
+ console.log("No daemon processes found.");
237
+ else if (killed > 0)
238
+ console.log(`Killed ${killed} daemon process${killed === 1 ? "" : "es"}.`);
239
+ }
240
+ async function listSessions(registry, clientInfo, all) {
241
+ console.log("### Browsers");
242
+ let count = 0;
243
+ const runningSessions = /* @__PURE__ */ new Set();
244
+ const entries = registry.entryMap();
245
+ for (const [workspace, list] of entries) {
246
+ if (!all && workspace !== clientInfo.workspaceDir)
247
+ continue;
248
+ count += await gcAndPrintSessions(clientInfo, list.map((entry) => new import_session.Session(entry)), all ? `${import_path.default.relative(process.cwd(), workspace) || "/"}:` : void 0, runningSessions);
249
+ }
250
+ const serverEntries = await import_serverRegistry.serverRegistry.list();
251
+ const filteredServerEntries = /* @__PURE__ */ new Map();
252
+ for (const [workspace, list] of serverEntries) {
253
+ if (!all && workspace !== clientInfo.workspaceDir)
254
+ continue;
255
+ const unattached = list.filter((d) => !runningSessions.has(d.title));
256
+ if (unattached.length)
257
+ filteredServerEntries.set(workspace, unattached);
258
+ }
259
+ if (filteredServerEntries.size) {
260
+ if (count)
261
+ console.log("");
262
+ console.log("### Browser servers available for attach");
263
+ }
264
+ for (const [workspace, list] of filteredServerEntries)
265
+ count += await gcAndPrintBrowserSessions(workspace, list);
266
+ if (!count)
267
+ console.log(" (no browsers)");
268
+ }
269
+ async function gcAndPrintSessions(clientInfo, sessions, header, runningSessions) {
270
+ const running = [];
271
+ const stopped = [];
272
+ for (const session of sessions) {
273
+ const canConnect = await session.canConnect();
274
+ if (canConnect) {
275
+ running.push(session);
276
+ runningSessions?.add(session.name);
277
+ } else {
278
+ if (session.config.cli.persistent)
279
+ stopped.push(session);
280
+ else
281
+ await session.deleteSessionConfig();
282
+ }
283
+ }
284
+ if (header && (running.length || stopped.length))
285
+ console.log(header);
286
+ for (const session of running)
287
+ console.log(await renderSessionStatus(clientInfo, session));
288
+ for (const session of stopped)
289
+ console.log(await renderSessionStatus(clientInfo, session));
290
+ return running.length + stopped.length;
291
+ }
292
+ async function gcAndPrintBrowserSessions(workspace, list) {
293
+ if (!list.length)
294
+ return 0;
295
+ if (workspace)
296
+ console.log(`${import_path.default.relative(process.cwd(), workspace) || "/"}:`);
297
+ for (const descriptor of list) {
298
+ const text = [];
299
+ text.push(`- browser "${descriptor.title}":`);
300
+ text.push(` - browser: ${descriptor.browser.browserName}`);
301
+ text.push(` - version: v${descriptor.playwrightVersion}`);
302
+ text.push(` - status: ${descriptor.canConnect ? "open" : "closed"}`);
303
+ if (descriptor.browser.userDataDir)
304
+ text.push(` - data-dir: ${descriptor.browser.userDataDir}`);
305
+ else
306
+ text.push(` - data-dir: <in-memory>`);
307
+ text.push(` - run \`playwright-cli attach "${descriptor.title}"\` to attach`);
308
+ console.log(text.join("\n"));
309
+ }
310
+ return list.length;
311
+ }
312
+ async function renderSessionStatus(clientInfo, session) {
313
+ const text = [];
314
+ const config = session.config;
315
+ const canConnect = await session.canConnect();
316
+ text.push(`- ${session.name}:`);
317
+ text.push(` - status: ${canConnect ? "open" : "closed"}`);
318
+ if (canConnect && !session.isCompatible(clientInfo))
319
+ text.push(` - version: v${config.version} [incompatible please re-open]`);
320
+ if (config.browser)
321
+ text.push(...(0, import_session.renderResolvedConfig)(config));
322
+ return text.join("\n");
323
+ }
324
+ function validateFlags(args, command) {
325
+ const unknownFlags = [];
326
+ for (const key of Object.keys(args)) {
327
+ if (key === "_")
328
+ continue;
329
+ if (globalOptions.includes(key))
330
+ continue;
331
+ if (!(key in command.flags))
332
+ unknownFlags.push(key);
333
+ }
334
+ if (unknownFlags.length) {
335
+ console.error(`Unknown option${unknownFlags.length > 1 ? "s" : ""}: ${unknownFlags.map((f) => `--${f}`).join(", ")}`);
336
+ console.log("");
337
+ console.log(command.help);
338
+ process.exit(1);
339
+ }
340
+ }
341
+ function calculateSha1(buffer) {
342
+ const hash = import_crypto.default.createHash("sha1");
343
+ hash.update(buffer);
344
+ return hash.digest("hex");
345
+ }
346
+ // Annotate the CommonJS export names for ESM import in node:
347
+ 0 && (module.exports = {
348
+ calculateSha1,
349
+ program
350
+ });
@@ -0,0 +1,176 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var registry_exports = {};
30
+ __export(registry_exports, {
31
+ Registry: () => Registry,
32
+ baseDaemonDir: () => baseDaemonDir,
33
+ createClientInfo: () => createClientInfo,
34
+ explicitSessionName: () => explicitSessionName,
35
+ resolveSessionName: () => resolveSessionName
36
+ });
37
+ module.exports = __toCommonJS(registry_exports);
38
+ var import_crypto = __toESM(require("crypto"));
39
+ var import_fs = __toESM(require("fs"));
40
+ var import_os = __toESM(require("os"));
41
+ var import_path = __toESM(require("path"));
42
+ class Registry {
43
+ constructor(files) {
44
+ this._files = files;
45
+ }
46
+ entry(clientInfo, sessionName) {
47
+ const key = clientInfo.workspaceDir || clientInfo.workspaceDirHash;
48
+ const entries = this._files.get(key) || [];
49
+ return entries.find((entry) => entry.config.name === sessionName);
50
+ }
51
+ entries(clientInfo) {
52
+ const key = clientInfo.workspaceDir || clientInfo.workspaceDirHash;
53
+ return this._files.get(key) || [];
54
+ }
55
+ entryMap() {
56
+ return this._files;
57
+ }
58
+ async loadEntry(clientInfo, sessionName) {
59
+ const entry = await Registry._loadSessionEntry(clientInfo.daemonProfilesDir, sessionName + ".session");
60
+ if (!entry)
61
+ throw new Error(`Could not start the session "${sessionName}"`);
62
+ const key = clientInfo.workspaceDir || clientInfo.workspaceDirHash;
63
+ let list = this._files.get(key);
64
+ if (!list) {
65
+ list = [];
66
+ this._files.set(key, list);
67
+ }
68
+ const oldIndex = list.findIndex((e) => e.config.name === sessionName);
69
+ if (oldIndex !== -1)
70
+ list.splice(oldIndex, 1);
71
+ list.push(entry);
72
+ return entry;
73
+ }
74
+ static async _loadSessionEntry(daemonDir, file) {
75
+ try {
76
+ const fileName = import_path.default.join(daemonDir, file);
77
+ const data = await import_fs.default.promises.readFile(fileName, "utf-8");
78
+ const config = JSON.parse(data);
79
+ if (!config.name)
80
+ config.name = import_path.default.basename(file, ".session");
81
+ if (!config.timestamp)
82
+ config.timestamp = 0;
83
+ return { file: fileName, config, daemonDir };
84
+ } catch {
85
+ return void 0;
86
+ }
87
+ }
88
+ static async load() {
89
+ const sessions = /* @__PURE__ */ new Map();
90
+ const hashDirs = await import_fs.default.promises.readdir(baseDaemonDir).catch(() => []);
91
+ for (const workspaceDirHash of hashDirs) {
92
+ const daemonDir = import_path.default.join(baseDaemonDir, workspaceDirHash);
93
+ const stat = await import_fs.default.promises.stat(daemonDir);
94
+ if (!stat.isDirectory())
95
+ continue;
96
+ const files = await import_fs.default.promises.readdir(daemonDir).catch(() => []);
97
+ for (const file of files) {
98
+ if (!file.endsWith(".session"))
99
+ continue;
100
+ const entry = await Registry._loadSessionEntry(daemonDir, file);
101
+ if (!entry)
102
+ continue;
103
+ const key = entry.config.workspaceDir || workspaceDirHash;
104
+ let list = sessions.get(key);
105
+ if (!list) {
106
+ list = [];
107
+ sessions.set(key, list);
108
+ }
109
+ list.push(entry);
110
+ }
111
+ }
112
+ return new Registry(sessions);
113
+ }
114
+ }
115
+ const baseDaemonDir = (() => {
116
+ if (process.env.PLAYWRIGHT_DAEMON_SESSION_DIR)
117
+ return process.env.PLAYWRIGHT_DAEMON_SESSION_DIR;
118
+ let localCacheDir;
119
+ if (process.platform === "linux")
120
+ localCacheDir = process.env.XDG_CACHE_HOME || import_path.default.join(import_os.default.homedir(), ".cache");
121
+ if (process.platform === "darwin")
122
+ localCacheDir = import_path.default.join(import_os.default.homedir(), "Library", "Caches");
123
+ if (process.platform === "win32")
124
+ localCacheDir = process.env.LOCALAPPDATA || import_path.default.join(import_os.default.homedir(), "AppData", "Local");
125
+ if (!localCacheDir)
126
+ throw new Error("Unsupported platform: " + process.platform);
127
+ return import_path.default.join(localCacheDir, "ms-playwright", "daemon");
128
+ })();
129
+ function createClientInfo() {
130
+ const packageLocation = require.resolve("../../../package.json");
131
+ const packageJSON = require(packageLocation);
132
+ const workspaceDir = findWorkspaceDir(process.cwd());
133
+ const version = process.env.PLAYWRIGHT_CLI_VERSION_FOR_TEST || packageJSON.version;
134
+ const hash = import_crypto.default.createHash("sha1");
135
+ hash.update(workspaceDir || packageLocation);
136
+ const workspaceDirHash = hash.digest("hex").substring(0, 16);
137
+ return {
138
+ version,
139
+ workspaceDir,
140
+ workspaceDirHash,
141
+ daemonProfilesDir: daemonProfilesDir(workspaceDirHash)
142
+ };
143
+ }
144
+ function findWorkspaceDir(startDir) {
145
+ let dir = startDir;
146
+ for (let i = 0; i < 10; i++) {
147
+ if (import_fs.default.existsSync(import_path.default.join(dir, ".playwright")))
148
+ return dir;
149
+ const parentDir = import_path.default.dirname(dir);
150
+ if (parentDir === dir)
151
+ break;
152
+ dir = parentDir;
153
+ }
154
+ return void 0;
155
+ }
156
+ const daemonProfilesDir = (workspaceDirHash) => {
157
+ return import_path.default.join(baseDaemonDir, workspaceDirHash);
158
+ };
159
+ function explicitSessionName(sessionName) {
160
+ return sessionName || process.env.PLAYWRIGHT_CLI_SESSION;
161
+ }
162
+ function resolveSessionName(sessionName) {
163
+ if (sessionName)
164
+ return sessionName;
165
+ if (process.env.PLAYWRIGHT_CLI_SESSION)
166
+ return process.env.PLAYWRIGHT_CLI_SESSION;
167
+ return "default";
168
+ }
169
+ // Annotate the CommonJS export names for ESM import in node:
170
+ 0 && (module.exports = {
171
+ Registry,
172
+ baseDaemonDir,
173
+ createClientInfo,
174
+ explicitSessionName,
175
+ resolveSessionName
176
+ });