easytouch-linux 1.0.7 → 1.0.17

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 (337) hide show
  1. package/LICENSE.txt +201 -0
  2. package/README.md +33 -314
  3. package/SKILL.md +366 -0
  4. package/bin/arm64/et +0 -0
  5. package/bin/et.js +60 -0
  6. package/bin/x64/et +0 -0
  7. package/package.json +19 -37
  8. package/.playwright/node/LICENSE +0 -2607
  9. package/.playwright/node/linux-x64/node +0 -0
  10. package/.playwright/package/README.md +0 -3
  11. package/.playwright/package/ThirdPartyNotices.txt +0 -1602
  12. package/.playwright/package/api.json +0 -1
  13. package/.playwright/package/bin/install_media_pack.ps1 +0 -5
  14. package/.playwright/package/bin/reinstall_chrome_beta_linux.sh +0 -42
  15. package/.playwright/package/bin/reinstall_chrome_beta_mac.sh +0 -13
  16. package/.playwright/package/bin/reinstall_chrome_beta_win.ps1 +0 -24
  17. package/.playwright/package/bin/reinstall_chrome_stable_linux.sh +0 -42
  18. package/.playwright/package/bin/reinstall_chrome_stable_mac.sh +0 -12
  19. package/.playwright/package/bin/reinstall_chrome_stable_win.ps1 +0 -24
  20. package/.playwright/package/bin/reinstall_msedge_beta_linux.sh +0 -48
  21. package/.playwright/package/bin/reinstall_msedge_beta_mac.sh +0 -11
  22. package/.playwright/package/bin/reinstall_msedge_beta_win.ps1 +0 -23
  23. package/.playwright/package/bin/reinstall_msedge_dev_linux.sh +0 -48
  24. package/.playwright/package/bin/reinstall_msedge_dev_mac.sh +0 -11
  25. package/.playwright/package/bin/reinstall_msedge_dev_win.ps1 +0 -23
  26. package/.playwright/package/bin/reinstall_msedge_stable_linux.sh +0 -48
  27. package/.playwright/package/bin/reinstall_msedge_stable_mac.sh +0 -11
  28. package/.playwright/package/bin/reinstall_msedge_stable_win.ps1 +0 -24
  29. package/.playwright/package/browsers.json +0 -66
  30. package/.playwright/package/cli.js +0 -18
  31. package/.playwright/package/index.d.ts +0 -17
  32. package/.playwright/package/index.js +0 -33
  33. package/.playwright/package/index.mjs +0 -28
  34. package/.playwright/package/lib/androidServerImpl.js +0 -69
  35. package/.playwright/package/lib/browserServerImpl.js +0 -92
  36. package/.playwright/package/lib/cli/driver.js +0 -95
  37. package/.playwright/package/lib/cli/program.js +0 -583
  38. package/.playwright/package/lib/cli/programWithTestStub.js +0 -67
  39. package/.playwright/package/lib/client/accessibility.js +0 -50
  40. package/.playwright/package/lib/client/android.js +0 -473
  41. package/.playwright/package/lib/client/api.js +0 -285
  42. package/.playwright/package/lib/client/artifact.js +0 -79
  43. package/.playwright/package/lib/client/browser.js +0 -145
  44. package/.playwright/package/lib/client/browserContext.js +0 -559
  45. package/.playwright/package/lib/client/browserType.js +0 -241
  46. package/.playwright/package/lib/client/cdpSession.js +0 -53
  47. package/.playwright/package/lib/client/channelOwner.js +0 -215
  48. package/.playwright/package/lib/client/clientHelper.js +0 -57
  49. package/.playwright/package/lib/client/clientInstrumentation.js +0 -52
  50. package/.playwright/package/lib/client/clock.js +0 -68
  51. package/.playwright/package/lib/client/connection.js +0 -333
  52. package/.playwright/package/lib/client/consoleMessage.js +0 -55
  53. package/.playwright/package/lib/client/coverage.js +0 -41
  54. package/.playwright/package/lib/client/dialog.js +0 -57
  55. package/.playwright/package/lib/client/download.js +0 -62
  56. package/.playwright/package/lib/client/electron.js +0 -135
  57. package/.playwright/package/lib/client/elementHandle.js +0 -321
  58. package/.playwright/package/lib/client/errors.js +0 -77
  59. package/.playwright/package/lib/client/eventEmitter.js +0 -314
  60. package/.playwright/package/lib/client/events.js +0 -94
  61. package/.playwright/package/lib/client/fetch.js +0 -391
  62. package/.playwright/package/lib/client/fileChooser.js +0 -45
  63. package/.playwright/package/lib/client/frame.js +0 -504
  64. package/.playwright/package/lib/client/harRouter.js +0 -99
  65. package/.playwright/package/lib/client/input.js +0 -111
  66. package/.playwright/package/lib/client/jsHandle.js +0 -121
  67. package/.playwright/package/lib/client/jsonPipe.js +0 -35
  68. package/.playwright/package/lib/client/localUtils.js +0 -36
  69. package/.playwright/package/lib/client/locator.js +0 -448
  70. package/.playwright/package/lib/client/network.js +0 -769
  71. package/.playwright/package/lib/client/page.js +0 -748
  72. package/.playwright/package/lib/client/playwright.js +0 -80
  73. package/.playwright/package/lib/client/selectors.js +0 -67
  74. package/.playwright/package/lib/client/stream.js +0 -54
  75. package/.playwright/package/lib/client/tracing.js +0 -147
  76. package/.playwright/package/lib/client/types.js +0 -24
  77. package/.playwright/package/lib/client/video.js +0 -51
  78. package/.playwright/package/lib/client/waiter.js +0 -162
  79. package/.playwright/package/lib/client/webError.js +0 -37
  80. package/.playwright/package/lib/client/worker.js +0 -71
  81. package/.playwright/package/lib/client/writableStream.js +0 -54
  82. package/.playwright/package/lib/common/socksProxy.js +0 -569
  83. package/.playwright/package/lib/common/timeoutSettings.js +0 -73
  84. package/.playwright/package/lib/common/types.js +0 -5
  85. package/.playwright/package/lib/generated/clockSource.js +0 -7
  86. package/.playwright/package/lib/generated/consoleApiSource.js +0 -7
  87. package/.playwright/package/lib/generated/injectedScriptSource.js +0 -7
  88. package/.playwright/package/lib/generated/pollingRecorderSource.js +0 -7
  89. package/.playwright/package/lib/generated/utilityScriptSource.js +0 -7
  90. package/.playwright/package/lib/generated/webSocketMockSource.js +0 -7
  91. package/.playwright/package/lib/image_tools/colorUtils.js +0 -98
  92. package/.playwright/package/lib/image_tools/compare.js +0 -108
  93. package/.playwright/package/lib/image_tools/imageChannel.js +0 -70
  94. package/.playwright/package/lib/image_tools/stats.js +0 -102
  95. package/.playwright/package/lib/inProcessFactory.js +0 -56
  96. package/.playwright/package/lib/inprocess.js +0 -20
  97. package/.playwright/package/lib/outofprocess.js +0 -67
  98. package/.playwright/package/lib/protocol/debug.js +0 -27
  99. package/.playwright/package/lib/protocol/serializers.js +0 -173
  100. package/.playwright/package/lib/protocol/transport.js +0 -82
  101. package/.playwright/package/lib/protocol/validator.js +0 -2780
  102. package/.playwright/package/lib/protocol/validatorPrimitives.js +0 -139
  103. package/.playwright/package/lib/remote/playwrightConnection.js +0 -275
  104. package/.playwright/package/lib/remote/playwrightServer.js +0 -111
  105. package/.playwright/package/lib/server/accessibility.js +0 -62
  106. package/.playwright/package/lib/server/android/android.js +0 -441
  107. package/.playwright/package/lib/server/android/backendAdb.js +0 -172
  108. package/.playwright/package/lib/server/artifact.js +0 -104
  109. package/.playwright/package/lib/server/bidi/bidiBrowser.js +0 -314
  110. package/.playwright/package/lib/server/bidi/bidiChromium.js +0 -124
  111. package/.playwright/package/lib/server/bidi/bidiConnection.js +0 -204
  112. package/.playwright/package/lib/server/bidi/bidiExecutionContext.js +0 -175
  113. package/.playwright/package/lib/server/bidi/bidiFirefox.js +0 -104
  114. package/.playwright/package/lib/server/bidi/bidiInput.js +0 -160
  115. package/.playwright/package/lib/server/bidi/bidiNetworkManager.js +0 -337
  116. package/.playwright/package/lib/server/bidi/bidiOverCdp.js +0 -103
  117. package/.playwright/package/lib/server/bidi/bidiPage.js +0 -518
  118. package/.playwright/package/lib/server/bidi/bidiPdf.js +0 -140
  119. package/.playwright/package/lib/server/bidi/third_party/bidiDeserializer.js +0 -93
  120. package/.playwright/package/lib/server/bidi/third_party/bidiKeyboard.js +0 -240
  121. package/.playwright/package/lib/server/bidi/third_party/bidiProtocol.js +0 -139
  122. package/.playwright/package/lib/server/bidi/third_party/bidiSerializer.js +0 -144
  123. package/.playwright/package/lib/server/bidi/third_party/firefoxPrefs.js +0 -221
  124. package/.playwright/package/lib/server/browser.js +0 -148
  125. package/.playwright/package/lib/server/browserContext.js +0 -675
  126. package/.playwright/package/lib/server/browserType.js +0 -338
  127. package/.playwright/package/lib/server/chromium/appIcon.png +0 -0
  128. package/.playwright/package/lib/server/chromium/chromium.js +0 -354
  129. package/.playwright/package/lib/server/chromium/chromiumSwitches.js +0 -46
  130. package/.playwright/package/lib/server/chromium/crAccessibility.js +0 -237
  131. package/.playwright/package/lib/server/chromium/crBrowser.js +0 -516
  132. package/.playwright/package/lib/server/chromium/crConnection.js +0 -228
  133. package/.playwright/package/lib/server/chromium/crCoverage.js +0 -246
  134. package/.playwright/package/lib/server/chromium/crDevTools.js +0 -104
  135. package/.playwright/package/lib/server/chromium/crDragDrop.js +0 -143
  136. package/.playwright/package/lib/server/chromium/crExecutionContext.js +0 -132
  137. package/.playwright/package/lib/server/chromium/crInput.js +0 -182
  138. package/.playwright/package/lib/server/chromium/crNetworkManager.js +0 -767
  139. package/.playwright/package/lib/server/chromium/crPage.js +0 -1122
  140. package/.playwright/package/lib/server/chromium/crPdf.js +0 -153
  141. package/.playwright/package/lib/server/chromium/crProtocolHelper.js +0 -133
  142. package/.playwright/package/lib/server/chromium/crServiceWorker.js +0 -112
  143. package/.playwright/package/lib/server/chromium/defaultFontFamilies.js +0 -145
  144. package/.playwright/package/lib/server/chromium/videoRecorder.js +0 -155
  145. package/.playwright/package/lib/server/clock.js +0 -125
  146. package/.playwright/package/lib/server/codegen/csharp.js +0 -304
  147. package/.playwright/package/lib/server/codegen/java.js +0 -243
  148. package/.playwright/package/lib/server/codegen/javascript.js +0 -253
  149. package/.playwright/package/lib/server/codegen/jsonl.js +0 -47
  150. package/.playwright/package/lib/server/codegen/language.js +0 -88
  151. package/.playwright/package/lib/server/codegen/languages.js +0 -30
  152. package/.playwright/package/lib/server/codegen/python.js +0 -262
  153. package/.playwright/package/lib/server/codegen/types.js +0 -5
  154. package/.playwright/package/lib/server/console.js +0 -57
  155. package/.playwright/package/lib/server/cookieStore.js +0 -185
  156. package/.playwright/package/lib/server/debugController.js +0 -212
  157. package/.playwright/package/lib/server/debugger.js +0 -132
  158. package/.playwright/package/lib/server/deviceDescriptors.js +0 -26
  159. package/.playwright/package/lib/server/deviceDescriptorsSource.json +0 -1669
  160. package/.playwright/package/lib/server/dialog.js +0 -71
  161. package/.playwright/package/lib/server/dispatchers/androidDispatcher.js +0 -204
  162. package/.playwright/package/lib/server/dispatchers/artifactDispatcher.js +0 -118
  163. package/.playwright/package/lib/server/dispatchers/browserContextDispatcher.js +0 -357
  164. package/.playwright/package/lib/server/dispatchers/browserDispatcher.js +0 -170
  165. package/.playwright/package/lib/server/dispatchers/browserTypeDispatcher.js +0 -55
  166. package/.playwright/package/lib/server/dispatchers/cdpSessionDispatcher.js +0 -48
  167. package/.playwright/package/lib/server/dispatchers/debugControllerDispatcher.js +0 -105
  168. package/.playwright/package/lib/server/dispatchers/dialogDispatcher.js +0 -44
  169. package/.playwright/package/lib/server/dispatchers/dispatcher.js +0 -395
  170. package/.playwright/package/lib/server/dispatchers/electronDispatcher.js +0 -93
  171. package/.playwright/package/lib/server/dispatchers/elementHandlerDispatcher.js +0 -228
  172. package/.playwright/package/lib/server/dispatchers/frameDispatcher.js +0 -294
  173. package/.playwright/package/lib/server/dispatchers/jsHandleDispatcher.js +0 -97
  174. package/.playwright/package/lib/server/dispatchers/jsonPipeDispatcher.js +0 -59
  175. package/.playwright/package/lib/server/dispatchers/localUtilsDispatcher.js +0 -413
  176. package/.playwright/package/lib/server/dispatchers/networkDispatchers.js +0 -221
  177. package/.playwright/package/lib/server/dispatchers/pageDispatcher.js +0 -367
  178. package/.playwright/package/lib/server/dispatchers/playwrightDispatcher.js +0 -107
  179. package/.playwright/package/lib/server/dispatchers/selectorsDispatcher.js +0 -36
  180. package/.playwright/package/lib/server/dispatchers/streamDispatcher.js +0 -62
  181. package/.playwright/package/lib/server/dispatchers/tracingDispatcher.js +0 -64
  182. package/.playwright/package/lib/server/dispatchers/webSocketRouteDispatcher.js +0 -188
  183. package/.playwright/package/lib/server/dispatchers/writableStreamDispatcher.js +0 -58
  184. package/.playwright/package/lib/server/dom.js +0 -893
  185. package/.playwright/package/lib/server/download.js +0 -60
  186. package/.playwright/package/lib/server/electron/electron.js +0 -296
  187. package/.playwright/package/lib/server/electron/loader.js +0 -57
  188. package/.playwright/package/lib/server/errors.js +0 -68
  189. package/.playwright/package/lib/server/fetch.js +0 -663
  190. package/.playwright/package/lib/server/fileChooser.js +0 -42
  191. package/.playwright/package/lib/server/fileUploadUtils.js +0 -75
  192. package/.playwright/package/lib/server/firefox/ffAccessibility.js +0 -216
  193. package/.playwright/package/lib/server/firefox/ffBrowser.js +0 -462
  194. package/.playwright/package/lib/server/firefox/ffConnection.js +0 -168
  195. package/.playwright/package/lib/server/firefox/ffExecutionContext.js +0 -123
  196. package/.playwright/package/lib/server/firefox/ffInput.js +0 -161
  197. package/.playwright/package/lib/server/firefox/ffNetworkManager.js +0 -233
  198. package/.playwright/package/lib/server/firefox/ffPage.js +0 -544
  199. package/.playwright/package/lib/server/firefox/firefox.js +0 -99
  200. package/.playwright/package/lib/server/formData.js +0 -75
  201. package/.playwright/package/lib/server/frameSelectors.js +0 -171
  202. package/.playwright/package/lib/server/frames.js +0 -1663
  203. package/.playwright/package/lib/server/har/harRecorder.js +0 -139
  204. package/.playwright/package/lib/server/har/harTracer.js +0 -542
  205. package/.playwright/package/lib/server/helper.js +0 -103
  206. package/.playwright/package/lib/server/index.js +0 -108
  207. package/.playwright/package/lib/server/input.js +0 -309
  208. package/.playwright/package/lib/server/instrumentation.js +0 -70
  209. package/.playwright/package/lib/server/isomorphic/utilityScriptSerializers.js +0 -226
  210. package/.playwright/package/lib/server/javascript.js +0 -293
  211. package/.playwright/package/lib/server/launchApp.js +0 -91
  212. package/.playwright/package/lib/server/macEditingCommands.js +0 -139
  213. package/.playwright/package/lib/server/network.js +0 -617
  214. package/.playwright/package/lib/server/page.js +0 -863
  215. package/.playwright/package/lib/server/pipeTransport.js +0 -85
  216. package/.playwright/package/lib/server/playwright.js +0 -88
  217. package/.playwright/package/lib/server/progress.js +0 -99
  218. package/.playwright/package/lib/server/protocolError.js +0 -49
  219. package/.playwright/package/lib/server/recorder/chat.js +0 -177
  220. package/.playwright/package/lib/server/recorder/contextRecorder.js +0 -290
  221. package/.playwright/package/lib/server/recorder/recorderApp.js +0 -187
  222. package/.playwright/package/lib/server/recorder/recorderCollection.js +0 -104
  223. package/.playwright/package/lib/server/recorder/recorderFrontend.js +0 -5
  224. package/.playwright/package/lib/server/recorder/recorderRunner.js +0 -159
  225. package/.playwright/package/lib/server/recorder/recorderUtils.js +0 -89
  226. package/.playwright/package/lib/server/recorder/throttledFile.js +0 -46
  227. package/.playwright/package/lib/server/recorder.js +0 -367
  228. package/.playwright/package/lib/server/registry/browserFetcher.js +0 -168
  229. package/.playwright/package/lib/server/registry/dependencies.js +0 -322
  230. package/.playwright/package/lib/server/registry/index.js +0 -1165
  231. package/.playwright/package/lib/server/registry/nativeDeps.js +0 -496
  232. package/.playwright/package/lib/server/registry/oopDownloadBrowserMain.js +0 -138
  233. package/.playwright/package/lib/server/screenshotter.js +0 -348
  234. package/.playwright/package/lib/server/selectors.js +0 -73
  235. package/.playwright/package/lib/server/socksClientCertificatesInterceptor.js +0 -340
  236. package/.playwright/package/lib/server/socksInterceptor.js +0 -100
  237. package/.playwright/package/lib/server/trace/recorder/snapshotter.js +0 -161
  238. package/.playwright/package/lib/server/trace/recorder/snapshotterInjected.js +0 -518
  239. package/.playwright/package/lib/server/trace/recorder/tracing.js +0 -596
  240. package/.playwright/package/lib/server/trace/test/inMemorySnapshotter.js +0 -93
  241. package/.playwright/package/lib/server/trace/viewer/traceViewer.js +0 -219
  242. package/.playwright/package/lib/server/transport.js +0 -192
  243. package/.playwright/package/lib/server/types.js +0 -24
  244. package/.playwright/package/lib/server/usKeyboardLayout.js +0 -555
  245. package/.playwright/package/lib/server/webkit/webkit.js +0 -87
  246. package/.playwright/package/lib/server/webkit/wkAccessibility.js +0 -194
  247. package/.playwright/package/lib/server/webkit/wkBrowser.js +0 -329
  248. package/.playwright/package/lib/server/webkit/wkConnection.js +0 -173
  249. package/.playwright/package/lib/server/webkit/wkExecutionContext.js +0 -131
  250. package/.playwright/package/lib/server/webkit/wkInput.js +0 -179
  251. package/.playwright/package/lib/server/webkit/wkInterceptableRequest.js +0 -162
  252. package/.playwright/package/lib/server/webkit/wkPage.js +0 -1207
  253. package/.playwright/package/lib/server/webkit/wkProvisionalPage.js +0 -94
  254. package/.playwright/package/lib/server/webkit/wkWorkers.js +0 -104
  255. package/.playwright/package/lib/third_party/pixelmatch.js +0 -255
  256. package/.playwright/package/lib/utils/ascii.js +0 -31
  257. package/.playwright/package/lib/utils/comparators.js +0 -159
  258. package/.playwright/package/lib/utils/crypto.js +0 -171
  259. package/.playwright/package/lib/utils/debug.js +0 -46
  260. package/.playwright/package/lib/utils/debugLogger.js +0 -93
  261. package/.playwright/package/lib/utils/env.js +0 -49
  262. package/.playwright/package/lib/utils/eventsHelper.js +0 -38
  263. package/.playwright/package/lib/utils/expectUtils.js +0 -33
  264. package/.playwright/package/lib/utils/fileUtils.js +0 -205
  265. package/.playwright/package/lib/utils/happy-eyeballs.js +0 -194
  266. package/.playwright/package/lib/utils/headers.js +0 -52
  267. package/.playwright/package/lib/utils/hostPlatform.js +0 -145
  268. package/.playwright/package/lib/utils/httpServer.js +0 -233
  269. package/.playwright/package/lib/utils/index.js +0 -368
  270. package/.playwright/package/lib/utils/isomorphic/ariaSnapshot.js +0 -391
  271. package/.playwright/package/lib/utils/isomorphic/cssParser.js +0 -250
  272. package/.playwright/package/lib/utils/isomorphic/cssTokenizer.js +0 -979
  273. package/.playwright/package/lib/utils/isomorphic/locatorGenerators.js +0 -660
  274. package/.playwright/package/lib/utils/isomorphic/locatorParser.js +0 -185
  275. package/.playwright/package/lib/utils/isomorphic/locatorUtils.js +0 -62
  276. package/.playwright/package/lib/utils/isomorphic/mimeType.js +0 -29
  277. package/.playwright/package/lib/utils/isomorphic/selectorParser.js +0 -397
  278. package/.playwright/package/lib/utils/isomorphic/stringUtils.js +0 -169
  279. package/.playwright/package/lib/utils/isomorphic/traceUtils.js +0 -39
  280. package/.playwright/package/lib/utils/isomorphic/urlMatch.js +0 -122
  281. package/.playwright/package/lib/utils/linuxUtils.js +0 -78
  282. package/.playwright/package/lib/utils/manualPromise.js +0 -109
  283. package/.playwright/package/lib/utils/multimap.js +0 -75
  284. package/.playwright/package/lib/utils/network.js +0 -160
  285. package/.playwright/package/lib/utils/processLauncher.js +0 -248
  286. package/.playwright/package/lib/utils/profiler.js +0 -53
  287. package/.playwright/package/lib/utils/rtti.js +0 -44
  288. package/.playwright/package/lib/utils/semaphore.js +0 -51
  289. package/.playwright/package/lib/utils/sequence.js +0 -64
  290. package/.playwright/package/lib/utils/spawnAsync.js +0 -45
  291. package/.playwright/package/lib/utils/stackTrace.js +0 -134
  292. package/.playwright/package/lib/utils/task.js +0 -58
  293. package/.playwright/package/lib/utils/time.js +0 -37
  294. package/.playwright/package/lib/utils/timeoutRunner.js +0 -66
  295. package/.playwright/package/lib/utils/traceUtils.js +0 -44
  296. package/.playwright/package/lib/utils/userAgent.js +0 -105
  297. package/.playwright/package/lib/utils/wsServer.js +0 -128
  298. package/.playwright/package/lib/utils/zipFile.js +0 -75
  299. package/.playwright/package/lib/utils/zones.js +0 -69
  300. package/.playwright/package/lib/utilsBundle.js +0 -81
  301. package/.playwright/package/lib/utilsBundleImpl/index.js +0 -210
  302. package/.playwright/package/lib/utilsBundleImpl/xdg-open +0 -1066
  303. package/.playwright/package/lib/vite/htmlReport/index.html +0 -69
  304. package/.playwright/package/lib/vite/recorder/assets/codeMirrorModule-C3UTv-Ge.css +0 -1
  305. package/.playwright/package/lib/vite/recorder/assets/codeMirrorModule-k-61wZCK.js +0 -24
  306. package/.playwright/package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  307. package/.playwright/package/lib/vite/recorder/assets/index-B70BEW3b.js +0 -184
  308. package/.playwright/package/lib/vite/recorder/assets/index-eHBmevrY.css +0 -1
  309. package/.playwright/package/lib/vite/recorder/index.html +0 -29
  310. package/.playwright/package/lib/vite/recorder/playwright-logo.svg +0 -9
  311. package/.playwright/package/lib/vite/traceViewer/assets/codeMirrorModule-CyuxU5C-.js +0 -24
  312. package/.playwright/package/lib/vite/traceViewer/assets/defaultSettingsView-5nVJRt0A.js +0 -243
  313. package/.playwright/package/lib/vite/traceViewer/assets/xtermModule-c-SNdYZy.js +0 -9
  314. package/.playwright/package/lib/vite/traceViewer/codeMirrorModule.C3UTv-Ge.css +0 -1
  315. package/.playwright/package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  316. package/.playwright/package/lib/vite/traceViewer/defaultSettingsView.2xeEXCXv.css +0 -1
  317. package/.playwright/package/lib/vite/traceViewer/index.CFOW-Ezb.css +0 -1
  318. package/.playwright/package/lib/vite/traceViewer/index.html +0 -43
  319. package/.playwright/package/lib/vite/traceViewer/index.qVn2ZnpC.js +0 -2
  320. package/.playwright/package/lib/vite/traceViewer/playwright-logo.svg +0 -9
  321. package/.playwright/package/lib/vite/traceViewer/snapshot.html +0 -21
  322. package/.playwright/package/lib/vite/traceViewer/sw.bundle.js +0 -3
  323. package/.playwright/package/lib/vite/traceViewer/uiMode.BatfzHMG.css +0 -1
  324. package/.playwright/package/lib/vite/traceViewer/uiMode.html +0 -17
  325. package/.playwright/package/lib/vite/traceViewer/uiMode.m4IPRPOd.js +0 -5
  326. package/.playwright/package/lib/vite/traceViewer/xtermModule.Beg8tuEN.css +0 -32
  327. package/.playwright/package/lib/zipBundle.js +0 -25
  328. package/.playwright/package/lib/zipBundleImpl.js +0 -5
  329. package/.playwright/package/package.json +0 -44
  330. package/.playwright/package/protocol.yml +0 -3758
  331. package/.playwright/package/types/protocol.d.ts +0 -21868
  332. package/.playwright/package/types/structs.d.ts +0 -45
  333. package/.playwright/package/types/types.d.ts +0 -22663
  334. package/et +0 -0
  335. package/install.js +0 -19
  336. package/playwright.ps1 +0 -7
  337. package/scripts/playwright-bridge.js +0 -560
