playwright-codegen-pro-core 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (468) hide show
  1. package/LICENSE +202 -0
  2. package/NOTICE +5 -0
  3. package/README.md +3 -0
  4. package/ThirdPartyNotices.txt +3552 -0
  5. package/bin/install_media_pack.ps1 +5 -0
  6. package/bin/install_webkit_wsl.ps1 +33 -0
  7. package/bin/reinstall_chrome_beta_linux.sh +42 -0
  8. package/bin/reinstall_chrome_beta_mac.sh +13 -0
  9. package/bin/reinstall_chrome_beta_win.ps1 +24 -0
  10. package/bin/reinstall_chrome_stable_linux.sh +42 -0
  11. package/bin/reinstall_chrome_stable_mac.sh +12 -0
  12. package/bin/reinstall_chrome_stable_win.ps1 +24 -0
  13. package/bin/reinstall_msedge_beta_linux.sh +48 -0
  14. package/bin/reinstall_msedge_beta_mac.sh +11 -0
  15. package/bin/reinstall_msedge_beta_win.ps1 +23 -0
  16. package/bin/reinstall_msedge_dev_linux.sh +48 -0
  17. package/bin/reinstall_msedge_dev_mac.sh +11 -0
  18. package/bin/reinstall_msedge_dev_win.ps1 +23 -0
  19. package/bin/reinstall_msedge_stable_linux.sh +48 -0
  20. package/bin/reinstall_msedge_stable_mac.sh +11 -0
  21. package/bin/reinstall_msedge_stable_win.ps1 +24 -0
  22. package/browsers.json +81 -0
  23. package/bundles/mcp/package-lock.json +1135 -0
  24. package/bundles/mcp/package.json +10 -0
  25. package/bundles/mcp/raw-body.ts +43 -0
  26. package/bundles/utils/package-lock.json +466 -0
  27. package/bundles/utils/package.json +40 -0
  28. package/bundles/zip/package-lock.json +257 -0
  29. package/bundles/zip/package.json +16 -0
  30. package/cli.js +18 -0
  31. package/index.d.ts +17 -0
  32. package/index.js +32 -0
  33. package/index.mjs +28 -0
  34. package/lib/androidServerImpl.js +65 -0
  35. package/lib/browserServerImpl.js +120 -0
  36. package/lib/cli/driver.js +98 -0
  37. package/lib/cli/program.js +599 -0
  38. package/lib/cli/programWithTestStub.js +74 -0
  39. package/lib/client/android.js +361 -0
  40. package/lib/client/api.js +137 -0
  41. package/lib/client/artifact.js +79 -0
  42. package/lib/client/browser.js +169 -0
  43. package/lib/client/browserContext.js +563 -0
  44. package/lib/client/browserType.js +153 -0
  45. package/lib/client/cdpSession.js +55 -0
  46. package/lib/client/channelOwner.js +194 -0
  47. package/lib/client/clientHelper.js +64 -0
  48. package/lib/client/clientInstrumentation.js +55 -0
  49. package/lib/client/clientStackTrace.js +69 -0
  50. package/lib/client/clock.js +68 -0
  51. package/lib/client/connect.js +143 -0
  52. package/lib/client/connection.js +322 -0
  53. package/lib/client/consoleMessage.js +61 -0
  54. package/lib/client/coverage.js +44 -0
  55. package/lib/client/debugger.js +57 -0
  56. package/lib/client/dialog.js +56 -0
  57. package/lib/client/disposable.js +76 -0
  58. package/lib/client/download.js +62 -0
  59. package/lib/client/electron.js +138 -0
  60. package/lib/client/elementHandle.js +281 -0
  61. package/lib/client/errors.js +77 -0
  62. package/lib/client/eventEmitter.js +314 -0
  63. package/lib/client/events.js +103 -0
  64. package/lib/client/fetch.js +367 -0
  65. package/lib/client/fileChooser.js +46 -0
  66. package/lib/client/fileUtils.js +34 -0
  67. package/lib/client/frame.js +404 -0
  68. package/lib/client/harRouter.js +99 -0
  69. package/lib/client/input.js +84 -0
  70. package/lib/client/jsHandle.js +105 -0
  71. package/lib/client/jsonPipe.js +39 -0
  72. package/lib/client/localUtils.js +60 -0
  73. package/lib/client/locator.js +367 -0
  74. package/lib/client/network.js +750 -0
  75. package/lib/client/page.js +729 -0
  76. package/lib/client/platform.js +77 -0
  77. package/lib/client/playwright.js +71 -0
  78. package/lib/client/screencast.js +48 -0
  79. package/lib/client/selectors.js +57 -0
  80. package/lib/client/stream.js +39 -0
  81. package/lib/client/timeoutSettings.js +79 -0
  82. package/lib/client/tracing.js +126 -0
  83. package/lib/client/types.js +28 -0
  84. package/lib/client/video.js +68 -0
  85. package/lib/client/waiter.js +142 -0
  86. package/lib/client/webError.js +39 -0
  87. package/lib/client/worker.js +85 -0
  88. package/lib/client/writableStream.js +39 -0
  89. package/lib/generated/bindingsControllerSource.js +28 -0
  90. package/lib/generated/clockSource.js +28 -0
  91. package/lib/generated/injectedScriptSource.js +28 -0
  92. package/lib/generated/pollingRecorderSource.js +28 -0
  93. package/lib/generated/storageScriptSource.js +28 -0
  94. package/lib/generated/utilityScriptSource.js +28 -0
  95. package/lib/generated/webSocketMockSource.js +336 -0
  96. package/lib/inProcessFactory.js +60 -0
  97. package/lib/inprocess.js +3 -0
  98. package/lib/mcpBundle.js +81 -0
  99. package/lib/mcpBundleImpl/index.js +91 -0
  100. package/lib/outofprocess.js +76 -0
  101. package/lib/protocol/serializers.js +197 -0
  102. package/lib/protocol/validator.js +3035 -0
  103. package/lib/protocol/validatorPrimitives.js +193 -0
  104. package/lib/remote/playwrightConnection.js +131 -0
  105. package/lib/remote/playwrightPipeServer.js +100 -0
  106. package/lib/remote/playwrightServer.js +339 -0
  107. package/lib/remote/playwrightWebSocketServer.js +73 -0
  108. package/lib/remote/serverTransport.js +96 -0
  109. package/lib/server/android/android.js +465 -0
  110. package/lib/server/android/backendAdb.js +177 -0
  111. package/lib/server/artifact.js +127 -0
  112. package/lib/server/bidi/bidiBrowser.js +571 -0
  113. package/lib/server/bidi/bidiChromium.js +162 -0
  114. package/lib/server/bidi/bidiConnection.js +213 -0
  115. package/lib/server/bidi/bidiDeserializer.js +116 -0
  116. package/lib/server/bidi/bidiExecutionContext.js +267 -0
  117. package/lib/server/bidi/bidiFirefox.js +128 -0
  118. package/lib/server/bidi/bidiInput.js +146 -0
  119. package/lib/server/bidi/bidiNetworkManager.js +411 -0
  120. package/lib/server/bidi/bidiOverCdp.js +102 -0
  121. package/lib/server/bidi/bidiPage.js +599 -0
  122. package/lib/server/bidi/bidiPdf.js +106 -0
  123. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
  124. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
  125. package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
  126. package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -0
  127. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
  128. package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
  129. package/lib/server/bidi/third_party/firefoxPrefs.js +261 -0
  130. package/lib/server/browser.js +223 -0
  131. package/lib/server/browserContext.js +703 -0
  132. package/lib/server/browserType.js +338 -0
  133. package/lib/server/callLog.js +82 -0
  134. package/lib/server/chromium/appIcon.png +0 -0
  135. package/lib/server/chromium/chromium.js +399 -0
  136. package/lib/server/chromium/chromiumSwitches.js +104 -0
  137. package/lib/server/chromium/crBrowser.js +532 -0
  138. package/lib/server/chromium/crConnection.js +197 -0
  139. package/lib/server/chromium/crCoverage.js +235 -0
  140. package/lib/server/chromium/crDevTools.js +111 -0
  141. package/lib/server/chromium/crDragDrop.js +131 -0
  142. package/lib/server/chromium/crExecutionContext.js +146 -0
  143. package/lib/server/chromium/crInput.js +187 -0
  144. package/lib/server/chromium/crNetworkManager.js +711 -0
  145. package/lib/server/chromium/crPage.js +1004 -0
  146. package/lib/server/chromium/crPdf.js +121 -0
  147. package/lib/server/chromium/crProtocolHelper.js +145 -0
  148. package/lib/server/chromium/crServiceWorker.js +137 -0
  149. package/lib/server/chromium/defaultFontFamilies.js +162 -0
  150. package/lib/server/chromium/protocol.d.js +16 -0
  151. package/lib/server/clock.js +149 -0
  152. package/lib/server/codegen/csharp.js +327 -0
  153. package/lib/server/codegen/java.js +274 -0
  154. package/lib/server/codegen/javascript.js +247 -0
  155. package/lib/server/codegen/jsonl.js +52 -0
  156. package/lib/server/codegen/language.js +132 -0
  157. package/lib/server/codegen/languages.js +68 -0
  158. package/lib/server/codegen/python.js +279 -0
  159. package/lib/server/codegen/types.js +16 -0
  160. package/lib/server/console.js +61 -0
  161. package/lib/server/cookieStore.js +206 -0
  162. package/lib/server/debugController.js +197 -0
  163. package/lib/server/debugger.js +117 -0
  164. package/lib/server/deviceDescriptors.js +39 -0
  165. package/lib/server/deviceDescriptorsSource.json +1779 -0
  166. package/lib/server/dialog.js +116 -0
  167. package/lib/server/dispatchers/androidDispatcher.js +325 -0
  168. package/lib/server/dispatchers/artifactDispatcher.js +118 -0
  169. package/lib/server/dispatchers/browserContextDispatcher.js +381 -0
  170. package/lib/server/dispatchers/browserDispatcher.js +124 -0
  171. package/lib/server/dispatchers/browserTypeDispatcher.js +71 -0
  172. package/lib/server/dispatchers/cdpSessionDispatcher.js +47 -0
  173. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
  174. package/lib/server/dispatchers/debuggerDispatcher.js +80 -0
  175. package/lib/server/dispatchers/dialogDispatcher.js +47 -0
  176. package/lib/server/dispatchers/dispatcher.js +364 -0
  177. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  178. package/lib/server/dispatchers/electronDispatcher.js +90 -0
  179. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
  180. package/lib/server/dispatchers/frameDispatcher.js +227 -0
  181. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
  182. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
  183. package/lib/server/dispatchers/localUtilsDispatcher.js +185 -0
  184. package/lib/server/dispatchers/networkDispatchers.js +214 -0
  185. package/lib/server/dispatchers/pageDispatcher.js +430 -0
  186. package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
  187. package/lib/server/dispatchers/streamDispatcher.js +67 -0
  188. package/lib/server/dispatchers/tracingDispatcher.js +68 -0
  189. package/lib/server/dispatchers/webSocketRouteDispatcher.js +164 -0
  190. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
  191. package/lib/server/disposable.js +41 -0
  192. package/lib/server/dom.js +833 -0
  193. package/lib/server/download.js +71 -0
  194. package/lib/server/electron/electron.js +272 -0
  195. package/lib/server/electron/loader.js +29 -0
  196. package/lib/server/errors.js +69 -0
  197. package/lib/server/fetch.js +621 -0
  198. package/lib/server/fileChooser.js +43 -0
  199. package/lib/server/fileUploadUtils.js +84 -0
  200. package/lib/server/firefox/ffBrowser.js +415 -0
  201. package/lib/server/firefox/ffConnection.js +142 -0
  202. package/lib/server/firefox/ffExecutionContext.js +150 -0
  203. package/lib/server/firefox/ffInput.js +175 -0
  204. package/lib/server/firefox/ffNetworkManager.js +256 -0
  205. package/lib/server/firefox/ffPage.js +495 -0
  206. package/lib/server/firefox/firefox.js +114 -0
  207. package/lib/server/firefox/protocol.d.js +16 -0
  208. package/lib/server/formData.js +147 -0
  209. package/lib/server/frameSelectors.js +160 -0
  210. package/lib/server/frames.js +1495 -0
  211. package/lib/server/har/harRecorder.js +147 -0
  212. package/lib/server/har/harTracer.js +608 -0
  213. package/lib/server/harBackend.js +157 -0
  214. package/lib/server/helper.js +96 -0
  215. package/lib/server/index.js +58 -0
  216. package/lib/server/input.js +322 -0
  217. package/lib/server/instrumentation.js +72 -0
  218. package/lib/server/javascript.js +291 -0
  219. package/lib/server/launchApp.js +127 -0
  220. package/lib/server/localUtils.js +214 -0
  221. package/lib/server/macEditingCommands.js +143 -0
  222. package/lib/server/network.js +668 -0
  223. package/lib/server/page.js +884 -0
  224. package/lib/server/pipeTransport.js +89 -0
  225. package/lib/server/playwright.js +69 -0
  226. package/lib/server/progress.js +136 -0
  227. package/lib/server/protocolError.js +52 -0
  228. package/lib/server/recorder/chat.js +161 -0
  229. package/lib/server/recorder/networkCapture.js +282 -0
  230. package/lib/server/recorder/recorderApp.js +581 -0
  231. package/lib/server/recorder/recorderRunner.js +138 -0
  232. package/lib/server/recorder/recorderSignalProcessor.js +83 -0
  233. package/lib/server/recorder/recorderUtils.js +157 -0
  234. package/lib/server/recorder/sessionExporter.js +40 -0
  235. package/lib/server/recorder/sessionPromptBuilder.js +128 -0
  236. package/lib/server/recorder/sessionRedactor.js +74 -0
  237. package/lib/server/recorder/throttledFile.js +57 -0
  238. package/lib/server/recorder.js +538 -0
  239. package/lib/server/registry/browserFetcher.js +177 -0
  240. package/lib/server/registry/dependencies.js +371 -0
  241. package/lib/server/registry/index.js +1395 -0
  242. package/lib/server/registry/nativeDeps.js +1281 -0
  243. package/lib/server/registry/oopDownloadBrowserMain.js +127 -0
  244. package/lib/server/screencast.js +238 -0
  245. package/lib/server/screenshotter.js +333 -0
  246. package/lib/server/selectors.js +112 -0
  247. package/lib/server/socksClientCertificatesInterceptor.js +383 -0
  248. package/lib/server/socksInterceptor.js +95 -0
  249. package/lib/server/trace/recorder/snapshotter.js +147 -0
  250. package/lib/server/trace/recorder/snapshotterInjected.js +561 -0
  251. package/lib/server/trace/recorder/tracing.js +615 -0
  252. package/lib/server/trace/viewer/traceViewer.js +244 -0
  253. package/lib/server/transport.js +181 -0
  254. package/lib/server/types.js +28 -0
  255. package/lib/server/usKeyboardLayout.js +152 -0
  256. package/lib/server/utils/ascii.js +44 -0
  257. package/lib/server/utils/comparators.js +139 -0
  258. package/lib/server/utils/crypto.js +216 -0
  259. package/lib/server/utils/debug.js +42 -0
  260. package/lib/server/utils/debugLogger.js +122 -0
  261. package/lib/server/utils/disposable.js +32 -0
  262. package/lib/server/utils/env.js +73 -0
  263. package/lib/server/utils/eventsHelper.js +41 -0
  264. package/lib/server/utils/expectUtils.js +123 -0
  265. package/lib/server/utils/fileUtils.js +191 -0
  266. package/lib/server/utils/happyEyeballs.js +207 -0
  267. package/lib/server/utils/hostPlatform.js +123 -0
  268. package/lib/server/utils/httpServer.js +205 -0
  269. package/lib/server/utils/image_tools/colorUtils.js +89 -0
  270. package/lib/server/utils/image_tools/compare.js +109 -0
  271. package/lib/server/utils/image_tools/imageChannel.js +78 -0
  272. package/lib/server/utils/image_tools/stats.js +102 -0
  273. package/lib/server/utils/linuxUtils.js +71 -0
  274. package/lib/server/utils/network.js +243 -0
  275. package/lib/server/utils/nodePlatform.js +154 -0
  276. package/lib/server/utils/pipeTransport.js +84 -0
  277. package/lib/server/utils/processLauncher.js +243 -0
  278. package/lib/server/utils/profiler.js +65 -0
  279. package/lib/server/utils/socksProxy.js +511 -0
  280. package/lib/server/utils/spawnAsync.js +41 -0
  281. package/lib/server/utils/task.js +51 -0
  282. package/lib/server/utils/userAgent.js +98 -0
  283. package/lib/server/utils/wsServer.js +121 -0
  284. package/lib/server/utils/zipFile.js +74 -0
  285. package/lib/server/utils/zones.js +57 -0
  286. package/lib/server/videoRecorder.js +133 -0
  287. package/lib/server/webkit/protocol.d.js +16 -0
  288. package/lib/server/webkit/webkit.js +108 -0
  289. package/lib/server/webkit/wkBrowser.js +331 -0
  290. package/lib/server/webkit/wkConnection.js +144 -0
  291. package/lib/server/webkit/wkExecutionContext.js +154 -0
  292. package/lib/server/webkit/wkInput.js +181 -0
  293. package/lib/server/webkit/wkInterceptableRequest.js +197 -0
  294. package/lib/server/webkit/wkPage.js +1164 -0
  295. package/lib/server/webkit/wkProvisionalPage.js +83 -0
  296. package/lib/server/webkit/wkWorkers.js +106 -0
  297. package/lib/serverRegistry.js +147 -0
  298. package/lib/third_party/pixelmatch.js +255 -0
  299. package/lib/tools/backend/browserBackend.js +79 -0
  300. package/lib/tools/backend/common.js +63 -0
  301. package/lib/tools/backend/config.js +41 -0
  302. package/lib/tools/backend/console.js +66 -0
  303. package/lib/tools/backend/context.js +290 -0
  304. package/lib/tools/backend/cookies.js +152 -0
  305. package/lib/tools/backend/devtools.js +69 -0
  306. package/lib/tools/backend/dialogs.js +59 -0
  307. package/lib/tools/backend/evaluate.js +64 -0
  308. package/lib/tools/backend/files.js +60 -0
  309. package/lib/tools/backend/form.js +64 -0
  310. package/lib/tools/backend/keyboard.js +155 -0
  311. package/lib/tools/backend/logFile.js +95 -0
  312. package/lib/tools/backend/mouse.js +168 -0
  313. package/lib/tools/backend/navigate.js +106 -0
  314. package/lib/tools/backend/network.js +135 -0
  315. package/lib/tools/backend/pdf.js +48 -0
  316. package/lib/tools/backend/recorder.js +74 -0
  317. package/lib/tools/backend/response.js +302 -0
  318. package/lib/tools/backend/route.js +140 -0
  319. package/lib/tools/backend/runCode.js +76 -0
  320. package/lib/tools/backend/screenshot.js +88 -0
  321. package/lib/tools/backend/sessionLog.js +74 -0
  322. package/lib/tools/backend/snapshot.js +208 -0
  323. package/lib/tools/backend/storage.js +67 -0
  324. package/lib/tools/backend/tab.js +445 -0
  325. package/lib/tools/backend/tabs.js +67 -0
  326. package/lib/tools/backend/tool.js +47 -0
  327. package/lib/tools/backend/tools.js +104 -0
  328. package/lib/tools/backend/tracing.js +75 -0
  329. package/lib/tools/backend/utils.js +83 -0
  330. package/lib/tools/backend/verify.js +151 -0
  331. package/lib/tools/backend/video.js +89 -0
  332. package/lib/tools/backend/wait.js +63 -0
  333. package/lib/tools/backend/webstorage.js +223 -0
  334. package/lib/tools/cli-client/cli.js +6 -0
  335. package/lib/tools/cli-client/help.json +101 -0
  336. package/lib/tools/cli-client/minimist.js +128 -0
  337. package/lib/tools/cli-client/program.js +382 -0
  338. package/lib/tools/cli-client/registry.js +176 -0
  339. package/lib/tools/cli-client/session.js +289 -0
  340. package/lib/tools/cli-client/skill/SKILL.md +326 -0
  341. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  342. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  343. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  344. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  345. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  346. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  347. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  348. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  349. package/lib/tools/cli-client/skill/references/video-recording.md +46 -0
  350. package/lib/tools/cli-daemon/command.js +73 -0
  351. package/lib/tools/cli-daemon/commands.js +933 -0
  352. package/lib/tools/cli-daemon/daemon.js +178 -0
  353. package/lib/tools/cli-daemon/helpGenerator.js +173 -0
  354. package/lib/tools/cli-daemon/program.js +118 -0
  355. package/lib/tools/dashboard/appIcon.png +0 -0
  356. package/lib/tools/dashboard/dashboardApp.js +286 -0
  357. package/lib/tools/dashboard/dashboardController.js +296 -0
  358. package/lib/tools/exports.js +60 -0
  359. package/lib/tools/mcp/browserFactory.js +233 -0
  360. package/lib/tools/mcp/cdpRelay.js +353 -0
  361. package/lib/tools/mcp/cli-stub.js +7 -0
  362. package/lib/tools/mcp/config.d.js +16 -0
  363. package/lib/tools/mcp/config.js +401 -0
  364. package/lib/tools/mcp/configIni.js +189 -0
  365. package/lib/tools/mcp/extensionContextFactory.js +59 -0
  366. package/lib/tools/mcp/index.js +62 -0
  367. package/lib/tools/mcp/log.js +35 -0
  368. package/lib/tools/mcp/program.js +107 -0
  369. package/lib/tools/mcp/protocol.js +28 -0
  370. package/lib/tools/mcp/watchdog.js +44 -0
  371. package/lib/tools/trace/SKILL.md +163 -0
  372. package/lib/tools/trace/installSkill.js +48 -0
  373. package/lib/tools/trace/traceActions.js +142 -0
  374. package/lib/tools/trace/traceAttachments.js +69 -0
  375. package/lib/tools/trace/traceCli.js +80 -0
  376. package/lib/tools/trace/traceConsole.js +97 -0
  377. package/lib/tools/trace/traceErrors.js +55 -0
  378. package/lib/tools/trace/traceOpen.js +69 -0
  379. package/lib/tools/trace/traceParser.js +96 -0
  380. package/lib/tools/trace/traceRequests.js +158 -0
  381. package/lib/tools/trace/traceScreenshot.js +68 -0
  382. package/lib/tools/trace/traceSnapshot.js +149 -0
  383. package/lib/tools/trace/traceUtils.js +135 -0
  384. package/lib/tools/utils/connect.js +32 -0
  385. package/lib/tools/utils/mcp/http.js +152 -0
  386. package/lib/tools/utils/mcp/server.js +230 -0
  387. package/lib/tools/utils/mcp/tool.js +47 -0
  388. package/lib/tools/utils/socketConnection.js +108 -0
  389. package/lib/utils/isomorphic/ariaSnapshot.js +455 -0
  390. package/lib/utils/isomorphic/assert.js +31 -0
  391. package/lib/utils/isomorphic/colors.js +72 -0
  392. package/lib/utils/isomorphic/cssParser.js +245 -0
  393. package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
  394. package/lib/utils/isomorphic/formatUtils.js +64 -0
  395. package/lib/utils/isomorphic/headers.js +53 -0
  396. package/lib/utils/isomorphic/imageUtils.js +141 -0
  397. package/lib/utils/isomorphic/locatorGenerators.js +689 -0
  398. package/lib/utils/isomorphic/locatorParser.js +176 -0
  399. package/lib/utils/isomorphic/locatorUtils.js +81 -0
  400. package/lib/utils/isomorphic/lruCache.js +51 -0
  401. package/lib/utils/isomorphic/manualPromise.js +114 -0
  402. package/lib/utils/isomorphic/mimeType.js +464 -0
  403. package/lib/utils/isomorphic/multimap.js +80 -0
  404. package/lib/utils/isomorphic/protocolFormatter.js +81 -0
  405. package/lib/utils/isomorphic/protocolMetainfo.js +347 -0
  406. package/lib/utils/isomorphic/rtti.js +43 -0
  407. package/lib/utils/isomorphic/selectorParser.js +386 -0
  408. package/lib/utils/isomorphic/semaphore.js +54 -0
  409. package/lib/utils/isomorphic/stackTrace.js +158 -0
  410. package/lib/utils/isomorphic/stringUtils.js +204 -0
  411. package/lib/utils/isomorphic/time.js +49 -0
  412. package/lib/utils/isomorphic/timeoutRunner.js +66 -0
  413. package/lib/utils/isomorphic/trace/entries.js +16 -0
  414. package/lib/utils/isomorphic/trace/snapshotRenderer.js +492 -0
  415. package/lib/utils/isomorphic/trace/snapshotServer.js +120 -0
  416. package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -0
  417. package/lib/utils/isomorphic/trace/traceLoader.js +131 -0
  418. package/lib/utils/isomorphic/trace/traceModel.js +366 -0
  419. package/lib/utils/isomorphic/trace/traceModernizer.js +401 -0
  420. package/lib/utils/isomorphic/trace/traceUtils.js +58 -0
  421. package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -0
  422. package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -0
  423. package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -0
  424. package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -0
  425. package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -0
  426. package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -0
  427. package/lib/utils/isomorphic/types.js +16 -0
  428. package/lib/utils/isomorphic/urlMatch.js +243 -0
  429. package/lib/utils/isomorphic/utilityScriptSerializers.js +262 -0
  430. package/lib/utils/isomorphic/yaml.js +84 -0
  431. package/lib/utils.js +113 -0
  432. package/lib/utilsBundle.js +91 -0
  433. package/lib/utilsBundleImpl/index.js +218 -0
  434. package/lib/utilsBundleImpl/xdg-open +1066 -0
  435. package/lib/vite/dashboard/assets/index-Bn2lDGZX.js +50 -0
  436. package/lib/vite/dashboard/assets/index-DDWrEWMc.css +1 -0
  437. package/lib/vite/dashboard/index.html +28 -0
  438. package/lib/vite/htmlReport/index.html +89 -0
  439. package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -0
  440. package/lib/vite/recorder/assets/codeMirrorModule-RoSmqW0t.js +32 -0
  441. package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  442. package/lib/vite/recorder/assets/index-CLrDthbi.js +193 -0
  443. package/lib/vite/recorder/assets/index-OFPIkgDs.css +1 -0
  444. package/lib/vite/recorder/index.html +29 -0
  445. package/lib/vite/recorder/playwright-logo.svg +9 -0
  446. package/lib/vite/traceViewer/assets/codeMirrorModule-Cigrr2OM.js +32 -0
  447. package/lib/vite/traceViewer/assets/defaultSettingsView-ConrJv9G.js +262 -0
  448. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
  449. package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -0
  450. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  451. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  452. package/lib/vite/traceViewer/index.CzXZzn5A.css +1 -0
  453. package/lib/vite/traceViewer/index.EVGp-u_4.js +2 -0
  454. package/lib/vite/traceViewer/index.html +43 -0
  455. package/lib/vite/traceViewer/manifest.webmanifest +16 -0
  456. package/lib/vite/traceViewer/playwright-logo.svg +9 -0
  457. package/lib/vite/traceViewer/snapshot.html +21 -0
  458. package/lib/vite/traceViewer/sw.bundle.js +5 -0
  459. package/lib/vite/traceViewer/uiMode.Bewj7-uD.js +6 -0
  460. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
  461. package/lib/vite/traceViewer/uiMode.html +17 -0
  462. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
  463. package/lib/zipBundle.js +34 -0
  464. package/lib/zipBundleImpl.js +5 -0
  465. package/package.json +46 -0
  466. package/types/protocol.d.ts +24365 -0
  467. package/types/structs.d.ts +45 -0
  468. package/types/types.d.ts +23498 -0
