patchright-core 1.48.2

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