@@ -1,767 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.CRNetworkManager = void 0;
7
- var _helper = require("../helper");
8
- var _eventsHelper = require("../../utils/eventsHelper");
9
- var network = _interopRequireWildcard(require("../network"));
10
- var _utils = require("../../utils");
11
- var _protocolError = require("../protocolError");
12
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
13
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
14
- /**
15
- * Copyright 2017 Google Inc. All rights reserved.
16
- * Modifications copyright (c) Microsoft Corporation.
17
- *
18
- * Licensed under the Apache License, Version 2.0 (the "License");
19
- * you may not use this file except in compliance with the License.
20
- * You may obtain a copy of the License at
21
- *
22
- * http://www.apache.org/licenses/LICENSE-2.0
23
- *
24
- * Unless required by applicable law or agreed to in writing, software
25
- * distributed under the License is distributed on an "AS IS" BASIS,
26
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
27
- * See the License for the specific language governing permissions and
28
- * limitations under the License.
29
- */
30
-
31
- class CRNetworkManager {
32
- constructor(page, serviceWorker) {
33
- this._page = void 0;
34
- this._serviceWorker = void 0;
35
- this._requestIdToRequest = new Map();
36
- this._requestIdToRequestWillBeSentEvent = new Map();
37
- this._credentials = null;
38
- this._attemptedAuthentications = new Set();
39
- this._userRequestInterceptionEnabled = false;
40
- this._protocolRequestInterceptionEnabled = false;
41
- this._offline = false;
42
- this._extraHTTPHeaders = [];
43
- this._requestIdToRequestPausedEvent = new Map();
44
- this._responseExtraInfoTracker = new ResponseExtraInfoTracker();
45
- this._sessions = new Map();
46
- this._page = page;
47
- this._serviceWorker = serviceWorker;
48
- }
49
- async addSession(session, workerFrame, isMain) {
50
- const sessionInfo = {
51
- session,
52
- isMain,
53
- workerFrame,
54
- eventListeners: []
55
- };
56
- sessionInfo.eventListeners = [_eventsHelper.eventsHelper.addEventListener(session, 'Fetch.requestPaused', this._onRequestPaused.bind(this, sessionInfo)), _eventsHelper.eventsHelper.addEventListener(session, 'Fetch.authRequired', this._onAuthRequired.bind(this, sessionInfo)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.requestWillBeSent', this._onRequestWillBeSent.bind(this, sessionInfo)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.requestWillBeSentExtraInfo', this._onRequestWillBeSentExtraInfo.bind(this)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.requestServedFromCache', this._onRequestServedFromCache.bind(this)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.responseReceived', this._onResponseReceived.bind(this, sessionInfo)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.responseReceivedExtraInfo', this._onResponseReceivedExtraInfo.bind(this)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.loadingFinished', this._onLoadingFinished.bind(this, sessionInfo)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.loadingFailed', this._onLoadingFailed.bind(this, sessionInfo))];
57
- if (this._page) {
58
- sessionInfo.eventListeners.push(...[_eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketCreated', e => this._page._frameManager.onWebSocketCreated(e.requestId, e.url)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketWillSendHandshakeRequest', e => this._page._frameManager.onWebSocketRequest(e.requestId)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketHandshakeResponseReceived', e => this._page._frameManager.onWebSocketResponse(e.requestId, e.response.status, e.response.statusText)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketFrameSent', e => e.response.payloadData && this._page._frameManager.onWebSocketFrameSent(e.requestId, e.response.opcode, e.response.payloadData)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketFrameReceived', e => e.response.payloadData && this._page._frameManager.webSocketFrameReceived(e.requestId, e.response.opcode, e.response.payloadData)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketClosed', e => this._page._frameManager.webSocketClosed(e.requestId)), _eventsHelper.eventsHelper.addEventListener(session, 'Network.webSocketFrameError', e => this._page._frameManager.webSocketError(e.requestId, e.errorMessage))]);
59
- }
60
- this._sessions.set(session, sessionInfo);
61
- await Promise.all([session.send('Network.enable'), this._updateProtocolRequestInterceptionForSession(sessionInfo, true /* initial */), this._setOfflineForSession(sessionInfo, true /* initial */), this._setExtraHTTPHeadersForSession(sessionInfo, true /* initial */)]);
62
- }
63
- removeSession(session) {
64
- const info = this._sessions.get(session);
65
- if (info) _eventsHelper.eventsHelper.removeEventListeners(info.eventListeners);
66
- this._sessions.delete(session);
67
- }
68
- async _forEachSession(cb) {
69
- await Promise.all([...this._sessions.values()].map(info => {
70
- if (info.isMain) return cb(info);
71
- return cb(info).catch(e => {
72
- // Broadcasting a message to the closed target should be a noop.
73
- if ((0, _protocolError.isSessionClosedError)(e)) return;
74
- throw e;
75
- });
76
- }));
77
- }
78
- async authenticate(credentials) {
79
- this._credentials = credentials;
80
- await this._updateProtocolRequestInterception();
81
- }
82
- async setOffline(offline) {
83
- if (offline === this._offline) return;
84
- this._offline = offline;
85
- await this._forEachSession(info => this._setOfflineForSession(info));
86
- }
87
- async _setOfflineForSession(info, initial) {
88
- if (initial && !this._offline) return;
89
- // Workers are affected by the owner frame's Network.emulateNetworkConditions.
90
- if (info.workerFrame) return;
91
- await info.session.send('Network.emulateNetworkConditions', {
92
- offline: this._offline,
93
- // values of 0 remove any active throttling. crbug.com/456324#c9
94
- latency: 0,
95
- downloadThroughput: -1,
96
- uploadThroughput: -1
97
- });
98
- }
99
- async setRequestInterception(value) {
100
- this._userRequestInterceptionEnabled = value;
101
- await this._updateProtocolRequestInterception();
102
- }
103
- async _updateProtocolRequestInterception() {
104
- const enabled = this._userRequestInterceptionEnabled || !!this._credentials;
105
- if (enabled === this._protocolRequestInterceptionEnabled) return;
106
- this._protocolRequestInterceptionEnabled = enabled;
107
- await this._forEachSession(info => this._updateProtocolRequestInterceptionForSession(info));
108
- }
109
- async _updateProtocolRequestInterceptionForSession(info, initial) {
110
- const enabled = this._protocolRequestInterceptionEnabled;
111
- if (initial && !enabled) return;
112
- const cachePromise = info.session.send('Network.setCacheDisabled', {
113
- cacheDisabled: enabled
114
- });
115
- let fetchPromise = Promise.resolve(undefined);
116
- if (!info.workerFrame) {
117
- if (enabled) fetchPromise = info.session.send('Fetch.enable', {
118
- handleAuthRequests: true,
119
- patterns: [{
120
- urlPattern: '*',
121
- requestStage: 'Request'
122
- }]
123
- });else fetchPromise = info.session.send('Fetch.disable');
124
- }
125
- await Promise.all([cachePromise, fetchPromise]);
126
- }
127
- async setExtraHTTPHeaders(extraHTTPHeaders) {
128
- if (!this._extraHTTPHeaders.length && !extraHTTPHeaders.length) return;
129
- this._extraHTTPHeaders = extraHTTPHeaders;
130
- await this._forEachSession(info => this._setExtraHTTPHeadersForSession(info));
131
- }
132
- async _setExtraHTTPHeadersForSession(info, initial) {
133
- if (initial && !this._extraHTTPHeaders.length) return;
134
- await info.session.send('Network.setExtraHTTPHeaders', {
135
- headers: (0, _utils.headersArrayToObject)(this._extraHTTPHeaders, false /* lowerCase */)
136
- });
137
- }
138
- async clearCache() {
139
- await this._forEachSession(async info => {
140
- // Sending 'Network.setCacheDisabled' with 'cacheDisabled = true' will clear the MemoryCache.
141
- await info.session.send('Network.setCacheDisabled', {
142
- cacheDisabled: true
143
- });
144
- if (!this._protocolRequestInterceptionEnabled) await info.session.send('Network.setCacheDisabled', {
145
- cacheDisabled: false
146
- });
147
- if (!info.workerFrame) await info.session.send('Network.clearBrowserCache');
148
- });
149
- }
150
- _onRequestWillBeSent(sessionInfo, event) {
151
- // Request interception doesn't happen for data URLs with Network Service.
152
- if (this._protocolRequestInterceptionEnabled && !event.request.url.startsWith('data:')) {
153
- const requestId = event.requestId;
154
- const requestPausedEvent = this._requestIdToRequestPausedEvent.get(requestId);
155
- if (requestPausedEvent) {
156
- this._onRequest(sessionInfo, event, requestPausedEvent.sessionInfo, requestPausedEvent.event);
157
- this._requestIdToRequestPausedEvent.delete(requestId);
158
- } else {
159
- this._requestIdToRequestWillBeSentEvent.set(event.requestId, {
160
- sessionInfo,
161
- event
162
- });
163
- }
164
- } else {
165
- this._onRequest(sessionInfo, event, undefined, undefined);
166
- }
167
- }
168
- _onRequestServedFromCache(event) {
169
- this._responseExtraInfoTracker.requestServedFromCache(event);
170
- }
171
- _onRequestWillBeSentExtraInfo(event) {
172
- this._responseExtraInfoTracker.requestWillBeSentExtraInfo(event);
173
- }
174
- _onAuthRequired(sessionInfo, event) {
175
- let response = 'Default';
176
- const shouldProvideCredentials = this._shouldProvideCredentials(event.request.url);
177
- if (this._attemptedAuthentications.has(event.requestId)) {
178
- response = 'CancelAuth';
179
- } else if (shouldProvideCredentials) {
180
- response = 'ProvideCredentials';
181
- this._attemptedAuthentications.add(event.requestId);
182
- }
183
- const {
184
- username,
185
- password
186
- } = shouldProvideCredentials && this._credentials ? this._credentials : {
187
- username: undefined,
188
- password: undefined
189
- };
190
- sessionInfo.session._sendMayFail('Fetch.continueWithAuth', {
191
- requestId: event.requestId,
192
- authChallengeResponse: {
193
- response,
194
- username,
195
- password
196
- }
197
- });
198
- }
199
- _shouldProvideCredentials(url) {
200
- if (!this._credentials) return false;
201
- return !this._credentials.origin || new URL(url).origin.toLowerCase() === this._credentials.origin.toLowerCase();
202
- }
203
- _onRequestPaused(sessionInfo, event) {
204
- if (!event.networkId) {
205
- // Fetch without networkId means that request was not recognized by inspector, and
206
- // it will never receive Network.requestWillBeSent. Continue the request to not affect it.
207
- sessionInfo.session._sendMayFail('Fetch.continueRequest', {
208
- requestId: event.requestId
209
- });
210
- return;
211
- }
212
- if (event.request.url.startsWith('data:')) return;
213
- const requestId = event.networkId;
214
- const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(requestId);
215
- if (requestWillBeSentEvent) {
216
- this._onRequest(requestWillBeSentEvent.sessionInfo, requestWillBeSentEvent.event, sessionInfo, event);
217
- this._requestIdToRequestWillBeSentEvent.delete(requestId);
218
- } else {
219
- var _existingRequest$_rou;
220
- const existingRequest = this._requestIdToRequest.get(requestId);
221
- const alreadyContinuedParams = existingRequest === null || existingRequest === void 0 || (_existingRequest$_rou = existingRequest._route) === null || _existingRequest$_rou === void 0 ? void 0 : _existingRequest$_rou._alreadyContinuedParams;
222
- if (alreadyContinuedParams && !event.redirectedRequestId) {
223
- // Sometimes Chromium network stack restarts the request internally.
224
- // For example, when no-cors request hits a "less public address space", it should be resent with cors.
225
- // There are some more examples here: https://source.chromium.org/chromium/chromium/src/+/main:services/network/url_loader.cc;l=1205-1234;drc=d5dd931e0ad3d9ffe74888ec62a3cc106efd7ea6
226
- // There are probably even more cases deep inside the network stack.
227
- //
228
- // Anyway, in this case, continue the request in the same way as before, and it should go through.
229
- //
230
- // Note: make sure not to prematurely continue the redirect, which shares the
231
- // `networkId` between the original request and the redirect.
232
- sessionInfo.session._sendMayFail('Fetch.continueRequest', {
233
- ...alreadyContinuedParams,
234
- requestId: event.requestId
235
- });
236
- return;
237
- }
238
- this._requestIdToRequestPausedEvent.set(requestId, {
239
- sessionInfo,
240
- event
241
- });
242
- }
243
- }
244
- _onRequest(requestWillBeSentSessionInfo, requestWillBeSentEvent, requestPausedSessionInfo, requestPausedEvent) {
245
- var _this$_page, _this$_page2, _this$_page3;
246
- if (requestWillBeSentEvent.request.url.startsWith('data:')) return;
247
- let redirectedFrom = null;
248
- if (requestWillBeSentEvent.redirectResponse) {
249
- const request = this._requestIdToRequest.get(requestWillBeSentEvent.requestId);
250
- // If we connect late to the target, we could have missed the requestWillBeSent event.
251
- if (request) {
252
- this._handleRequestRedirect(request, requestWillBeSentEvent.redirectResponse, requestWillBeSentEvent.timestamp, requestWillBeSentEvent.redirectHasExtraInfo);
253
- redirectedFrom = request;
254
- }
255
- }
256
- let frame = requestWillBeSentEvent.frameId ? (_this$_page = this._page) === null || _this$_page === void 0 ? void 0 : _this$_page._frameManager.frame(requestWillBeSentEvent.frameId) : requestWillBeSentSessionInfo.workerFrame;
257
- // Requests from workers lack frameId, because we receive Network.requestWillBeSent
258
- // on the worker target. However, we receive Fetch.requestPaused on the page target,
259
- // and lack workerFrame there. Luckily, Fetch.requestPaused provides a frameId.
260
- if (!frame && this._page && requestPausedEvent && requestPausedEvent.frameId) frame = this._page._frameManager.frame(requestPausedEvent.frameId);
261
-
262
- // Check if it's main resource request interception (targetId === main frame id).
263
- if (!frame && this._page && requestWillBeSentEvent.frameId === ((_this$_page2 = this._page) === null || _this$_page2 === void 0 ? void 0 : _this$_page2._delegate)._targetId) {
264
- // Main resource request for the page is being intercepted so the Frame is not created
265
- // yet. Precreate it here for the purposes of request interception. It will be updated
266
- // later as soon as the request continues and we receive frame tree from the page.
267
- frame = this._page._frameManager.frameAttached(requestWillBeSentEvent.frameId, null);
268
- }
269
-
270
- // CORS options preflight request is generated by the network stack. If interception is enabled,
271
- // we accept all CORS options, assuming that this was intended when setting route.
272
- //
273
- // Note: it would be better to match the URL against interception patterns.
274
- const isInterceptedOptionsPreflight = !!requestPausedEvent && requestPausedEvent.request.method === 'OPTIONS' && requestWillBeSentEvent.initiator.type === 'preflight';
275
- if (isInterceptedOptionsPreflight && (this._page || this._serviceWorker).needsRequestInterception()) {
276
- const requestHeaders = requestPausedEvent.request.headers;
277
- const responseHeaders = [{
278
- name: 'Access-Control-Allow-Origin',
279
- value: requestHeaders['Origin'] || '*'
280
- }, {
281
- name: 'Access-Control-Allow-Methods',
282
- value: requestHeaders['Access-Control-Request-Method'] || 'GET, POST, OPTIONS, DELETE'
283
- }, {
284
- name: 'Access-Control-Allow-Credentials',
285
- value: 'true'
286
- }];
287
- if (requestHeaders['Access-Control-Request-Headers']) responseHeaders.push({
288
- name: 'Access-Control-Allow-Headers',
289
- value: requestHeaders['Access-Control-Request-Headers']
290
- });
291
- requestPausedSessionInfo.session._sendMayFail('Fetch.fulfillRequest', {
292
- requestId: requestPausedEvent.requestId,
293
- responseCode: 204,
294
- responsePhrase: network.statusText(204),
295
- responseHeaders,
296
- body: ''
297
- });
298
- return;
299
- }
300
-
301
- // Non-service-worker requests MUST have a frame—if they don't, we pretend there was no request
302
- if (!frame && !this._serviceWorker) {
303
- if (requestPausedEvent) requestPausedSessionInfo.session._sendMayFail('Fetch.continueRequest', {
304
- requestId: requestPausedEvent.requestId
305
- });
306
- return;
307
- }
308
- let route = null;
309
- let headersOverride;
310
- if (requestPausedEvent) {
311
- // We do not support intercepting redirects.
312
- if (redirectedFrom || !this._userRequestInterceptionEnabled && this._protocolRequestInterceptionEnabled) {
313
- var _redirectedFrom;
314
- // Chromium does not preserve header overrides between redirects, so we have to do it ourselves.
315
- headersOverride = (_redirectedFrom = redirectedFrom) === null || _redirectedFrom === void 0 || (_redirectedFrom = _redirectedFrom._originalRequestRoute) === null || _redirectedFrom === void 0 || (_redirectedFrom = _redirectedFrom._alreadyContinuedParams) === null || _redirectedFrom === void 0 ? void 0 : _redirectedFrom.headers;
316
- requestPausedSessionInfo.session._sendMayFail('Fetch.continueRequest', {
317
- requestId: requestPausedEvent.requestId,
318
- headers: headersOverride
319
- });
320
- } else {
321
- route = new RouteImpl(requestPausedSessionInfo.session, requestPausedEvent.requestId);
322
- }
323
- }
324
- const isNavigationRequest = requestWillBeSentEvent.requestId === requestWillBeSentEvent.loaderId && requestWillBeSentEvent.type === 'Document';
325
- const documentId = isNavigationRequest ? requestWillBeSentEvent.loaderId : undefined;
326
- const request = new InterceptableRequest({
327
- session: requestWillBeSentSessionInfo.session,
328
- context: (this._page || this._serviceWorker)._browserContext,
329
- frame: frame || null,
330
- serviceWorker: this._serviceWorker || null,
331
- documentId,
332
- route,
333
- requestWillBeSentEvent,
334
- requestPausedEvent,
335
- redirectedFrom,
336
- headersOverride: headersOverride || null
337
- });
338
- this._requestIdToRequest.set(requestWillBeSentEvent.requestId, request);
339
- if (route) {
340
- // We may not receive extra info when intercepting the request.
341
- // Use the headers from the Fetch.requestPausedPayload and release the allHeaders()
342
- // right away, so that client can call it from the route handler.
343
- request.request.setRawRequestHeaders((0, _utils.headersObjectToArray)(requestPausedEvent.request.headers, '\n'));
344
- }
345
- (((_this$_page3 = this._page) === null || _this$_page3 === void 0 ? void 0 : _this$_page3._frameManager) || this._serviceWorker).requestStarted(request.request, route || undefined);
346
- }
347
- _createResponse(request, responsePayload, hasExtraInfo) {
348
- var _responsePayload$secu, _responsePayload$secu2, _responsePayload$secu3, _responsePayload$secu4, _responsePayload$secu5;
349
- const getResponseBody = async () => {
350
- var _request$_route;
351
- const contentLengthHeader = Object.entries(responsePayload.headers).find(header => header[0].toLowerCase() === 'content-length');
352
- const expectedLength = contentLengthHeader ? +contentLengthHeader[1] : undefined;
353
- const session = request.session;
354
- const response = await session.send('Network.getResponseBody', {
355
- requestId: request._requestId
356
- });
357
- if (response.body || !expectedLength) return Buffer.from(response.body, response.base64Encoded ? 'base64' : 'utf8');
358
-
359
- // Make sure no network requests sent while reading the body for fulfilled requests.
360
- if ((_request$_route = request._route) !== null && _request$_route !== void 0 && _request$_route._fulfilled) return Buffer.from('');
361
-
362
- // For <link prefetch we are going to receive empty body with non-empty content-length expectation. Reach out for the actual content.
363
- const resource = await session.send('Network.loadNetworkResource', {
364
- url: request.request.url(),
365
- frameId: this._serviceWorker ? undefined : request.request.frame()._id,
366
- options: {
367
- disableCache: false,
368
- includeCredentials: true
369
- }
370
- });
371
- const chunks = [];
372
- while (resource.resource.stream) {
373
- const chunk = await session.send('IO.read', {
374
- handle: resource.resource.stream
375
- });
376
- chunks.push(Buffer.from(chunk.data, chunk.base64Encoded ? 'base64' : 'utf-8'));
377
- if (chunk.eof) {
378
- await session.send('IO.close', {
379
- handle: resource.resource.stream
380
- });
381
- break;
382
- }
383
- }
384
- return Buffer.concat(chunks);
385
- };
386
- const timingPayload = responsePayload.timing;
387
- let timing;
388
- if (timingPayload && !this._responseExtraInfoTracker.servedFromCache(request._requestId)) {
389
- timing = {
390
- startTime: (timingPayload.requestTime - request._timestamp + request._wallTime) * 1000,
391
- domainLookupStart: timingPayload.dnsStart,
392
- domainLookupEnd: timingPayload.dnsEnd,
393
- connectStart: timingPayload.connectStart,
394
- secureConnectionStart: timingPayload.sslStart,
395
- connectEnd: timingPayload.connectEnd,
396
- requestStart: timingPayload.sendStart,
397
- responseStart: timingPayload.receiveHeadersEnd
398
- };
399
- } else {
400
- timing = {
401
- startTime: request._wallTime * 1000,
402
- domainLookupStart: -1,
403
- domainLookupEnd: -1,
404
- connectStart: -1,
405
- secureConnectionStart: -1,
406
- connectEnd: -1,
407
- requestStart: -1,
408
- responseStart: -1
409
- };
410
- }
411
- const response = new network.Response(request.request, responsePayload.status, responsePayload.statusText, (0, _utils.headersObjectToArray)(responsePayload.headers), timing, getResponseBody, !!responsePayload.fromServiceWorker, responsePayload.protocol);
412
- if (responsePayload !== null && responsePayload !== void 0 && responsePayload.remoteIPAddress && typeof (responsePayload === null || responsePayload === void 0 ? void 0 : responsePayload.remotePort) === 'number') {
413
- response._serverAddrFinished({
414
- ipAddress: responsePayload.remoteIPAddress,
415
- port: responsePayload.remotePort
416
- });
417
- } else {
418
- response._serverAddrFinished();
419
- }
420
- response._securityDetailsFinished({
421
- protocol: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu = responsePayload.securityDetails) === null || _responsePayload$secu === void 0 ? void 0 : _responsePayload$secu.protocol,
422
- subjectName: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu2 = responsePayload.securityDetails) === null || _responsePayload$secu2 === void 0 ? void 0 : _responsePayload$secu2.subjectName,
423
- issuer: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu3 = responsePayload.securityDetails) === null || _responsePayload$secu3 === void 0 ? void 0 : _responsePayload$secu3.issuer,
424
- validFrom: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu4 = responsePayload.securityDetails) === null || _responsePayload$secu4 === void 0 ? void 0 : _responsePayload$secu4.validFrom,
425
- validTo: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu5 = responsePayload.securityDetails) === null || _responsePayload$secu5 === void 0 ? void 0 : _responsePayload$secu5.validTo
426
- });
427
- this._responseExtraInfoTracker.processResponse(request._requestId, response, hasExtraInfo);
428
- return response;
429
- }
430
- _deleteRequest(request) {
431
- this._requestIdToRequest.delete(request._requestId);
432
- if (request._interceptionId) this._attemptedAuthentications.delete(request._interceptionId);
433
- }
434
- _handleRequestRedirect(request, responsePayload, timestamp, hasExtraInfo) {
435
- var _this$_page4, _this$_page5;
436
- const response = this._createResponse(request, responsePayload, hasExtraInfo);
437
- response.setTransferSize(null);
438
- response.setEncodedBodySize(null);
439
- response._requestFinished((timestamp - request._timestamp) * 1000);
440
- this._deleteRequest(request);
441
- (((_this$_page4 = this._page) === null || _this$_page4 === void 0 ? void 0 : _this$_page4._frameManager) || this._serviceWorker).requestReceivedResponse(response);
442
- (((_this$_page5 = this._page) === null || _this$_page5 === void 0 ? void 0 : _this$_page5._frameManager) || this._serviceWorker).reportRequestFinished(request.request, response);
443
- }
444
- _onResponseReceivedExtraInfo(event) {
445
- this._responseExtraInfoTracker.responseReceivedExtraInfo(event);
446
- }
447
- _onResponseReceived(sessionInfo, event) {
448
- var _this$_page6;
449
- let request = this._requestIdToRequest.get(event.requestId);
450
- // For frame-level Requests that are handled by a Service Worker's fetch handler, we'll never get a requestPaused event, so we need to
451
- // manually create the request. In an ideal world, crNetworkManager would be able to know this on Network.requestWillBeSent, but there
452
- // is not enough metadata there.
453
- if (!request && event.response.fromServiceWorker) {
454
- const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(event.requestId);
455
- if (requestWillBeSentEvent) {
456
- this._requestIdToRequestWillBeSentEvent.delete(event.requestId);
457
- this._onRequest(sessionInfo, requestWillBeSentEvent.event, undefined, undefined);
458
- request = this._requestIdToRequest.get(event.requestId);
459
- }
460
- }
461
- // FileUpload sends a response without a matching request.
462
- if (!request) return;
463
- const response = this._createResponse(request, event.response, event.hasExtraInfo);
464
- (((_this$_page6 = this._page) === null || _this$_page6 === void 0 ? void 0 : _this$_page6._frameManager) || this._serviceWorker).requestReceivedResponse(response);
465
- }
466
- _onLoadingFinished(sessionInfo, event) {
467
- var _this$_page7;
468
- this._responseExtraInfoTracker.loadingFinished(event);
469
- const request = this._requestIdToRequest.get(event.requestId);
470
- // For certain requestIds we never receive requestWillBeSent event.
471
- // @see https://crbug.com/750469
472
- if (!request) return;
473
- this._maybeUpdateOOPIFMainRequest(sessionInfo, request);
474
-
475
- // Under certain conditions we never get the Network.responseReceived
476
- // event from protocol. @see https://crbug.com/883475
477
- const response = request.request._existingResponse();
478
- if (response) {
479
- response.setTransferSize(event.encodedDataLength);
480
- response.responseHeadersSize().then(size => response.setEncodedBodySize(event.encodedDataLength - size));
481
- response._requestFinished(_helper.helper.secondsToRoundishMillis(event.timestamp - request._timestamp));
482
- }
483
- this._deleteRequest(request);
484
- (((_this$_page7 = this._page) === null || _this$_page7 === void 0 ? void 0 : _this$_page7._frameManager) || this._serviceWorker).reportRequestFinished(request.request, response);
485
- }
486
- _onLoadingFailed(sessionInfo, event) {
487
- var _this$_page8;
488
- this._responseExtraInfoTracker.loadingFailed(event);
489
- let request = this._requestIdToRequest.get(event.requestId);
490
- if (!request) {
491
- const requestWillBeSentEvent = this._requestIdToRequestWillBeSentEvent.get(event.requestId);
492
- if (requestWillBeSentEvent) {
493
- // This is a case where request has failed before we had a chance to intercept it.
494
- // We stop waiting for Fetch.requestPaused (it might never come), and dispatch request event
495
- // right away, followed by requestfailed event.
496
- this._requestIdToRequestWillBeSentEvent.delete(event.requestId);
497
- this._onRequest(sessionInfo, requestWillBeSentEvent.event, undefined, undefined);
498
- request = this._requestIdToRequest.get(event.requestId);
499
- }
500
- }
501
-
502
- // For certain requestIds we never receive requestWillBeSent event.
503
- // @see https://crbug.com/750469
504
- if (!request) return;
505
- this._maybeUpdateOOPIFMainRequest(sessionInfo, request);
506
- const response = request.request._existingResponse();
507
- if (response) {
508
- response.setTransferSize(null);
509
- response.setEncodedBodySize(null);
510
- response._requestFinished(_helper.helper.secondsToRoundishMillis(event.timestamp - request._timestamp));
511
- } else {
512
- // Loading failed before response has arrived - there will be no extra info events.
513
- request.request.setRawRequestHeaders(null);
514
- }
515
- this._deleteRequest(request);
516
- request.request._setFailureText(event.errorText || event.blockedReason || '');
517
- (((_this$_page8 = this._page) === null || _this$_page8 === void 0 ? void 0 : _this$_page8._frameManager) || this._serviceWorker).requestFailed(request.request, !!event.canceled);
518
- }
519
- _maybeUpdateOOPIFMainRequest(sessionInfo, request) {
520
- // OOPIF has a main request that starts in the parent session but finishes in the child session.
521
- // We check for the main request by matching loaderId and requestId, and if it now belongs to
522
- // a child session, migrate it there.
523
- if (request.session !== sessionInfo.session && !sessionInfo.isMain && request._documentId === request._requestId) request.session = sessionInfo.session;
524
- }
525
- }
526
- exports.CRNetworkManager = CRNetworkManager;
527
- class InterceptableRequest {
528
- constructor(options) {
529
- this.request = void 0;
530
- this._requestId = void 0;
531
- this._interceptionId = void 0;
532
- this._documentId = void 0;
533
- this._timestamp = void 0;
534
- this._wallTime = void 0;
535
- this._route = void 0;
536
- // Only first request in the chain can be intercepted, so this will
537
- // store the first and only Route in the chain (if any).
538
- this._originalRequestRoute = void 0;
539
- this.session = void 0;
540
- const {
541
- session,
542
- context,
543
- frame,
544
- documentId,
545
- route,
546
- requestWillBeSentEvent,
547
- requestPausedEvent,
548
- redirectedFrom,
549
- serviceWorker,
550
- headersOverride
551
- } = options;
552
- this.session = session;
553
- this._timestamp = requestWillBeSentEvent.timestamp;
554
- this._wallTime = requestWillBeSentEvent.wallTime;
555
- this._requestId = requestWillBeSentEvent.requestId;
556
- this._interceptionId = requestPausedEvent && requestPausedEvent.requestId;
557
- this._documentId = documentId;
558
- this._route = route;
559
- this._originalRequestRoute = route !== null && route !== void 0 ? route : redirectedFrom === null || redirectedFrom === void 0 ? void 0 : redirectedFrom._originalRequestRoute;
560
- const {
561
- headers,
562
- method,
563
- url,
564
- postDataEntries = null
565
- } = requestPausedEvent ? requestPausedEvent.request : requestWillBeSentEvent.request;
566
- const type = (requestWillBeSentEvent.type || '').toLowerCase();
567
- let postDataBuffer = null;
568
- const entries = postDataEntries === null || postDataEntries === void 0 ? void 0 : postDataEntries.filter(entry => entry.bytes);
569
- if (entries && entries.length) postDataBuffer = Buffer.concat(entries.map(entry => Buffer.from(entry.bytes, 'base64')));
570
- this.request = new network.Request(context, frame, serviceWorker, (redirectedFrom === null || redirectedFrom === void 0 ? void 0 : redirectedFrom.request) || null, documentId, url, type, method, postDataBuffer, headersOverride || (0, _utils.headersObjectToArray)(headers));
571
- }
572
- }
573
- class RouteImpl {
574
- constructor(session, interceptionId) {
575
- this._session = void 0;
576
- this._interceptionId = void 0;
577
- this._alreadyContinuedParams = void 0;
578
- this._fulfilled = false;
579
- this._session = session;
580
- this._interceptionId = interceptionId;
581
- }
582
- async continue(overrides) {
583
- this._alreadyContinuedParams = {
584
- requestId: this._interceptionId,
585
- url: overrides.url,
586
- headers: overrides.headers,
587
- method: overrides.method,
588
- postData: overrides.postData ? overrides.postData.toString('base64') : undefined
589
- };
590
- await catchDisallowedErrors(async () => {
591
- await this._session.send('Fetch.continueRequest', this._alreadyContinuedParams);
592
- });
593
- }
594
- async fulfill(response) {
595
- this._fulfilled = true;
596
- const body = response.isBase64 ? response.body : Buffer.from(response.body).toString('base64');
597
- const responseHeaders = splitSetCookieHeader(response.headers);
598
- await catchDisallowedErrors(async () => {
599
- await this._session.send('Fetch.fulfillRequest', {
600
- requestId: this._interceptionId,
601
- responseCode: response.status,
602
- responsePhrase: network.statusText(response.status),
603
- responseHeaders,
604
- body
605
- });
606
- });
607
- }
608
- async abort(errorCode = 'failed') {
609
- const errorReason = errorReasons[errorCode];
610
- (0, _utils.assert)(errorReason, 'Unknown error code: ' + errorCode);
611
- await catchDisallowedErrors(async () => {
612
- await this._session.send('Fetch.failRequest', {
613
- requestId: this._interceptionId,
614
- errorReason
615
- });
616
- });
617
- }
618
- }
619
-
620
- // In certain cases, protocol will return error if the request was already canceled
621
- // or the page was closed. We should tolerate these errors but propagate other.
622
- async function catchDisallowedErrors(callback) {
623
- try {
624
- return await callback();
625
- } catch (e) {
626
- if ((0, _protocolError.isProtocolError)(e) && e.message.includes('Invalid http status code or phrase')) throw e;
627
- }
628
- }
629
- function splitSetCookieHeader(headers) {
630
- const index = headers.findIndex(({
631
- name
632
- }) => name.toLowerCase() === 'set-cookie');
633
- if (index === -1) return headers;
634
- const header = headers[index];
635
- const values = header.value.split('\n');
636
- if (values.length === 1) return headers;
637
- const result = headers.slice();
638
- result.splice(index, 1, ...values.map(value => ({
639
- name: header.name,
640
- value
641
- })));
642
- return result;
643
- }
644
- const errorReasons = {
645
- 'aborted': 'Aborted',
646
- 'accessdenied': 'AccessDenied',
647
- 'addressunreachable': 'AddressUnreachable',
648
- 'blockedbyclient': 'BlockedByClient',
649
- 'blockedbyresponse': 'BlockedByResponse',
650
- 'connectionaborted': 'ConnectionAborted',
651
- 'connectionclosed': 'ConnectionClosed',
652
- 'connectionfailed': 'ConnectionFailed',
653
- 'connectionrefused': 'ConnectionRefused',
654
- 'connectionreset': 'ConnectionReset',
655
- 'internetdisconnected': 'InternetDisconnected',
656
- 'namenotresolved': 'NameNotResolved',
657
- 'timedout': 'TimedOut',
658
- 'failed': 'Failed'
659
- };
660
- // This class aligns responses with response headers from extra info:
661
- // - Network.requestWillBeSent, Network.responseReceived, Network.loadingFinished/loadingFailed are
662
- // dispatched using one channel.
663
- // - Network.requestWillBeSentExtraInfo and Network.responseReceivedExtraInfo are dispatched on
664
- // another channel. Those channels are not associated, so events come in random order.
665
- //
666
- // This class will associate responses with the new headers. These extra info headers will become
667
- // available to client reliably upon requestfinished event only. It consumes CDP
668
- // signals on one end and processResponse(network.Response) signals on the other hands. It then makes
669
- // sure that responses have all the extra headers in place by the time request finishes.
670
- //
671
- // The shape of the instrumentation API is deliberately following the CDP, so that it
672
- // is clear what is called when and what this means to the tracker without extra
673
- // documentation.
674
- class ResponseExtraInfoTracker {
675
- constructor() {
676
- this._requests = new Map();
677
- }
678
- requestWillBeSentExtraInfo(event) {
679
- const info = this._getOrCreateEntry(event.requestId);
680
- info.requestWillBeSentExtraInfo.push(event);
681
- this._patchHeaders(info, info.requestWillBeSentExtraInfo.length - 1);
682
- this._checkFinished(info);
683
- }
684
- requestServedFromCache(event) {
685
- const info = this._getOrCreateEntry(event.requestId);
686
- info.servedFromCache = true;
687
- }
688
- servedFromCache(requestId) {
689
- const info = this._requests.get(requestId);
690
- return !!(info !== null && info !== void 0 && info.servedFromCache);
691
- }
692
- responseReceivedExtraInfo(event) {
693
- const info = this._getOrCreateEntry(event.requestId);
694
- info.responseReceivedExtraInfo.push(event);
695
- this._patchHeaders(info, info.responseReceivedExtraInfo.length - 1);
696
- this._checkFinished(info);
697
- }
698
- processResponse(requestId, response, hasExtraInfo) {
699
- var _info;
700
- let info = this._requests.get(requestId);
701
- // Cached responses have erroneous "hasExtraInfo" flag.
702
- // https://bugs.chromium.org/p/chromium/issues/detail?id=1340398
703
- if (!hasExtraInfo || (_info = info) !== null && _info !== void 0 && _info.servedFromCache) {
704
- // Use "provisional" headers as "raw" ones.
705
- response.request().setRawRequestHeaders(null);
706
- response.setResponseHeadersSize(null);
707
- response.setRawResponseHeaders(null);
708
- return;
709
- }
710
- info = this._getOrCreateEntry(requestId);
711
- info.responses.push(response);
712
- this._patchHeaders(info, info.responses.length - 1);
713
- }
714
- loadingFinished(event) {
715
- const info = this._requests.get(event.requestId);
716
- if (!info) return;
717
- info.loadingFinished = event;
718
- this._checkFinished(info);
719
- }
720
- loadingFailed(event) {
721
- const info = this._requests.get(event.requestId);
722
- if (!info) return;
723
- info.loadingFailed = event;
724
- this._checkFinished(info);
725
- }
726
- _getOrCreateEntry(requestId) {
727
- let info = this._requests.get(requestId);
728
- if (!info) {
729
- info = {
730
- requestId: requestId,
731
- requestWillBeSentExtraInfo: [],
732
- responseReceivedExtraInfo: [],
733
- responses: []
734
- };
735
- this._requests.set(requestId, info);
736
- }
737
- return info;
738
- }
739
- _patchHeaders(info, index) {
740
- const response = info.responses[index];
741
- const requestExtraInfo = info.requestWillBeSentExtraInfo[index];
742
- if (response && requestExtraInfo) {
743
- response.request().setRawRequestHeaders((0, _utils.headersObjectToArray)(requestExtraInfo.headers, '\n'));
744
- info.requestWillBeSentExtraInfo[index] = undefined;
745
- }
746
- const responseExtraInfo = info.responseReceivedExtraInfo[index];
747
- if (response && responseExtraInfo) {
748
- var _responseExtraInfo$he;
749
- response.setResponseHeadersSize(((_responseExtraInfo$he = responseExtraInfo.headersText) === null || _responseExtraInfo$he === void 0 ? void 0 : _responseExtraInfo$he.length) || 0);
750
- response.setRawResponseHeaders((0, _utils.headersObjectToArray)(responseExtraInfo.headers, '\n'));
751
- info.responseReceivedExtraInfo[index] = undefined;
752
- }
753
- }
754
- _checkFinished(info) {
755
- if (!info.loadingFinished && !info.loadingFailed) return;
756
- if (info.responses.length <= info.responseReceivedExtraInfo.length) {
757
- // We have extra info for each response.
758
- this._stopTracking(info.requestId);
759
- return;
760
- }
761
-
762
- // We are not done yet.
763
- }
764
- _stopTracking(requestId) {
765
- this._requests.delete(requestId);
766
- }
767
- }