@@ -0,0 +1,1164 @@
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 wkPage_exports = {};
30
+ __export(wkPage_exports, {
31
+ WKPage: () => WKPage
32
+ });
33
+ module.exports = __toCommonJS(wkPage_exports);
34
+ var import_utils = require("../../utils");
35
+ var import_headers = require("../../utils/isomorphic/headers");
36
+ var import_eventsHelper = require("../utils/eventsHelper");
37
+ var import_hostPlatform = require("../utils/hostPlatform");
38
+ var import_stackTrace = require("../../utils/isomorphic/stackTrace");
39
+ var import_utilsBundle = require("../../utilsBundle");
40
+ var dialog = __toESM(require("../dialog"));
41
+ var dom = __toESM(require("../dom"));
42
+ var import_errors = require("../errors");
43
+ var import_helper = require("../helper");
44
+ var network = __toESM(require("../network"));
45
+ var import_page = require("../page");
46
+ var import_wkConnection = require("./wkConnection");
47
+ var import_wkExecutionContext = require("./wkExecutionContext");
48
+ var import_wkInput = require("./wkInput");
49
+ var import_wkInterceptableRequest = require("./wkInterceptableRequest");
50
+ var import_wkProvisionalPage = require("./wkProvisionalPage");
51
+ var import_wkWorkers = require("./wkWorkers");
52
+ var import_webkit = require("./webkit");
53
+ var import_registry = require("../registry");
54
+ const UTILITY_WORLD_NAME = "__playwright_utility_world__";
55
+ const enableFrameSessions = !process.env.WK_DISABLE_FRAME_SESSIONS && parseInt(import_registry.registry.findExecutable("webkit").revision, 10) >= 2245 && parseInt(import_registry.registry.findExecutable("webkit").revision, 10) <= 2255;
56
+ class WKPage {
57
+ constructor(browserContext, pageProxySession, opener) {
58
+ this._provisionalPage = null;
59
+ this._targetIdToFrameSession = /* @__PURE__ */ new Map();
60
+ this._requestIdToRequest = /* @__PURE__ */ new Map();
61
+ this._requestIdToRequestWillBeSentEvent = /* @__PURE__ */ new Map();
62
+ this._sessionListeners = [];
63
+ this._firstNonInitialNavigationCommittedFulfill = () => {
64
+ };
65
+ this._firstNonInitialNavigationCommittedReject = (e) => {
66
+ };
67
+ this._lastConsoleMessage = null;
68
+ this._requestIdToResponseReceivedPayloadEvent = /* @__PURE__ */ new Map();
69
+ this._screencastGeneration = 0;
70
+ this._pageProxySession = pageProxySession;
71
+ this._opener = opener;
72
+ this.rawKeyboard = new import_wkInput.RawKeyboardImpl(pageProxySession);
73
+ this.rawMouse = new import_wkInput.RawMouseImpl(pageProxySession);
74
+ this.rawTouchscreen = new import_wkInput.RawTouchscreenImpl(pageProxySession);
75
+ this._contextIdToContext = /* @__PURE__ */ new Map();
76
+ this._page = new import_page.Page(this, browserContext);
77
+ this.rawMouse.setPage(this._page);
78
+ this._workers = new import_wkWorkers.WKWorkers(this._page);
79
+ this._session = void 0;
80
+ this._browserContext = browserContext;
81
+ this._page.on(import_page.Page.Events.FrameDetached, (frame) => this._removeContextsForFrame(frame, false));
82
+ this._eventListeners = [
83
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Target.targetCreated", this._onTargetCreated.bind(this)),
84
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Target.targetDestroyed", this._onTargetDestroyed.bind(this)),
85
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Target.dispatchMessageFromTarget", this._onDispatchMessageFromTarget.bind(this)),
86
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Target.didCommitProvisionalTarget", this._onDidCommitProvisionalTarget.bind(this)),
87
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Screencast.screencastFrame", this._onScreencastFrame.bind(this))
88
+ ];
89
+ this._firstNonInitialNavigationCommittedPromise = new Promise((f, r) => {
90
+ this._firstNonInitialNavigationCommittedFulfill = f;
91
+ this._firstNonInitialNavigationCommittedReject = r;
92
+ });
93
+ this._firstNonInitialNavigationCommittedPromise.catch(() => {
94
+ });
95
+ if (opener && !browserContext._options.noDefaultViewport && opener._nextWindowOpenPopupFeatures) {
96
+ const viewportSize = import_helper.helper.getViewportSizeFromWindowFeatures(opener._nextWindowOpenPopupFeatures);
97
+ opener._nextWindowOpenPopupFeatures = void 0;
98
+ if (viewportSize)
99
+ this._page.setEmulatedSizeFromWindowOpen({ viewport: viewportSize, screen: viewportSize });
100
+ }
101
+ }
102
+ async _initializePageProxySession() {
103
+ if (this._page.isStorageStatePage)
104
+ return;
105
+ const promises = [
106
+ this._pageProxySession.send("Dialog.enable"),
107
+ this._pageProxySession.send("Emulation.setActiveAndFocused", { active: true })
108
+ ];
109
+ const contextOptions = this._browserContext._options;
110
+ if (contextOptions.javaScriptEnabled === false)
111
+ promises.push(this._pageProxySession.send("Emulation.setJavaScriptEnabled", { enabled: false }));
112
+ promises.push(this._updateViewport());
113
+ promises.push(this.updateHttpCredentials());
114
+ if (this._browserContext._permissions.size) {
115
+ for (const [key, value] of this._browserContext._permissions)
116
+ promises.push(this._grantPermissions(key, value));
117
+ }
118
+ promises.push(this._initializeVideoRecording());
119
+ await Promise.all(promises);
120
+ }
121
+ _setSession(session) {
122
+ import_eventsHelper.eventsHelper.removeEventListeners(this._sessionListeners);
123
+ this._session = session;
124
+ this.rawKeyboard.setSession(session);
125
+ this.rawMouse.setSession(session);
126
+ this._addSessionListeners();
127
+ this._workers.setSession(session);
128
+ }
129
+ // This method is called for provisional targets as well. The session passed as the parameter
130
+ // may be different from the current session and may be destroyed without becoming current.
131
+ async _initializeSession(session, provisional, resourceTreeHandler) {
132
+ await this._initializeSessionMayThrow(session, resourceTreeHandler).catch((e) => {
133
+ if (provisional && session.isDisposed())
134
+ return;
135
+ if (this._session === session)
136
+ throw e;
137
+ });
138
+ }
139
+ async _initializeSessionMayThrow(session, resourceTreeHandler) {
140
+ const [, frameTree] = await Promise.all([
141
+ // Page agent must be enabled before Runtime.
142
+ session.send("Page.enable"),
143
+ session.send("Page.getResourceTree")
144
+ ]);
145
+ resourceTreeHandler(frameTree);
146
+ const promises = [
147
+ // Resource tree should be received before first execution context.
148
+ session.send("Runtime.enable"),
149
+ session.send("Page.createUserWorld", { name: UTILITY_WORLD_NAME }).catch((_) => {
150
+ }),
151
+ // Worlds are per-process
152
+ session.send("Network.enable"),
153
+ this._workers.initializeSession(session)
154
+ ];
155
+ if (enableFrameSessions)
156
+ this._initializeFrameSessions(frameTree.frameTree, promises);
157
+ else
158
+ promises.push(session.send("Console.enable"));
159
+ if (this._page.browserContext.needsPlaywrightBinding())
160
+ promises.push(session.send("Runtime.addBinding", { name: import_page.PageBinding.kBindingName }));
161
+ if (this._page.needsRequestInterception()) {
162
+ promises.push(session.send("Network.setInterceptionEnabled", { enabled: true }));
163
+ promises.push(session.send("Network.setResourceCachingDisabled", { disabled: true }));
164
+ promises.push(session.send("Network.addInterception", { url: ".*", stage: "request", isRegex: true }));
165
+ }
166
+ if (this._page.isStorageStatePage) {
167
+ await Promise.all(promises);
168
+ return;
169
+ }
170
+ const contextOptions = this._browserContext._options;
171
+ if (contextOptions.userAgent)
172
+ promises.push(this.updateUserAgent());
173
+ const emulatedMedia = this._page.emulatedMedia();
174
+ if (emulatedMedia.media || emulatedMedia.colorScheme || emulatedMedia.reducedMotion || emulatedMedia.forcedColors || emulatedMedia.contrast)
175
+ promises.push(WKPage._setEmulateMedia(session, emulatedMedia.media, emulatedMedia.colorScheme, emulatedMedia.reducedMotion, emulatedMedia.forcedColors, emulatedMedia.contrast));
176
+ const bootstrapScript = this._calculateBootstrapScript();
177
+ if (bootstrapScript.length)
178
+ promises.push(session.send("Page.setBootstrapScript", { source: bootstrapScript }));
179
+ this._page.frames().map((frame) => frame.evaluateExpression(bootstrapScript).catch((e) => {
180
+ }));
181
+ if (contextOptions.bypassCSP)
182
+ promises.push(session.send("Page.setBypassCSP", { enabled: true }));
183
+ const emulatedSize = this._page.emulatedSize();
184
+ if (emulatedSize) {
185
+ promises.push(session.send("Page.setScreenSizeOverride", {
186
+ width: emulatedSize.screen.width,
187
+ height: emulatedSize.screen.height
188
+ }));
189
+ }
190
+ promises.push(this.updateEmulateMedia());
191
+ promises.push(session.send("Network.setExtraHTTPHeaders", { headers: (0, import_headers.headersArrayToObject)(
192
+ this._calculateExtraHTTPHeaders(),
193
+ false
194
+ /* lowerCase */
195
+ ) }));
196
+ if (contextOptions.offline)
197
+ promises.push(session.send("Network.setEmulateOfflineState", { offline: true }));
198
+ promises.push(session.send("Page.setTouchEmulationEnabled", { enabled: !!contextOptions.hasTouch }));
199
+ if (contextOptions.timezoneId) {
200
+ promises.push(session.send("Page.setTimeZone", { timeZone: contextOptions.timezoneId }).catch((e) => {
201
+ throw new Error(`Invalid timezone ID: ${contextOptions.timezoneId}`);
202
+ }));
203
+ }
204
+ if (this._page.fileChooserIntercepted())
205
+ promises.push(session.send("Page.setInterceptFileChooserDialog", { enabled: true }));
206
+ promises.push(session.send("Page.overrideSetting", { setting: "DeviceOrientationEventEnabled", value: contextOptions.isMobile }));
207
+ promises.push(session.send("Page.overrideSetting", { setting: "FullScreenEnabled", value: !contextOptions.isMobile }));
208
+ promises.push(session.send("Page.overrideSetting", { setting: "NotificationsEnabled", value: !contextOptions.isMobile }));
209
+ promises.push(session.send("Page.overrideSetting", { setting: "PointerLockEnabled", value: !contextOptions.isMobile }));
210
+ promises.push(session.send("Page.overrideSetting", { setting: "InputTypeMonthEnabled", value: contextOptions.isMobile }));
211
+ promises.push(session.send("Page.overrideSetting", { setting: "InputTypeWeekEnabled", value: contextOptions.isMobile }));
212
+ promises.push(session.send("Page.overrideSetting", { setting: "FixedBackgroundsPaintRelativeToDocument", value: contextOptions.isMobile }));
213
+ await Promise.all(promises);
214
+ }
215
+ _initializeFrameSessions(frame, promises) {
216
+ const session = this._targetIdToFrameSession.get(`frame-${frame.frame.id}`);
217
+ if (session)
218
+ promises.push(session.initialize());
219
+ for (const childFrame of frame.childFrames || [])
220
+ this._initializeFrameSessions(childFrame, promises);
221
+ }
222
+ _onDidCommitProvisionalTarget(event) {
223
+ const { oldTargetId, newTargetId } = event;
224
+ (0, import_utils.assert)(this._provisionalPage);
225
+ (0, import_utils.assert)(this._provisionalPage._session.sessionId === newTargetId, "Unknown new target: " + newTargetId);
226
+ (0, import_utils.assert)(this._session.sessionId === oldTargetId, "Unknown old target: " + oldTargetId);
227
+ const newSession = this._provisionalPage._session;
228
+ this._provisionalPage.commit();
229
+ this._provisionalPage.dispose();
230
+ this._provisionalPage = null;
231
+ this._setSession(newSession);
232
+ }
233
+ _onTargetDestroyed(event) {
234
+ const { targetId, crashed } = event;
235
+ if (this._provisionalPage && this._provisionalPage._session.sessionId === targetId) {
236
+ this._maybeCancelCoopNavigationRequest(this._provisionalPage);
237
+ this._provisionalPage._session.dispose();
238
+ this._provisionalPage.dispose();
239
+ this._provisionalPage = null;
240
+ } else if (this._session.sessionId === targetId) {
241
+ this._session.dispose();
242
+ import_eventsHelper.eventsHelper.removeEventListeners(this._sessionListeners);
243
+ if (crashed) {
244
+ this._session.markAsCrashed();
245
+ this._page._didCrash();
246
+ }
247
+ } else if (this._targetIdToFrameSession.has(targetId)) {
248
+ this._targetIdToFrameSession.get(targetId).dispose();
249
+ this._targetIdToFrameSession.delete(targetId);
250
+ }
251
+ }
252
+ didClose() {
253
+ this._pageProxySession.dispose();
254
+ import_eventsHelper.eventsHelper.removeEventListeners(this._sessionListeners);
255
+ import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
256
+ if (this._session)
257
+ this._session.dispose();
258
+ if (this._provisionalPage) {
259
+ this._provisionalPage._session.dispose();
260
+ this._provisionalPage.dispose();
261
+ this._provisionalPage = null;
262
+ }
263
+ this._firstNonInitialNavigationCommittedReject(new import_errors.TargetClosedError(this._page.closeReason()));
264
+ this._page._didClose();
265
+ }
266
+ dispatchMessageToSession(message) {
267
+ this._pageProxySession.dispatchMessage(message);
268
+ }
269
+ handleProvisionalLoadFailed(event) {
270
+ if (!this._page.initializedOrUndefined()) {
271
+ this._firstNonInitialNavigationCommittedReject(new Error("Initial load failed"));
272
+ return;
273
+ }
274
+ if (!this._provisionalPage)
275
+ return;
276
+ let errorText = event.error;
277
+ if (errorText.includes("cancelled"))
278
+ errorText += "; maybe frame was detached?";
279
+ this._page.frameManager.frameAbortedNavigation(this._page.mainFrame()._id, errorText, event.loaderId);
280
+ }
281
+ handleWindowOpen(event) {
282
+ this._nextWindowOpenPopupFeatures = event.windowFeatures;
283
+ }
284
+ async _onTargetCreated(event) {
285
+ const { targetInfo } = event;
286
+ const session = new import_wkConnection.WKSession(this._pageProxySession.connection, targetInfo.targetId, (message) => {
287
+ this._pageProxySession.send("Target.sendMessageToTarget", {
288
+ message: JSON.stringify(message),
289
+ targetId: targetInfo.targetId
290
+ }).catch((e) => {
291
+ session.dispatchMessage({ id: message.id, error: { message: e.message } });
292
+ });
293
+ });
294
+ if (targetInfo.type === "frame") {
295
+ if (enableFrameSessions) {
296
+ const wkFrame = new WKFrame(this, session);
297
+ this._targetIdToFrameSession.set(targetInfo.targetId, wkFrame);
298
+ await wkFrame.initialize().catch((e) => {
299
+ });
300
+ }
301
+ return;
302
+ }
303
+ (0, import_utils.assert)(targetInfo.type === "page", "Only page targets are expected in WebKit, received: " + targetInfo.type);
304
+ if (!targetInfo.isProvisional) {
305
+ (0, import_utils.assert)(!this._page.initializedOrUndefined());
306
+ let pageOrError;
307
+ try {
308
+ this._setSession(session);
309
+ await Promise.all([
310
+ this._initializePageProxySession(),
311
+ this._initializeSession(session, false, ({ frameTree }) => this._handleFrameTree(frameTree))
312
+ ]);
313
+ pageOrError = this._page;
314
+ } catch (e) {
315
+ pageOrError = e;
316
+ }
317
+ if (targetInfo.isPaused)
318
+ this._pageProxySession.sendMayFail("Target.resume", { targetId: targetInfo.targetId });
319
+ if (pageOrError instanceof import_page.Page && this._page.mainFrame().url() === "") {
320
+ try {
321
+ await this._firstNonInitialNavigationCommittedPromise;
322
+ } catch (e) {
323
+ pageOrError = e;
324
+ }
325
+ }
326
+ this._page.reportAsNew(this._opener?._page, pageOrError instanceof import_page.Page ? void 0 : pageOrError);
327
+ } else {
328
+ (0, import_utils.assert)(targetInfo.isProvisional);
329
+ (0, import_utils.assert)(!this._provisionalPage);
330
+ this._provisionalPage = new import_wkProvisionalPage.WKProvisionalPage(session, this);
331
+ if (targetInfo.isPaused) {
332
+ this._provisionalPage.initializationPromise.then(() => {
333
+ this._pageProxySession.sendMayFail("Target.resume", { targetId: targetInfo.targetId });
334
+ });
335
+ }
336
+ }
337
+ }
338
+ _onDispatchMessageFromTarget(event) {
339
+ const { targetId, message } = event;
340
+ if (this._provisionalPage && this._provisionalPage._session.sessionId === targetId)
341
+ this._provisionalPage._session.dispatchMessage(JSON.parse(message));
342
+ else if (this._session.sessionId === targetId)
343
+ this._session.dispatchMessage(JSON.parse(message));
344
+ else if (this._targetIdToFrameSession.has(targetId))
345
+ this._targetIdToFrameSession.get(targetId)._session.dispatchMessage(JSON.parse(message));
346
+ else
347
+ throw new Error("Unknown target: " + targetId);
348
+ }
349
+ _addSessionListeners() {
350
+ this._sessionListeners = [
351
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.frameNavigated", (event) => this._onFrameNavigated(event.frame, false)),
352
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.navigatedWithinDocument", (event) => this._onFrameNavigatedWithinDocument(event.frameId, event.url)),
353
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.frameAttached", (event) => this._onFrameAttached(event.frameId, event.parentFrameId)),
354
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.frameDetached", (event) => this._onFrameDetached(event.frameId)),
355
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.willCheckNavigationPolicy", (event) => this._onWillCheckNavigationPolicy(event.frameId)),
356
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.didCheckNavigationPolicy", (event) => this._onDidCheckNavigationPolicy(event.frameId, event.cancel)),
357
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.loadEventFired", (event) => this._page.frameManager.frameLifecycleEvent(event.frameId, "load")),
358
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.domContentEventFired", (event) => this._page.frameManager.frameLifecycleEvent(event.frameId, "domcontentloaded")),
359
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Runtime.executionContextCreated", (event) => this._onExecutionContextCreated(event.context)),
360
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Runtime.bindingCalled", (event) => this._onBindingCalled(event.contextId, event.argument)),
361
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Console.messageAdded", (event) => this._onConsoleMessage(event)),
362
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Console.messageRepeatCountUpdated", (event) => this._onConsoleRepeatCountUpdated(event)),
363
+ import_eventsHelper.eventsHelper.addEventListener(this._pageProxySession, "Dialog.javascriptDialogOpening", (event) => this._onDialog(event)),
364
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.fileChooserOpened", (event) => this._onFileChooserOpened(event)),
365
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.requestWillBeSent", (e) => this._onRequestWillBeSent(this._session, e)),
366
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.requestIntercepted", (e) => this._onRequestIntercepted(this._session, e)),
367
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.responseReceived", (e) => this._onResponseReceived(this._session, e)),
368
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.loadingFinished", (e) => this._onLoadingFinished(e)),
369
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.loadingFailed", (e) => this._onLoadingFailed(this._session, e)),
370
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketCreated", (e) => this._page.frameManager.onWebSocketCreated(e.requestId, e.url)),
371
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketWillSendHandshakeRequest", (e) => this._page.frameManager.onWebSocketRequest(e.requestId)),
372
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketHandshakeResponseReceived", (e) => this._page.frameManager.onWebSocketResponse(e.requestId, e.response.status, e.response.statusText)),
373
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketFrameSent", (e) => e.response.payloadData && this._page.frameManager.onWebSocketFrameSent(e.requestId, e.response.opcode, e.response.payloadData)),
374
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketFrameReceived", (e) => e.response.payloadData && this._page.frameManager.webSocketFrameReceived(e.requestId, e.response.opcode, e.response.payloadData)),
375
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketClosed", (e) => this._page.frameManager.webSocketClosed(e.requestId)),
376
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Network.webSocketFrameError", (e) => this._page.frameManager.webSocketError(e.requestId, e.errorMessage))
377
+ ];
378
+ }
379
+ async _updateState(method, params) {
380
+ await this._forAllSessions((session) => session.send(method, params).then());
381
+ }
382
+ async _forAllSessions(callback) {
383
+ const sessions = [
384
+ this._session
385
+ ];
386
+ if (this._provisionalPage)
387
+ sessions.push(this._provisionalPage._session);
388
+ await Promise.all(sessions.map((session) => callback(session).catch((e) => {
389
+ })));
390
+ }
391
+ _onWillCheckNavigationPolicy(frameId) {
392
+ if (this._provisionalPage)
393
+ return;
394
+ this._page.frameManager.frameRequestedNavigation(frameId);
395
+ }
396
+ _onDidCheckNavigationPolicy(frameId, cancel) {
397
+ if (!cancel)
398
+ return;
399
+ if (this._provisionalPage)
400
+ return;
401
+ this._page.frameManager.frameAbortedNavigation(frameId, "Navigation canceled by policy check");
402
+ }
403
+ _handleFrameTree(frameTree) {
404
+ this._onFrameAttached(frameTree.frame.id, frameTree.frame.parentId || null);
405
+ this._onFrameNavigated(frameTree.frame, true);
406
+ this._page.frameManager.frameLifecycleEvent(frameTree.frame.id, "domcontentloaded");
407
+ this._page.frameManager.frameLifecycleEvent(frameTree.frame.id, "load");
408
+ if (!frameTree.childFrames)
409
+ return;
410
+ for (const child of frameTree.childFrames)
411
+ this._handleFrameTree(child);
412
+ }
413
+ _onFrameAttached(frameId, parentFrameId) {
414
+ return this._page.frameManager.frameAttached(frameId, parentFrameId);
415
+ }
416
+ _onFrameNavigated(framePayload, initial) {
417
+ const frame = this._page.frameManager.frame(framePayload.id);
418
+ (0, import_utils.assert)(frame);
419
+ this._removeContextsForFrame(frame, true);
420
+ if (!framePayload.parentId)
421
+ this._workers.clear();
422
+ this._page.frameManager.frameCommittedNewDocumentNavigation(framePayload.id, framePayload.url, framePayload.name || "", framePayload.loaderId, initial);
423
+ if (!initial)
424
+ this._firstNonInitialNavigationCommittedFulfill();
425
+ }
426
+ _onFrameNavigatedWithinDocument(frameId, url) {
427
+ this._page.frameManager.frameCommittedSameDocumentNavigation(frameId, url);
428
+ }
429
+ _onFrameDetached(frameId) {
430
+ this._page.frameManager.frameDetached(frameId);
431
+ }
432
+ _removeContextsForFrame(frame, notifyFrame) {
433
+ for (const [contextId, context] of this._contextIdToContext) {
434
+ if (context.frame === frame) {
435
+ this._contextIdToContext.delete(contextId);
436
+ if (notifyFrame)
437
+ frame._contextDestroyed(context);
438
+ }
439
+ }
440
+ }
441
+ _onExecutionContextCreated(contextPayload) {
442
+ if (this._contextIdToContext.has(contextPayload.id))
443
+ return;
444
+ const frame = this._page.frameManager.frame(contextPayload.frameId);
445
+ if (!frame)
446
+ return;
447
+ const delegate = new import_wkExecutionContext.WKExecutionContext(this._session, contextPayload.id);
448
+ let worldName = null;
449
+ if (contextPayload.type === "normal")
450
+ worldName = "main";
451
+ else if (contextPayload.type === "user" && contextPayload.name === UTILITY_WORLD_NAME)
452
+ worldName = "utility";
453
+ const context = new dom.FrameExecutionContext(delegate, frame, worldName);
454
+ if (worldName)
455
+ frame._contextCreated(worldName, context);
456
+ this._contextIdToContext.set(contextPayload.id, context);
457
+ }
458
+ async _onBindingCalled(contextId, argument) {
459
+ const pageOrError = await this._page.waitForInitializedOrError();
460
+ if (!(pageOrError instanceof Error)) {
461
+ const context = this._contextIdToContext.get(contextId);
462
+ if (context)
463
+ await this._page.onBindingCalled(argument, context);
464
+ }
465
+ }
466
+ async navigateFrame(frame, url, referrer) {
467
+ if (this._pageProxySession.isDisposed())
468
+ throw new import_errors.TargetClosedError(this._page.closeReason());
469
+ const pageProxyId = this._pageProxySession.sessionId;
470
+ const result = await this._pageProxySession.connection.browserSession.send("Playwright.navigate", { url, pageProxyId, frameId: frame._id, referrer });
471
+ return { newDocumentId: result.loaderId };
472
+ }
473
+ _onConsoleMessage(event) {
474
+ const { type, level, text, parameters, url, line: lineNumber, column: columnNumber, source } = event.message;
475
+ if (level === "error" && source === "javascript") {
476
+ const { name, message } = (0, import_stackTrace.splitErrorMessage)(text);
477
+ let stack;
478
+ if (event.message.stackTrace) {
479
+ stack = text + "\n" + event.message.stackTrace.callFrames.map((callFrame) => {
480
+ return ` at ${callFrame.functionName || "unknown"} (${callFrame.url}:${callFrame.lineNumber}:${callFrame.columnNumber})`;
481
+ }).join("\n");
482
+ } else {
483
+ stack = "";
484
+ }
485
+ this._lastConsoleMessage = null;
486
+ const error = new Error(message);
487
+ error.stack = stack;
488
+ error.name = name;
489
+ this._page.addPageError(error);
490
+ return;
491
+ }
492
+ let derivedType = type || "";
493
+ if (type === "log")
494
+ derivedType = level;
495
+ else if (type === "timing")
496
+ derivedType = "timeEnd";
497
+ const handles = [];
498
+ for (const p of parameters || []) {
499
+ let context;
500
+ if (p.objectId) {
501
+ const objectId = JSON.parse(p.objectId);
502
+ context = this._contextIdToContext.get(objectId.injectedScriptId);
503
+ } else {
504
+ context = [...this._contextIdToContext.values()].find((c) => c.frame === this._page.mainFrame());
505
+ }
506
+ if (!context)
507
+ return;
508
+ handles.push((0, import_wkExecutionContext.createHandle)(context, p));
509
+ }
510
+ this._lastConsoleMessage = {
511
+ derivedType,
512
+ text,
513
+ handles,
514
+ count: 0,
515
+ location: {
516
+ url: url || "",
517
+ lineNumber: (lineNumber || 1) - 1,
518
+ columnNumber: (columnNumber || 1) - 1
519
+ }
520
+ };
521
+ this._onConsoleRepeatCountUpdated({ count: 1, timestamp: event.message.timestamp });
522
+ }
523
+ _onConsoleRepeatCountUpdated(event) {
524
+ if (this._lastConsoleMessage) {
525
+ const {
526
+ derivedType,
527
+ text,
528
+ handles,
529
+ count,
530
+ location
531
+ } = this._lastConsoleMessage;
532
+ const timestamp = event.timestamp ? event.timestamp * 1e3 : Date.now();
533
+ for (let i = count; i < event.count; ++i)
534
+ this._page.addConsoleMessage(null, derivedType, handles, location, handles.length ? void 0 : text, timestamp);
535
+ this._lastConsoleMessage.count = event.count;
536
+ }
537
+ }
538
+ _onDialog(event) {
539
+ this._page.browserContext.dialogManager.dialogDidOpen(new dialog.Dialog(
540
+ this._page,
541
+ event.type,
542
+ event.message,
543
+ async (accept, promptText) => {
544
+ if (event.type === "beforeunload" && !accept)
545
+ this._page.frameManager.frameAbortedNavigation(this._page.mainFrame()._id, "navigation cancelled by beforeunload dialog");
546
+ await this._pageProxySession.send("Dialog.handleJavaScriptDialog", { accept, promptText });
547
+ },
548
+ event.defaultPrompt
549
+ ));
550
+ }
551
+ async _onFileChooserOpened(event) {
552
+ let handle;
553
+ try {
554
+ const context = await this._page.frameManager.frame(event.frameId)._mainContext();
555
+ handle = (0, import_wkExecutionContext.createHandle)(context, event.element).asElement();
556
+ } catch (e) {
557
+ return;
558
+ }
559
+ await this._page._onFileChooserOpened(handle);
560
+ }
561
+ static async _setEmulateMedia(session, mediaType, colorScheme, reducedMotion, forcedColors, contrast) {
562
+ const promises = [];
563
+ promises.push(session.send("Page.setEmulatedMedia", { media: mediaType === "no-override" ? "" : mediaType }));
564
+ let appearance = void 0;
565
+ switch (colorScheme) {
566
+ case "light":
567
+ appearance = "Light";
568
+ break;
569
+ case "dark":
570
+ appearance = "Dark";
571
+ break;
572
+ case "no-override":
573
+ appearance = void 0;
574
+ break;
575
+ }
576
+ promises.push(session.send("Page.overrideUserPreference", { name: "PrefersColorScheme", value: appearance }));
577
+ let reducedMotionWk = void 0;
578
+ switch (reducedMotion) {
579
+ case "reduce":
580
+ reducedMotionWk = "Reduce";
581
+ break;
582
+ case "no-preference":
583
+ reducedMotionWk = "NoPreference";
584
+ break;
585
+ case "no-override":
586
+ reducedMotionWk = void 0;
587
+ break;
588
+ }
589
+ promises.push(session.send("Page.overrideUserPreference", { name: "PrefersReducedMotion", value: reducedMotionWk }));
590
+ let forcedColorsWk = void 0;
591
+ switch (forcedColors) {
592
+ case "active":
593
+ forcedColorsWk = "Active";
594
+ break;
595
+ case "none":
596
+ forcedColorsWk = "None";
597
+ break;
598
+ case "no-override":
599
+ forcedColorsWk = void 0;
600
+ break;
601
+ }
602
+ promises.push(session.send("Page.setForcedColors", { forcedColors: forcedColorsWk }));
603
+ let contrastWk = void 0;
604
+ switch (contrast) {
605
+ case "more":
606
+ contrastWk = "More";
607
+ break;
608
+ case "no-preference":
609
+ contrastWk = "NoPreference";
610
+ break;
611
+ case "no-override":
612
+ contrastWk = void 0;
613
+ break;
614
+ }
615
+ promises.push(session.send("Page.overrideUserPreference", { name: "PrefersContrast", value: contrastWk }));
616
+ await Promise.all(promises);
617
+ }
618
+ async updateExtraHTTPHeaders() {
619
+ await this._updateState("Network.setExtraHTTPHeaders", { headers: (0, import_headers.headersArrayToObject)(
620
+ this._calculateExtraHTTPHeaders(),
621
+ false
622
+ /* lowerCase */
623
+ ) });
624
+ }
625
+ _calculateExtraHTTPHeaders() {
626
+ const locale = this._browserContext._options.locale;
627
+ const headers = network.mergeHeaders([
628
+ this._browserContext._options.extraHTTPHeaders,
629
+ this._page.extraHTTPHeaders(),
630
+ locale ? network.singleHeader("Accept-Language", locale) : void 0
631
+ ]);
632
+ return headers;
633
+ }
634
+ async updateEmulateMedia() {
635
+ const emulatedMedia = this._page.emulatedMedia();
636
+ const colorScheme = emulatedMedia.colorScheme;
637
+ const reducedMotion = emulatedMedia.reducedMotion;
638
+ const forcedColors = emulatedMedia.forcedColors;
639
+ const contrast = emulatedMedia.contrast;
640
+ await this._forAllSessions((session) => WKPage._setEmulateMedia(session, emulatedMedia.media, colorScheme, reducedMotion, forcedColors, contrast));
641
+ }
642
+ async updateEmulatedViewportSize() {
643
+ this._browserContext._validateEmulatedViewport(this._page.emulatedSize()?.viewport);
644
+ await this._updateViewport();
645
+ }
646
+ async updateUserAgent() {
647
+ const contextOptions = this._browserContext._options;
648
+ this._updateState("Page.overrideUserAgent", { value: contextOptions.userAgent });
649
+ }
650
+ async bringToFront() {
651
+ await this._pageProxySession.send("Target.activate", {
652
+ targetId: this._session.sessionId
653
+ });
654
+ }
655
+ async _updateViewport() {
656
+ const options = this._browserContext._options;
657
+ const emulatedSize = this._page.emulatedSize();
658
+ if (!emulatedSize)
659
+ return;
660
+ const viewportSize = emulatedSize.viewport;
661
+ const screenSize = emulatedSize.screen;
662
+ const promises = [
663
+ this._pageProxySession.send("Emulation.setDeviceMetricsOverride", {
664
+ width: viewportSize.width,
665
+ height: viewportSize.height,
666
+ fixedLayout: !!options.isMobile,
667
+ deviceScaleFactor: options.deviceScaleFactor || 1
668
+ }),
669
+ this._session.send("Page.setScreenSizeOverride", {
670
+ width: screenSize.width,
671
+ height: screenSize.height
672
+ })
673
+ ];
674
+ if (options.isMobile) {
675
+ const angle = viewportSize.width > viewportSize.height ? 90 : 0;
676
+ promises.push(this._pageProxySession.send("Emulation.setOrientationOverride", { angle }));
677
+ }
678
+ await Promise.all(promises);
679
+ if (!this._browserContext._browser?.options.headful && (import_hostPlatform.hostPlatform === "ubuntu22.04-x64" || import_hostPlatform.hostPlatform.startsWith("debian12")))
680
+ await new Promise((r) => setTimeout(r, 500));
681
+ }
682
+ async updateRequestInterception() {
683
+ const enabled = this._page.needsRequestInterception();
684
+ await Promise.all([
685
+ this._updateState("Network.setInterceptionEnabled", { enabled }),
686
+ this._updateState("Network.setResourceCachingDisabled", { disabled: enabled }),
687
+ this._updateState("Network.addInterception", { url: ".*", stage: "request", isRegex: true })
688
+ ]);
689
+ }
690
+ async updateOffline() {
691
+ await this._updateState("Network.setEmulateOfflineState", { offline: !!this._browserContext._options.offline });
692
+ }
693
+ async updateHttpCredentials() {
694
+ const credentials = this._browserContext._options.httpCredentials || { username: "", password: "", origin: "" };
695
+ await this._pageProxySession.send("Emulation.setAuthCredentials", { username: credentials.username, password: credentials.password, origin: credentials.origin });
696
+ }
697
+ async updateFileChooserInterception() {
698
+ const enabled = this._page.fileChooserIntercepted();
699
+ await this._session.send("Page.setInterceptFileChooserDialog", { enabled }).catch(() => {
700
+ });
701
+ }
702
+ async reload() {
703
+ await this._session.send("Page.reload");
704
+ }
705
+ goBack() {
706
+ return this._session.send("Page.goBack").then(() => true).catch((error) => {
707
+ if (error instanceof Error && error.message.includes(`Protocol error (Page.goBack): Failed to go`))
708
+ return false;
709
+ throw error;
710
+ });
711
+ }
712
+ goForward() {
713
+ return this._session.send("Page.goForward").then(() => true).catch((error) => {
714
+ if (error instanceof Error && error.message.includes(`Protocol error (Page.goForward): Failed to go`))
715
+ return false;
716
+ throw error;
717
+ });
718
+ }
719
+ async requestGC() {
720
+ await this._session.send("Heap.gc");
721
+ }
722
+ async addInitScript(initScript) {
723
+ await this._updateBootstrapScript();
724
+ }
725
+ async removeInitScripts(initScripts) {
726
+ await this._updateBootstrapScript();
727
+ }
728
+ async exposePlaywrightBinding() {
729
+ await this._updateState("Runtime.addBinding", { name: import_page.PageBinding.kBindingName });
730
+ }
731
+ _calculateBootstrapScript() {
732
+ const scripts = [];
733
+ if (!this._page.browserContext._options.isMobile) {
734
+ scripts.push("delete window.orientation");
735
+ scripts.push("delete window.ondevicemotion");
736
+ scripts.push("delete window.ondeviceorientation");
737
+ }
738
+ scripts.push('if (!window.safari) window.safari = { pushNotification: { toString() { return "[object SafariRemoteNotification]"; } } };');
739
+ scripts.push("if (!window.GestureEvent) window.GestureEvent = function GestureEvent() {};");
740
+ scripts.push(this._publicKeyCredentialScript());
741
+ scripts.push(...this._page.allInitScripts().map((script) => script.source));
742
+ return scripts.join(";\n");
743
+ }
744
+ _publicKeyCredentialScript() {
745
+ function polyfill() {
746
+ window.PublicKeyCredential ??= {
747
+ async getClientCapabilities() {
748
+ return {};
749
+ },
750
+ async isConditionalMediationAvailable() {
751
+ return false;
752
+ },
753
+ async isUserVerifyingPlatformAuthenticatorAvailable() {
754
+ return false;
755
+ }
756
+ };
757
+ }
758
+ return `(${polyfill.toString()})();`;
759
+ }
760
+ async _updateBootstrapScript() {
761
+ await this._updateState("Page.setBootstrapScript", { source: this._calculateBootstrapScript() });
762
+ }
763
+ async closePage(runBeforeUnload) {
764
+ await this._pageProxySession.sendMayFail("Target.close", {
765
+ targetId: this._session.sessionId,
766
+ runBeforeUnload
767
+ });
768
+ }
769
+ async setBackgroundColor(color) {
770
+ await this._session.send("Page.setDefaultBackgroundColorOverride", { color });
771
+ }
772
+ _toolbarHeight() {
773
+ if (this._page.browserContext._browser?.options.headful)
774
+ return import_hostPlatform.hostPlatform === "mac10.15" ? 55 : 59;
775
+ return 0;
776
+ }
777
+ async _initializeVideoRecording() {
778
+ const screencast = this._page.screencast;
779
+ const videoOptions = this._page.isStorageStatePage ? void 0 : screencast.launchAutomaticVideoRecorder();
780
+ if (videoOptions)
781
+ await screencast.startVideoRecording(videoOptions);
782
+ }
783
+ validateScreenshotDimension(side, omitDeviceScaleFactor) {
784
+ if (process.platform === "darwin")
785
+ return;
786
+ if (!omitDeviceScaleFactor && this._page.browserContext._options.deviceScaleFactor)
787
+ side = Math.ceil(side * this._page.browserContext._options.deviceScaleFactor);
788
+ if (side > 32767)
789
+ throw new Error("Cannot take screenshot larger than 32767 pixels on any dimension");
790
+ }
791
+ async takeScreenshot(progress, format, documentRect, viewportRect, quality, fitsViewport, scale) {
792
+ const rect = documentRect || viewportRect;
793
+ const omitDeviceScaleFactor = scale === "css";
794
+ this.validateScreenshotDimension(rect.width, omitDeviceScaleFactor);
795
+ this.validateScreenshotDimension(rect.height, omitDeviceScaleFactor);
796
+ const result = await progress.race(this._session.send("Page.snapshotRect", { ...rect, coordinateSystem: documentRect ? "Page" : "Viewport", omitDeviceScaleFactor }));
797
+ const prefix = "data:image/png;base64,";
798
+ let buffer = Buffer.from(result.dataURL.substr(prefix.length), "base64");
799
+ if (format === "jpeg")
800
+ buffer = import_utilsBundle.jpegjs.encode(import_utilsBundle.PNG.sync.read(buffer), quality).data;
801
+ return buffer;
802
+ }
803
+ async getContentFrame(handle) {
804
+ const nodeInfo = await this._session.send("DOM.describeNode", {
805
+ objectId: handle._objectId
806
+ });
807
+ if (!nodeInfo.contentFrameId)
808
+ return null;
809
+ return this._page.frameManager.frame(nodeInfo.contentFrameId);
810
+ }
811
+ async getOwnerFrame(handle) {
812
+ if (!handle._objectId)
813
+ return null;
814
+ const nodeInfo = await this._session.send("DOM.describeNode", {
815
+ objectId: handle._objectId
816
+ });
817
+ return nodeInfo.ownerFrameId || null;
818
+ }
819
+ async getBoundingBox(handle) {
820
+ const quads = await this.getContentQuads(handle);
821
+ if (!quads || !quads.length)
822
+ return null;
823
+ let minX = Infinity;
824
+ let maxX = -Infinity;
825
+ let minY = Infinity;
826
+ let maxY = -Infinity;
827
+ for (const quad of quads) {
828
+ for (const point of quad) {
829
+ minX = Math.min(minX, point.x);
830
+ maxX = Math.max(maxX, point.x);
831
+ minY = Math.min(minY, point.y);
832
+ maxY = Math.max(maxY, point.y);
833
+ }
834
+ }
835
+ return { x: minX, y: minY, width: maxX - minX, height: maxY - minY };
836
+ }
837
+ async scrollRectIntoViewIfNeeded(handle, rect) {
838
+ return await this._session.send("DOM.scrollIntoViewIfNeeded", {
839
+ objectId: handle._objectId,
840
+ rect
841
+ }).then(() => "done").catch((e) => {
842
+ if (e instanceof Error && e.message.includes("Node does not have a layout object"))
843
+ return "error:notvisible";
844
+ if (e instanceof Error && e.message.includes("Node is detached from document"))
845
+ return "error:notconnected";
846
+ throw e;
847
+ });
848
+ }
849
+ async startScreencast(options) {
850
+ const { generation } = await this._pageProxySession.send("Screencast.startScreencast", {
851
+ quality: options.quality,
852
+ width: options.width,
853
+ height: options.height,
854
+ toolbarHeight: this._toolbarHeight()
855
+ });
856
+ this._screencastGeneration = generation;
857
+ }
858
+ async stopScreencast() {
859
+ await this._pageProxySession.sendMayFail("Screencast.stopScreencast");
860
+ }
861
+ _onScreencastFrame(event) {
862
+ const generation = this._screencastGeneration;
863
+ this._page.screencast.throttleFrameAck(() => {
864
+ this._pageProxySession.sendMayFail("Screencast.screencastFrameAck", { generation });
865
+ });
866
+ const buffer = Buffer.from(event.data, "base64");
867
+ this._page.screencast.onScreencastFrame({
868
+ buffer,
869
+ frameSwapWallTime: event.timestamp ? event.timestamp * 1e3 : Date.now(),
870
+ viewportWidth: event.deviceWidth,
871
+ viewportHeight: event.deviceHeight
872
+ });
873
+ }
874
+ rafCountForStablePosition() {
875
+ return process.platform === "win32" ? 5 : 1;
876
+ }
877
+ async getContentQuads(handle) {
878
+ const result = await this._session.sendMayFail("DOM.getContentQuads", {
879
+ objectId: handle._objectId
880
+ });
881
+ if (!result)
882
+ return null;
883
+ return result.quads.map((quad) => [
884
+ { x: quad[0], y: quad[1] },
885
+ { x: quad[2], y: quad[3] },
886
+ { x: quad[4], y: quad[5] },
887
+ { x: quad[6], y: quad[7] }
888
+ ]);
889
+ }
890
+ async setInputFilePaths(handle, paths) {
891
+ const pageProxyId = this._pageProxySession.sessionId;
892
+ const objectId = handle._objectId;
893
+ if (this._browserContext._browser?.options.channel === "webkit-wsl")
894
+ paths = await Promise.all(paths.map((path) => (0, import_webkit.translatePathToWSL)(path)));
895
+ await Promise.all([
896
+ this._pageProxySession.connection.browserSession.send("Playwright.grantFileReadAccess", { pageProxyId, paths }),
897
+ this._session.send("DOM.setInputFiles", { objectId, paths })
898
+ ]);
899
+ }
900
+ async adoptElementHandle(handle, to) {
901
+ const result = await this._session.sendMayFail("DOM.resolveNode", {
902
+ objectId: handle._objectId,
903
+ executionContextId: to.delegate._contextId
904
+ });
905
+ if (!result || result.object.subtype === "null")
906
+ throw new Error(dom.kUnableToAdoptErrorMessage);
907
+ return (0, import_wkExecutionContext.createHandle)(to, result.object);
908
+ }
909
+ async inputActionEpilogue() {
910
+ }
911
+ async resetForReuse(progress) {
912
+ }
913
+ async getFrameElement(frame) {
914
+ const parent = frame.parentFrame();
915
+ if (!parent)
916
+ throw new Error("Frame has been detached.");
917
+ const context = await parent._mainContext();
918
+ const result = await this._session.send("DOM.resolveNode", {
919
+ frameId: frame._id,
920
+ executionContextId: context.delegate._contextId
921
+ });
922
+ if (!result || result.object.subtype === "null")
923
+ throw new Error("Frame has been detached.");
924
+ return (0, import_wkExecutionContext.createHandle)(context, result.object);
925
+ }
926
+ _maybeCancelCoopNavigationRequest(provisionalPage) {
927
+ const navigationRequest = provisionalPage.coopNavigationRequest();
928
+ for (const [requestId, request] of this._requestIdToRequest) {
929
+ if (request.request === navigationRequest) {
930
+ this._onLoadingFailed(provisionalPage._session, {
931
+ requestId,
932
+ errorText: "Provisiolal navigation canceled.",
933
+ timestamp: request._timestamp,
934
+ canceled: true
935
+ });
936
+ return;
937
+ }
938
+ }
939
+ }
940
+ _adoptRequestFromNewProcess(navigationRequest, newSession, newRequestId) {
941
+ for (const [requestId, request] of this._requestIdToRequest) {
942
+ if (request.request === navigationRequest) {
943
+ this._requestIdToRequest.delete(requestId);
944
+ request.adoptRequestFromNewProcess(newSession, newRequestId);
945
+ this._requestIdToRequest.set(newRequestId, request);
946
+ return;
947
+ }
948
+ }
949
+ }
950
+ _onRequestWillBeSent(session, event) {
951
+ if (event.request.url.startsWith("data:"))
952
+ return;
953
+ if (event.request.url.startsWith("about:"))
954
+ return;
955
+ if (this._page.needsRequestInterception() && !event.redirectResponse)
956
+ this._requestIdToRequestWillBeSentEvent.set(event.requestId, event);
957
+ else
958
+ this._onRequest(session, event, false);
959
+ }
960
+ _onRequest(session, event, intercepted) {
961
+ let redirectedFrom = null;
962
+ if (event.redirectResponse) {
963
+ const request2 = this._requestIdToRequest.get(event.requestId);
964
+ if (request2) {
965
+ this._handleRequestRedirect(request2, event.requestId, event.redirectResponse, event.timestamp);
966
+ redirectedFrom = request2;
967
+ }
968
+ }
969
+ const frame = redirectedFrom ? redirectedFrom.request.frame() : this._page.frameManager.frame(event.frameId);
970
+ if (!frame)
971
+ return;
972
+ const isNavigationRequest = event.type === "Document";
973
+ const documentId = isNavigationRequest ? event.loaderId : void 0;
974
+ const request = new import_wkInterceptableRequest.WKInterceptableRequest(session, frame, event, redirectedFrom, documentId);
975
+ let route;
976
+ if (intercepted) {
977
+ route = new import_wkInterceptableRequest.WKRouteImpl(session, event.requestId);
978
+ request.request.setRawRequestHeaders(null);
979
+ }
980
+ this._requestIdToRequest.set(event.requestId, request);
981
+ this._page.frameManager.requestStarted(request.request, route);
982
+ }
983
+ _handleRequestRedirect(request, requestId, responsePayload, timestamp) {
984
+ const response = request.createResponse(responsePayload);
985
+ response._setHttpVersion(null);
986
+ response._securityDetailsFinished();
987
+ response._serverAddrFinished();
988
+ response.setResponseHeadersSize(null);
989
+ response.setEncodedBodySize(null);
990
+ response._requestFinished(responsePayload.timing ? import_helper.helper.secondsToRoundishMillis(timestamp - request._timestamp) : -1);
991
+ this._requestIdToRequest.delete(requestId);
992
+ this._page.frameManager.requestReceivedResponse(response);
993
+ this._page.frameManager.reportRequestFinished(request.request, response);
994
+ }
995
+ _onRequestIntercepted(session, event) {
996
+ const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(event.requestId);
997
+ if (!requestWillBeSentEvent) {
998
+ session.sendMayFail("Network.interceptWithRequest", { requestId: event.requestId });
999
+ return;
1000
+ }
1001
+ this._requestIdToRequestWillBeSentEvent.delete(event.requestId);
1002
+ this._onRequest(session, requestWillBeSentEvent, true);
1003
+ }
1004
+ _onResponseReceived(session, event) {
1005
+ const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(event.requestId);
1006
+ if (requestWillBeSentEvent) {
1007
+ this._requestIdToRequestWillBeSentEvent.delete(event.requestId);
1008
+ this._onRequest(session, requestWillBeSentEvent, false);
1009
+ }
1010
+ const request = this._requestIdToRequest.get(event.requestId);
1011
+ if (!request)
1012
+ return;
1013
+ this._requestIdToResponseReceivedPayloadEvent.set(event.requestId, event);
1014
+ const response = request.createResponse(event.response);
1015
+ this._page.frameManager.requestReceivedResponse(response);
1016
+ if (response.status() === 204 && request.request.isNavigationRequest()) {
1017
+ this._onLoadingFailed(session, {
1018
+ requestId: event.requestId,
1019
+ errorText: "Aborted: 204 No Content",
1020
+ timestamp: event.timestamp
1021
+ });
1022
+ }
1023
+ }
1024
+ _onLoadingFinished(event) {
1025
+ const request = this._requestIdToRequest.get(event.requestId);
1026
+ if (!request)
1027
+ return;
1028
+ const response = request.request._existingResponse();
1029
+ if (response) {
1030
+ const responseReceivedPayload = this._requestIdToResponseReceivedPayloadEvent.get(event.requestId);
1031
+ response._serverAddrFinished(parseRemoteAddress(event?.metrics?.remoteAddress));
1032
+ response._securityDetailsFinished({
1033
+ protocol: isLoadedSecurely(response.url(), response.timing()) ? event.metrics?.securityConnection?.protocol : void 0,
1034
+ subjectName: responseReceivedPayload?.response.security?.certificate?.subject,
1035
+ validFrom: responseReceivedPayload?.response.security?.certificate?.validFrom,
1036
+ validTo: responseReceivedPayload?.response.security?.certificate?.validUntil
1037
+ });
1038
+ response._setHttpVersion(event.metrics?.protocol ?? null);
1039
+ response.setEncodedBodySize(event.metrics?.responseBodyBytesReceived ?? null);
1040
+ response.setResponseHeadersSize(event.metrics?.responseHeaderBytesReceived ?? null);
1041
+ response._requestFinished(import_helper.helper.secondsToRoundishMillis(event.timestamp - request._timestamp));
1042
+ } else {
1043
+ request.request.setRawRequestHeaders(null);
1044
+ }
1045
+ this._requestIdToResponseReceivedPayloadEvent.delete(event.requestId);
1046
+ this._requestIdToRequest.delete(event.requestId);
1047
+ this._page.frameManager.reportRequestFinished(request.request, response);
1048
+ }
1049
+ _onLoadingFailed(session, event) {
1050
+ const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(event.requestId);
1051
+ if (requestWillBeSentEvent) {
1052
+ this._requestIdToRequestWillBeSentEvent.delete(event.requestId);
1053
+ this._onRequest(session, requestWillBeSentEvent, false);
1054
+ }
1055
+ const request = this._requestIdToRequest.get(event.requestId);
1056
+ if (!request)
1057
+ return;
1058
+ const response = request.request._existingResponse();
1059
+ if (response) {
1060
+ response._serverAddrFinished();
1061
+ response._securityDetailsFinished();
1062
+ response._setHttpVersion(null);
1063
+ response.setResponseHeadersSize(null);
1064
+ response.setEncodedBodySize(null);
1065
+ response._requestFinished(import_helper.helper.secondsToRoundishMillis(event.timestamp - request._timestamp));
1066
+ } else {
1067
+ request.request.setRawRequestHeaders(null);
1068
+ }
1069
+ this._requestIdToRequest.delete(event.requestId);
1070
+ request.request._setFailureText(event.errorText);
1071
+ this._page.frameManager.requestFailed(request.request, event.errorText.includes("cancelled"));
1072
+ }
1073
+ async _grantPermissions(origin, permissions) {
1074
+ const webPermissionToProtocol = /* @__PURE__ */ new Map([
1075
+ ["geolocation", "geolocation"],
1076
+ ["notifications", "notifications"],
1077
+ ["clipboard-read", "clipboard-read"],
1078
+ ["screen-wake-lock", "screen-wake-lock"]
1079
+ ]);
1080
+ const filtered = permissions.map((permission) => {
1081
+ const protocolPermission = webPermissionToProtocol.get(permission);
1082
+ if (!protocolPermission)
1083
+ throw new Error("Unknown permission: " + permission);
1084
+ return protocolPermission;
1085
+ });
1086
+ await this._pageProxySession.send("Emulation.grantPermissions", { origin, permissions: filtered });
1087
+ }
1088
+ async _clearPermissions() {
1089
+ await this._pageProxySession.send("Emulation.resetPermissions", {});
1090
+ }
1091
+ shouldToggleStyleSheetToSyncAnimations() {
1092
+ return true;
1093
+ }
1094
+ async setDockTile(image) {
1095
+ }
1096
+ }
1097
+ class WKFrame {
1098
+ constructor(page, session) {
1099
+ this._sessionListeners = [];
1100
+ this._initializePromise = null;
1101
+ this._page = page;
1102
+ this._session = session;
1103
+ }
1104
+ async initialize() {
1105
+ if (this._initializePromise)
1106
+ return this._initializePromise;
1107
+ this._initializePromise = this._initializeImpl();
1108
+ return this._initializePromise;
1109
+ }
1110
+ async _initializeImpl() {
1111
+ this._sessionListeners = [
1112
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Console.messageAdded", (event) => this._page._onConsoleMessage(event)),
1113
+ import_eventsHelper.eventsHelper.addEventListener(this._session, "Console.messageRepeatCountUpdated", (event) => this._page._onConsoleRepeatCountUpdated(event))
1114
+ ];
1115
+ await this._session.send("Console.enable");
1116
+ }
1117
+ dispose() {
1118
+ import_eventsHelper.eventsHelper.removeEventListeners(this._sessionListeners);
1119
+ this._session.dispose();
1120
+ }
1121
+ }
1122
+ function parseRemoteAddress(value) {
1123
+ if (!value)
1124
+ return;
1125
+ try {
1126
+ const colon = value.lastIndexOf(":");
1127
+ const dot = value.lastIndexOf(".");
1128
+ if (dot < 0) {
1129
+ return {
1130
+ ipAddress: `[${value.slice(0, colon)}]`,
1131
+ port: +value.slice(colon + 1)
1132
+ };
1133
+ }
1134
+ if (colon > dot) {
1135
+ const [address, port] = value.split(":");
1136
+ return {
1137
+ ipAddress: address,
1138
+ port: +port
1139
+ };
1140
+ } else {
1141
+ const [address, port] = value.split(".");
1142
+ return {
1143
+ ipAddress: `[${address}]`,
1144
+ port: +port
1145
+ };
1146
+ }
1147
+ } catch (_) {
1148
+ }
1149
+ }
1150
+ function isLoadedSecurely(url, timing) {
1151
+ try {
1152
+ const u = new URL(url);
1153
+ if (u.protocol !== "https:" && u.protocol !== "wss:" && u.protocol !== "sftp:")
1154
+ return false;
1155
+ if (timing.secureConnectionStart === -1 && timing.connectStart !== -1)
1156
+ return false;
1157
+ return true;
1158
+ } catch (_) {
1159
+ }
1160
+ }
1161
+ // Annotate the CommonJS export names for ESM import in node:
1162
+ 0 && (module.exports = {
1163
+ WKPage
1164
+ });