patchright-core 1.51.2 → 1.52.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/browsers.json +15 -13
  2. package/lib/androidServerImpl.js +42 -48
  3. package/lib/browserServerImpl.js +54 -67
  4. package/lib/cli/driver.js +71 -69
  5. package/lib/cli/program.js +312 -328
  6. package/lib/cli/programWithTestStub.js +51 -45
  7. package/lib/client/accessibility.js +31 -32
  8. package/lib/client/android.js +141 -228
  9. package/lib/client/api.js +135 -283
  10. package/lib/client/artifact.js +39 -36
  11. package/lib/client/browser.js +57 -61
  12. package/lib/client/browserContext.js +297 -326
  13. package/lib/client/browserType.js +92 -106
  14. package/lib/client/cdpSession.js +29 -31
  15. package/lib/client/channelOwner.js +82 -95
  16. package/lib/client/clientHelper.js +46 -38
  17. package/lib/client/clientInstrumentation.js +40 -37
  18. package/lib/client/clientStackTrace.js +41 -37
  19. package/lib/client/clock.js +36 -36
  20. package/lib/client/connection.js +190 -212
  21. package/lib/client/consoleMessage.js +31 -28
  22. package/lib/client/coverage.js +25 -22
  23. package/lib/client/dialog.js +30 -31
  24. package/lib/client/download.js +25 -25
  25. package/lib/client/electron.js +73 -75
  26. package/lib/client/elementHandle.js +111 -147
  27. package/lib/client/errors.js +53 -53
  28. package/lib/client/eventEmitter.js +124 -121
  29. package/lib/client/events.js +72 -68
  30. package/lib/client/fetch.js +135 -158
  31. package/lib/client/fileChooser.js +25 -24
  32. package/lib/client/fileUtils.js +31 -28
  33. package/lib/client/frame.js +187 -306
  34. package/lib/client/harRouter.js +42 -52
  35. package/lib/client/input.js +40 -69
  36. package/lib/client/jsHandle.js +54 -69
  37. package/lib/client/jsonPipe.js +27 -23
  38. package/lib/client/localUtils.js +29 -28
  39. package/lib/client/locator.js +161 -245
  40. package/lib/client/network.js +277 -295
  41. package/lib/client/page.js +270 -318
  42. package/lib/client/platform.js +46 -43
  43. package/lib/client/playwright.js +51 -66
  44. package/lib/client/selectors.js +48 -46
  45. package/lib/client/stream.js +29 -25
  46. package/lib/client/timeoutSettings.js +49 -39
  47. package/lib/client/tracing.js +48 -84
  48. package/lib/client/types.js +26 -22
  49. package/lib/client/video.js +35 -27
  50. package/lib/client/waiter.js +69 -88
  51. package/lib/client/webError.js +25 -23
  52. package/lib/client/webSocket.js +61 -56
  53. package/lib/client/worker.js +48 -58
  54. package/lib/client/writableStream.js +27 -23
  55. package/lib/generated/clockSource.js +26 -5
  56. package/lib/generated/consoleApiSource.js +26 -5
  57. package/lib/generated/injectedScriptSource.js +26 -5
  58. package/lib/generated/pollingRecorderSource.js +26 -5
  59. package/lib/generated/utilityScriptSource.js +26 -5
  60. package/lib/generated/webSocketMockSource.js +375 -4
  61. package/lib/inProcessFactory.js +53 -53
  62. package/lib/inprocess.js +2 -19
  63. package/lib/outofprocess.js +53 -46
  64. package/lib/protocol/debug.js +209 -25
  65. package/lib/protocol/serializers.js +153 -134
  66. package/lib/protocol/validator.js +2714 -2714
  67. package/lib/protocol/validatorPrimitives.js +114 -73
  68. package/lib/remote/playwrightConnection.js +140 -157
  69. package/lib/remote/playwrightServer.js +99 -84
  70. package/lib/server/accessibility.js +44 -37
  71. package/lib/server/android/android.js +216 -209
  72. package/lib/server/android/backendAdb.js +89 -82
  73. package/lib/server/artifact.js +78 -55
  74. package/lib/server/bidi/bidiBrowser.js +221 -155
  75. package/lib/server/bidi/bidiChromium.js +106 -79
  76. package/lib/server/bidi/bidiConnection.js +66 -83
  77. package/lib/server/bidi/bidiExecutionContext.js +128 -113
  78. package/lib/server/bidi/bidiFirefox.js +76 -69
  79. package/lib/server/bidi/bidiInput.js +86 -97
  80. package/lib/server/bidi/bidiNetworkManager.js +137 -154
  81. package/lib/server/bidi/bidiOverCdp.js +57 -58
  82. package/lib/server/bidi/bidiPage.js +247 -219
  83. package/lib/server/bidi/bidiPdf.js +52 -86
  84. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
  85. package/lib/server/bidi/third_party/bidiDeserializer.js +55 -50
  86. package/lib/server/bidi/third_party/bidiKeyboard.js +236 -220
  87. package/lib/server/bidi/third_party/bidiProtocol.js +144 -131
  88. package/lib/server/bidi/third_party/bidiSerializer.js +67 -63
  89. package/lib/server/bidi/third_party/firefoxPrefs.js +141 -119
  90. package/lib/server/browser.js +76 -84
  91. package/lib/server/browserContext.js +321 -346
  92. package/lib/server/browserType.js +169 -182
  93. package/lib/server/callLog.js +47 -44
  94. package/lib/server/chromium/chromium.js +212 -190
  95. package/lib/server/chromium/chromiumSwitches.js +86 -64
  96. package/lib/server/chromium/crAccessibility.js +157 -131
  97. package/lib/server/chromium/crBrowser.js +253 -273
  98. package/lib/server/chromium/crConnection.js +91 -116
  99. package/lib/server/chromium/crCoverage.js +113 -127
  100. package/lib/server/chromium/crDevTools.js +59 -51
  101. package/lib/server/chromium/crDragDrop.js +62 -79
  102. package/lib/server/chromium/crExecutionContext.js +88 -83
  103. package/lib/server/chromium/crInput.js +97 -95
  104. package/lib/server/chromium/crNetworkManager.js +288 -403
  105. package/lib/server/chromium/crPage.js +522 -608
  106. package/lib/server/chromium/crPdf.js +54 -86
  107. package/lib/server/chromium/crProtocolHelper.js +92 -80
  108. package/lib/server/chromium/crServiceWorker.js +82 -67
  109. package/lib/server/chromium/defaultFontFamilies.js +152 -135
  110. package/lib/server/chromium/protocol.d.js +16 -0
  111. package/lib/server/chromium/videoRecorder.js +65 -99
  112. package/lib/server/clock.js +62 -50
  113. package/lib/server/codegen/csharp.js +185 -160
  114. package/lib/server/codegen/java.js +155 -128
  115. package/lib/server/codegen/javascript.js +163 -148
  116. package/lib/server/codegen/jsonl.js +32 -28
  117. package/lib/server/codegen/language.js +75 -52
  118. package/lib/server/codegen/languages.js +65 -27
  119. package/lib/server/codegen/python.js +140 -125
  120. package/lib/server/codegen/types.js +15 -4
  121. package/lib/server/console.js +28 -32
  122. package/lib/server/cookieStore.js +105 -86
  123. package/lib/server/debugController.js +97 -124
  124. package/lib/server/debugger.js +82 -78
  125. package/lib/server/deviceDescriptors.js +37 -24
  126. package/lib/server/deviceDescriptorsSource.json +50 -50
  127. package/lib/server/dialog.js +36 -35
  128. package/lib/server/dispatchers/androidDispatcher.js +196 -107
  129. package/lib/server/dispatchers/artifactDispatcher.js +62 -62
  130. package/lib/server/dispatchers/browserContextDispatcher.js +176 -205
  131. package/lib/server/dispatchers/browserDispatcher.js +78 -97
  132. package/lib/server/dispatchers/browserTypeDispatcher.js +35 -35
  133. package/lib/server/dispatchers/cdpSessionDispatcher.js +32 -36
  134. package/lib/server/dispatchers/debugControllerDispatcher.js +48 -66
  135. package/lib/server/dispatchers/dialogDispatcher.js +30 -27
  136. package/lib/server/dispatchers/dispatcher.js +169 -220
  137. package/lib/server/dispatchers/electronDispatcher.js +54 -57
  138. package/lib/server/dispatchers/elementHandlerDispatcher.js +77 -119
  139. package/lib/server/dispatchers/frameDispatcher.js +99 -163
  140. package/lib/server/dispatchers/jsHandleDispatcher.js +49 -66
  141. package/lib/server/dispatchers/jsonPipeDispatcher.js +35 -36
  142. package/lib/server/dispatchers/localUtilsDispatcher.js +95 -80
  143. package/lib/server/dispatchers/networkDispatchers.js +90 -107
  144. package/lib/server/dispatchers/pageDispatcher.js +128 -169
  145. package/lib/server/dispatchers/playwrightDispatcher.js +69 -76
  146. package/lib/server/dispatchers/selectorsDispatcher.js +28 -24
  147. package/lib/server/dispatchers/streamDispatcher.js +42 -45
  148. package/lib/server/dispatchers/tracingDispatcher.js +36 -41
  149. package/lib/server/dispatchers/webSocketRouteDispatcher.js +96 -131
  150. package/lib/server/dispatchers/writableStreamDispatcher.js +54 -38
  151. package/lib/server/dom.js +413 -443
  152. package/lib/server/download.js +45 -35
  153. package/lib/server/electron/electron.js +156 -176
  154. package/lib/server/electron/loader.js +8 -36
  155. package/lib/server/errors.js +47 -46
  156. package/lib/server/fetch.js +289 -323
  157. package/lib/server/fileChooser.js +25 -24
  158. package/lib/server/fileUploadUtils.js +65 -59
  159. package/lib/server/firefox/ffAccessibility.js +153 -131
  160. package/lib/server/firefox/ffBrowser.js +213 -277
  161. package/lib/server/firefox/ffConnection.js +63 -84
  162. package/lib/server/firefox/ffExecutionContext.js +91 -73
  163. package/lib/server/firefox/ffInput.js +67 -69
  164. package/lib/server/firefox/ffNetworkManager.js +131 -110
  165. package/lib/server/firefox/ffPage.js +236 -273
  166. package/lib/server/firefox/firefox.js +76 -67
  167. package/lib/server/firefox/protocol.d.js +16 -0
  168. package/lib/server/formData.js +107 -35
  169. package/lib/server/frameSelectors.js +77 -111
  170. package/lib/server/frames.js +741 -891
  171. package/lib/server/har/harRecorder.js +85 -77
  172. package/lib/server/har/harTracer.js +287 -222
  173. package/lib/server/harBackend.js +80 -80
  174. package/lib/server/helper.js +56 -59
  175. package/lib/server/index.js +59 -99
  176. package/lib/server/input.js +134 -163
  177. package/lib/server/instrumentation.js +49 -44
  178. package/lib/server/javascript.js +143 -134
  179. package/lib/server/launchApp.js +92 -73
  180. package/lib/server/localUtils.js +130 -122
  181. package/lib/server/macEditingCommands.js +141 -137
  182. package/lib/server/network.js +262 -296
  183. package/lib/server/page.js +329 -426
  184. package/lib/server/pageBinding.js +88 -0
  185. package/lib/server/pipeTransport.js +49 -45
  186. package/lib/server/playwright.js +60 -67
  187. package/lib/server/progress.js +56 -51
  188. package/lib/server/protocolError.js +34 -31
  189. package/lib/server/recorder/chat.js +70 -86
  190. package/lib/server/recorder/contextRecorder.js +134 -138
  191. package/lib/server/recorder/recorderApp.js +127 -136
  192. package/lib/server/recorder/recorderCollection.js +56 -44
  193. package/lib/server/recorder/recorderFrontend.js +15 -4
  194. package/lib/server/recorder/recorderRunner.js +79 -103
  195. package/lib/server/recorder/recorderUtils.js +56 -45
  196. package/lib/server/recorder/throttledFile.js +42 -30
  197. package/lib/server/recorder.js +177 -186
  198. package/lib/server/registry/browserFetcher.js +106 -101
  199. package/lib/server/registry/dependencies.js +245 -196
  200. package/lib/server/registry/index.js +904 -792
  201. package/lib/server/registry/nativeDeps.js +1073 -464
  202. package/lib/server/registry/oopDownloadBrowserMain.js +57 -75
  203. package/lib/server/screenshotter.js +166 -182
  204. package/lib/server/selectors.js +85 -46
  205. package/lib/server/socksClientCertificatesInterceptor.js +166 -185
  206. package/lib/server/socksInterceptor.js +62 -70
  207. package/lib/server/storageScript.js +94 -100
  208. package/lib/server/timeoutSettings.js +58 -43
  209. package/lib/server/trace/recorder/snapshotter.js +70 -89
  210. package/lib/server/trace/recorder/snapshotterInjected.js +238 -217
  211. package/lib/server/trace/recorder/tracing.js +321 -333
  212. package/lib/server/trace/test/inMemorySnapshotter.js +46 -52
  213. package/lib/server/trace/viewer/traceViewer.js +168 -146
  214. package/lib/server/transport.js +124 -133
  215. package/lib/server/types.js +26 -22
  216. package/lib/server/usKeyboardLayout.js +135 -545
  217. package/lib/server/utils/ascii.js +39 -26
  218. package/lib/server/utils/comparators.js +105 -103
  219. package/lib/server/utils/crypto.js +157 -112
  220. package/lib/server/utils/debug.js +37 -28
  221. package/lib/server/utils/debugLogger.js +69 -48
  222. package/lib/server/utils/env.js +52 -37
  223. package/lib/server/utils/eventsHelper.js +29 -28
  224. package/lib/server/utils/expectUtils.js +31 -26
  225. package/lib/server/utils/fileUtils.js +123 -136
  226. package/lib/server/utils/happyEyeballs.js +138 -123
  227. package/lib/server/utils/hostPlatform.js +84 -120
  228. package/lib/server/utils/httpServer.js +106 -121
  229. package/lib/server/utils/image_tools/colorUtils.js +42 -51
  230. package/lib/server/utils/image_tools/compare.js +44 -43
  231. package/lib/server/utils/image_tools/imageChannel.js +38 -30
  232. package/lib/server/utils/image_tools/stats.js +40 -40
  233. package/lib/server/utils/linuxUtils.js +50 -37
  234. package/lib/server/utils/network.js +143 -86
  235. package/lib/server/utils/nodePlatform.js +87 -79
  236. package/lib/server/utils/pipeTransport.js +44 -42
  237. package/lib/server/utils/processLauncher.js +111 -121
  238. package/lib/server/utils/profiler.js +52 -39
  239. package/lib/server/utils/socksProxy.js +280 -339
  240. package/lib/server/utils/spawnAsync.js +37 -41
  241. package/lib/server/utils/task.js +31 -38
  242. package/lib/server/utils/userAgent.js +73 -66
  243. package/lib/server/utils/wsServer.js +73 -69
  244. package/lib/server/utils/zipFile.js +36 -37
  245. package/lib/server/utils/zones.js +37 -34
  246. package/lib/server/webkit/protocol.d.js +16 -0
  247. package/lib/server/webkit/webkit.js +76 -63
  248. package/lib/server/webkit/wkAccessibility.js +161 -118
  249. package/lib/server/webkit/wkBrowser.js +159 -176
  250. package/lib/server/webkit/wkConnection.js +59 -83
  251. package/lib/server/webkit/wkExecutionContext.js +84 -70
  252. package/lib/server/webkit/wkInput.js +82 -80
  253. package/lib/server/webkit/wkInterceptableRequest.js +102 -95
  254. package/lib/server/webkit/wkPage.js +525 -619
  255. package/lib/server/webkit/wkProvisionalPage.js +45 -56
  256. package/lib/server/webkit/wkWorkers.js +77 -77
  257. package/lib/utils/isomorphic/ariaSnapshot.js +144 -152
  258. package/lib/utils/isomorphic/assert.js +28 -22
  259. package/lib/utils/isomorphic/builtins.js +90 -0
  260. package/lib/utils/isomorphic/colors.js +66 -59
  261. package/lib/utils/isomorphic/cssParser.js +121 -125
  262. package/lib/utils/isomorphic/cssTokenizer.js +436 -364
  263. package/lib/utils/isomorphic/headers.js +38 -37
  264. package/lib/utils/isomorphic/locatorGenerators.js +340 -357
  265. package/lib/utils/isomorphic/locatorParser.js +96 -105
  266. package/lib/utils/isomorphic/locatorUtils.js +63 -44
  267. package/lib/utils/isomorphic/manualPromise.js +47 -39
  268. package/lib/utils/isomorphic/mimeType.js +448 -25
  269. package/lib/utils/isomorphic/multimap.js +35 -27
  270. package/lib/utils/isomorphic/rtti.js +35 -33
  271. package/lib/utils/isomorphic/selectorParser.js +183 -193
  272. package/lib/utils/isomorphic/semaphore.js +27 -24
  273. package/lib/utils/isomorphic/stackTrace.js +87 -98
  274. package/lib/utils/isomorphic/stringUtils.js +113 -106
  275. package/lib/utils/isomorphic/time.js +41 -22
  276. package/lib/utils/isomorphic/timeoutRunner.js +55 -54
  277. package/lib/utils/isomorphic/traceUtils.js +38 -41
  278. package/lib/utils/isomorphic/types.js +15 -4
  279. package/lib/utils/isomorphic/urlMatch.js +112 -67
  280. package/lib/utils/isomorphic/utilityScriptSerializers.js +248 -0
  281. package/lib/utils.js +97 -443
  282. package/lib/utilsBundle.js +101 -52
  283. package/lib/vite/htmlReport/index.html +21 -15
  284. package/lib/vite/recorder/assets/{codeMirrorModule-B9YMkrwa.js → codeMirrorModule-DVQi6prl.js} +1 -1
  285. package/lib/vite/recorder/assets/index-97EUAAbk.js +184 -0
  286. package/lib/vite/recorder/index.html +1 -1
  287. package/lib/vite/traceViewer/assets/{codeMirrorModule-DpJ-EmBQ.js → codeMirrorModule-dvXVzLxY.js} +1 -1
  288. package/lib/vite/traceViewer/assets/defaultSettingsView-BjymbO6M.js +265 -0
  289. package/lib/vite/traceViewer/{defaultSettingsView.5fN5lw10.css → defaultSettingsView.QdHITyLI.css} +1 -1
  290. package/lib/vite/traceViewer/index.ChIUCJnj.js +2 -0
  291. package/lib/vite/traceViewer/index.html +3 -3
  292. package/lib/vite/traceViewer/sw.bundle.js +3 -3
  293. package/lib/vite/traceViewer/uiMode.html +3 -3
  294. package/lib/vite/traceViewer/uiMode.jUCiCtdp.js +5 -0
  295. package/lib/zipBundle.js +32 -23
  296. package/package.json +1 -1
  297. package/types/protocol.d.ts +436 -17
  298. package/types/types.d.ts +35 -16
  299. package/lib/server/isomorphic/utilityScriptSerializers.js +0 -229
  300. package/lib/vite/recorder/assets/index-ELPgmkwA.js +0 -184
  301. package/lib/vite/traceViewer/assets/defaultSettingsView-DTenqiGw.js +0 -259
  302. package/lib/vite/traceViewer/index.CUq7VgrV.js +0 -2
  303. package/lib/vite/traceViewer/uiMode.CHJSAD7F.js +0 -5
@@ -1,122 +1,108 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var socksClientCertificatesInterceptor_exports = {};
30
+ __export(socksClientCertificatesInterceptor_exports, {
31
+ ClientCertificatesProxy: () => ClientCertificatesProxy,
32
+ getMatchingTLSOptionsForOrigin: () => getMatchingTLSOptionsForOrigin,
33
+ rewriteOpenSSLErrorIfNeeded: () => rewriteOpenSSLErrorIfNeeded
5
34
  });
6
- exports.ClientCertificatesProxy = void 0;
7
- exports.getMatchingTLSOptionsForOrigin = getMatchingTLSOptionsForOrigin;
8
- exports.rewriteOpenSSLErrorIfNeeded = rewriteOpenSSLErrorIfNeeded;
9
- var _events = require("events");
10
- var _http = _interopRequireDefault(require("http2"));
11
- var _net = _interopRequireDefault(require("net"));
12
- var _stream = _interopRequireDefault(require("stream"));
13
- var _tls = _interopRequireDefault(require("tls"));
14
- var _socksProxy = require("./utils/socksProxy");
15
- var _utils = require("../utils");
16
- var _browserContext = require("./browserContext");
17
- var _fetch = require("./fetch");
18
- var _debugLogger = require("./utils/debugLogger");
19
- var _happyEyeballs = require("./utils/happyEyeballs");
20
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
21
- /**
22
- * Copyright (c) Microsoft Corporation.
23
- *
24
- * Licensed under the Apache License, Version 2.0 (the 'License");
25
- * you may not use this file except in compliance with the License.
26
- * You may obtain a copy of the License at
27
- *
28
- * http://www.apache.org/licenses/LICENSE-2.0
29
- *
30
- * Unless required by applicable law or agreed to in writing, software
31
- * distributed under the License is distributed on an "AS IS" BASIS,
32
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33
- * See the License for the specific language governing permissions and
34
- * limitations under the License.
35
- */
36
-
37
- let dummyServerTlsOptions = undefined;
35
+ module.exports = __toCommonJS(socksClientCertificatesInterceptor_exports);
36
+ var import_events = require("events");
37
+ var import_http2 = __toESM(require("http2"));
38
+ var import_net = __toESM(require("net"));
39
+ var import_stream = __toESM(require("stream"));
40
+ var import_tls = __toESM(require("tls"));
41
+ var import_socksProxy = require("./utils/socksProxy");
42
+ var import_utils = require("../utils");
43
+ var import_browserContext = require("./browserContext");
44
+ var import_network = require("./utils/network");
45
+ var import_debugLogger = require("./utils/debugLogger");
46
+ var import_happyEyeballs = require("./utils/happyEyeballs");
47
+ let dummyServerTlsOptions = void 0;
38
48
  function loadDummyServerCertsIfNeeded() {
39
- if (dummyServerTlsOptions) return;
40
- const {
41
- cert,
42
- key
43
- } = (0, _utils.generateSelfSignedCertificate)();
44
- dummyServerTlsOptions = {
45
- key,
46
- cert
47
- };
49
+ if (dummyServerTlsOptions)
50
+ return;
51
+ const { cert, key } = (0, import_utils.generateSelfSignedCertificate)();
52
+ dummyServerTlsOptions = { key, cert };
48
53
  }
49
54
  class ALPNCache {
50
55
  constructor() {
51
- this._cache = new Map();
56
+ this._cache = /* @__PURE__ */ new Map();
52
57
  }
53
58
  get(host, port, success) {
54
59
  const cacheKey = `${host}:${port}`;
55
60
  {
56
- const result = this._cache.get(cacheKey);
57
- if (result) {
58
- result.then(success);
61
+ const result2 = this._cache.get(cacheKey);
62
+ if (result2) {
63
+ result2.then(success);
59
64
  return;
60
65
  }
61
66
  }
62
- const result = new _utils.ManualPromise();
67
+ const result = new import_utils.ManualPromise();
63
68
  this._cache.set(cacheKey, result);
64
69
  result.then(success);
65
- (0, _happyEyeballs.createTLSSocket)({
70
+ (0, import_happyEyeballs.createTLSSocket)({
66
71
  host,
67
72
  port,
68
- servername: _net.default.isIP(host) ? undefined : host,
69
- ALPNProtocols: ['h2', 'http/1.1'],
73
+ servername: import_net.default.isIP(host) ? void 0 : host,
74
+ ALPNProtocols: ["h2", "http/1.1"],
70
75
  rejectUnauthorized: false
71
- }).then(socket => {
72
- // The server may not respond with ALPN, in which case we default to http/1.1.
73
- result.resolve(socket.alpnProtocol || 'http/1.1');
76
+ }).then((socket) => {
77
+ result.resolve(socket.alpnProtocol || "http/1.1");
74
78
  socket.end();
75
- }).catch(error => {
76
- _debugLogger.debugLogger.log('client-certificates', `ALPN error: ${error.message}`);
77
- result.resolve('http/1.1');
79
+ }).catch((error) => {
80
+ import_debugLogger.debugLogger.log("client-certificates", `ALPN error: ${error.message}`);
81
+ result.resolve("http/1.1");
78
82
  });
79
83
  }
80
84
  }
81
85
  class SocksProxyConnection {
82
86
  constructor(socksProxy, uid, host, port) {
83
- this.socksProxy = void 0;
84
- this.uid = void 0;
85
- this.host = void 0;
86
- this.port = void 0;
87
87
  this.firstPackageReceived = false;
88
- this.target = void 0;
89
- // In case of http, we just pipe data to the target socket and they are |undefined|.
90
- this.internal = void 0;
91
- this.internalTLS = void 0;
92
- this._targetCloseEventListener = void 0;
93
- this._dummyServer = void 0;
94
88
  this._closed = false;
95
89
  this.socksProxy = socksProxy;
96
90
  this.uid = uid;
97
91
  this.host = host;
98
92
  this.port = port;
99
93
  this._targetCloseEventListener = () => {
100
- var _this$internalTLS, _this$_dummyServer;
101
- // Close the other end and cleanup TLS resources.
102
- this.socksProxy._socksProxy.sendSocketEnd({
103
- uid: this.uid
104
- });
105
- (_this$internalTLS = this.internalTLS) === null || _this$internalTLS === void 0 || _this$internalTLS.destroy();
106
- (_this$_dummyServer = this._dummyServer) === null || _this$_dummyServer === void 0 || _this$_dummyServer.close();
94
+ this.socksProxy._socksProxy.sendSocketEnd({ uid: this.uid });
95
+ this.internalTLS?.destroy();
96
+ this._dummyServer?.close();
107
97
  };
108
98
  }
109
99
  async connect() {
110
- if (this.socksProxy.proxyAgentFromOptions) this.target = await this.socksProxy.proxyAgentFromOptions.callback(new _events.EventEmitter(), {
111
- host: rewriteToLocalhostIfNeeded(this.host),
112
- port: this.port,
113
- secureEndpoint: false
114
- });else this.target = await (0, _happyEyeballs.createSocket)(rewriteToLocalhostIfNeeded(this.host), this.port);
115
- this.target.once('close', this._targetCloseEventListener);
116
- this.target.once('error', error => this.socksProxy._socksProxy.sendSocketError({
117
- uid: this.uid,
118
- error: error.message
119
- }));
100
+ if (this.socksProxy.proxyAgentFromOptions)
101
+ this.target = await this.socksProxy.proxyAgentFromOptions.callback(new import_events.EventEmitter(), { host: rewriteToLocalhostIfNeeded(this.host), port: this.port, secureEndpoint: false });
102
+ else
103
+ this.target = await (0, import_happyEyeballs.createSocket)(rewriteToLocalhostIfNeeded(this.host), this.port);
104
+ this.target.once("close", this._targetCloseEventListener);
105
+ this.target.once("error", (error) => this.socksProxy._socksProxy.sendSocketError({ uid: this.uid, error: error.message }));
120
106
  if (this._closed) {
121
107
  this.target.destroy();
122
108
  return;
@@ -128,83 +114,81 @@ class SocksProxyConnection {
128
114
  });
129
115
  }
130
116
  onClose() {
131
- var _this$internalTLS2, _this$_dummyServer2;
132
- // Close the other end and cleanup TLS resources.
133
117
  this.target.destroy();
134
- (_this$internalTLS2 = this.internalTLS) === null || _this$internalTLS2 === void 0 || _this$internalTLS2.destroy();
135
- (_this$_dummyServer2 = this._dummyServer) === null || _this$_dummyServer2 === void 0 || _this$_dummyServer2.close();
118
+ this.internalTLS?.destroy();
119
+ this._dummyServer?.close();
136
120
  this._closed = true;
137
121
  }
138
122
  onData(data) {
139
- // HTTP / TLS are client-hello based protocols. This allows us to detect
140
- // the protocol on the first package and attach appropriate listeners.
141
123
  if (!this.firstPackageReceived) {
142
124
  this.firstPackageReceived = true;
143
- // 0x16 is SSLv3/TLS "handshake" content type: https://en.wikipedia.org/wiki/Transport_Layer_Security#TLS_record
144
- if (data[0] === 0x16) this._attachTLSListeners();else this.target.on('data', data => this.socksProxy._socksProxy.sendSocketData({
145
- uid: this.uid,
146
- data
147
- }));
125
+ if (data[0] === 22)
126
+ this._attachTLSListeners();
127
+ else
128
+ this.target.on("data", (data2) => this.socksProxy._socksProxy.sendSocketData({ uid: this.uid, data: data2 }));
148
129
  }
149
- if (this.internal) this.internal.push(data);else this.target.write(data);
130
+ if (this.internal)
131
+ this.internal.push(data);
132
+ else
133
+ this.target.write(data);
150
134
  }
151
135
  _attachTLSListeners() {
152
- this.internal = new _stream.default.Duplex({
153
- read: () => {},
136
+ this.internal = new import_stream.default.Duplex({
137
+ read: () => {
138
+ },
154
139
  write: (data, encoding, callback) => {
155
- this.socksProxy._socksProxy.sendSocketData({
156
- uid: this.uid,
157
- data
158
- });
140
+ this.socksProxy._socksProxy.sendSocketData({ uid: this.uid, data });
159
141
  callback();
160
142
  }
161
143
  });
162
- this.socksProxy.alpnCache.get(rewriteToLocalhostIfNeeded(this.host), this.port, alpnProtocolChosenByServer => {
163
- _debugLogger.debugLogger.log('client-certificates', `Proxy->Target ${this.host}:${this.port} chooses ALPN ${alpnProtocolChosenByServer}`);
164
- if (this._closed) return;
165
- this._dummyServer = _tls.default.createServer({
144
+ this.socksProxy.alpnCache.get(rewriteToLocalhostIfNeeded(this.host), this.port, (alpnProtocolChosenByServer) => {
145
+ import_debugLogger.debugLogger.log("client-certificates", `Proxy->Target ${this.host}:${this.port} chooses ALPN ${alpnProtocolChosenByServer}`);
146
+ if (this._closed)
147
+ return;
148
+ this._dummyServer = import_tls.default.createServer({
166
149
  ...dummyServerTlsOptions,
167
- ALPNProtocols: alpnProtocolChosenByServer === 'h2' ? ['h2', 'http/1.1'] : ['http/1.1']
150
+ ALPNProtocols: alpnProtocolChosenByServer === "h2" ? ["h2", "http/1.1"] : ["http/1.1"]
168
151
  });
169
- this._dummyServer.emit('connection', this.internal);
170
- this._dummyServer.once('secureConnection', internalTLS => {
152
+ this._dummyServer.emit("connection", this.internal);
153
+ this._dummyServer.once("secureConnection", (internalTLS) => {
171
154
  this.internalTLS = internalTLS;
172
- _debugLogger.debugLogger.log('client-certificates', `Browser->Proxy ${this.host}:${this.port} chooses ALPN ${internalTLS.alpnProtocol}`);
173
- let targetTLS = undefined;
174
- const handleError = error => {
175
- _debugLogger.debugLogger.log('client-certificates', `error when connecting to target: ${error.message.replaceAll('\n', ' ')}`);
176
- const responseBody = (0, _utils.escapeHTML)('Playwright client-certificate error: ' + error.message).replaceAll('\n', ' <br>');
177
- if ((internalTLS === null || internalTLS === void 0 ? void 0 : internalTLS.alpnProtocol) === 'h2') {
178
- // This method is available only in Node.js 20+
179
- if ('performServerHandshake' in _http.default) {
180
- // In case of an 'error' event on the target connection, we still need to perform the http2 handshake on the browser side.
181
- // This is an async operation, so we need to remove the listener to prevent the socket from being closed too early.
182
- // This means we call this._targetCloseEventListener manually.
183
- this.target.removeListener('close', this._targetCloseEventListener);
184
- // @ts-expect-error
185
- const session = _http.default.performServerHandshake(internalTLS);
186
- session.on('error', () => {
155
+ import_debugLogger.debugLogger.log("client-certificates", `Browser->Proxy ${this.host}:${this.port} chooses ALPN ${internalTLS.alpnProtocol}`);
156
+ let targetTLS = void 0;
157
+ const handleError = (error) => {
158
+ import_debugLogger.debugLogger.log("client-certificates", `error when connecting to target: ${error.message.replaceAll("\n", " ")}`);
159
+ const responseBody = (0, import_utils.escapeHTML)("Playwright client-certificate error: " + error.message).replaceAll("\n", " <br>");
160
+ if (internalTLS?.alpnProtocol === "h2") {
161
+ if ("performServerHandshake" in import_http2.default) {
162
+ this.target.removeListener("close", this._targetCloseEventListener);
163
+ const session = import_http2.default.performServerHandshake(internalTLS);
164
+ session.on("error", () => {
187
165
  this.target.destroy();
188
166
  this._targetCloseEventListener();
189
167
  });
190
- session.once('stream', stream => {
191
- stream.respond({
192
- 'content-type': 'text/html',
193
- [_http.default.constants.HTTP2_HEADER_STATUS]: 503
168
+ session.once("stream", (stream2) => {
169
+ stream2.respond({
170
+ "content-type": "text/html",
171
+ [import_http2.default.constants.HTTP2_HEADER_STATUS]: 503
194
172
  });
195
173
  const cleanup = () => {
196
174
  session.close();
197
175
  this.target.destroy();
198
176
  this._targetCloseEventListener();
199
177
  };
200
- stream.end(responseBody, cleanup);
201
- stream.once('error', cleanup);
178
+ stream2.end(responseBody, cleanup);
179
+ stream2.once("error", cleanup);
202
180
  });
203
181
  } else {
204
182
  this.target.destroy();
205
183
  }
206
184
  } else {
207
- internalTLS.end(['HTTP/1.1 503 Internal Server Error', 'Content-Type: text/html; charset=utf-8', 'Content-Length: ' + Buffer.byteLength(responseBody), '', responseBody].join('\r\n'));
185
+ internalTLS.end([
186
+ "HTTP/1.1 503 Internal Server Error",
187
+ "Content-Type: text/html; charset=utf-8",
188
+ "Content-Length: " + Buffer.byteLength(responseBody),
189
+ "",
190
+ responseBody
191
+ ].join("\r\n"));
208
192
  this.target.destroy();
209
193
  }
210
194
  };
@@ -212,94 +196,79 @@ class SocksProxyConnection {
212
196
  internalTLS.destroy();
213
197
  return;
214
198
  }
215
- targetTLS = _tls.default.connect({
199
+ targetTLS = import_tls.default.connect({
216
200
  socket: this.target,
217
201
  host: this.host,
218
202
  port: this.port,
219
203
  rejectUnauthorized: !this.socksProxy.ignoreHTTPSErrors,
220
- ALPNProtocols: [internalTLS.alpnProtocol || 'http/1.1'],
221
- servername: !_net.default.isIP(this.host) ? this.host : undefined,
204
+ ALPNProtocols: [internalTLS.alpnProtocol || "http/1.1"],
205
+ servername: !import_net.default.isIP(this.host) ? this.host : void 0,
222
206
  secureContext: this.socksProxy.secureContextMap.get(new URL(`https://${this.host}:${this.port}`).origin)
223
207
  });
224
- targetTLS.once('secureConnect', () => {
208
+ targetTLS.once("secureConnect", () => {
225
209
  internalTLS.pipe(targetTLS);
226
210
  targetTLS.pipe(internalTLS);
227
211
  });
228
- internalTLS.once('error', () => this.target.destroy());
229
- targetTLS.once('error', handleError);
212
+ internalTLS.once("error", () => this.target.destroy());
213
+ targetTLS.once("error", handleError);
230
214
  });
231
215
  });
232
216
  }
233
217
  }
234
218
  class ClientCertificatesProxy {
235
219
  constructor(contextOptions) {
236
- this._socksProxy = void 0;
237
- this._connections = new Map();
238
- this.ignoreHTTPSErrors = void 0;
239
- this.secureContextMap = new Map();
240
- this.alpnCache = void 0;
241
- this.proxyAgentFromOptions = void 0;
242
- (0, _browserContext.verifyClientCertificates)(contextOptions.clientCertificates);
220
+ this._connections = /* @__PURE__ */ new Map();
221
+ this.secureContextMap = /* @__PURE__ */ new Map();
222
+ (0, import_browserContext.verifyClientCertificates)(contextOptions.clientCertificates);
243
223
  this.alpnCache = new ALPNCache();
244
224
  this.ignoreHTTPSErrors = contextOptions.ignoreHTTPSErrors;
245
- this.proxyAgentFromOptions = contextOptions.proxy ? (0, _fetch.createProxyAgent)(contextOptions.proxy) : undefined;
225
+ this.proxyAgentFromOptions = (0, import_network.createProxyAgent)(contextOptions.proxy);
246
226
  this._initSecureContexts(contextOptions.clientCertificates);
247
- this._socksProxy = new _socksProxy.SocksProxy();
248
- this._socksProxy.setPattern('*');
249
- this._socksProxy.addListener(_socksProxy.SocksProxy.Events.SocksRequested, async payload => {
227
+ this._socksProxy = new import_socksProxy.SocksProxy();
228
+ this._socksProxy.setPattern("*");
229
+ this._socksProxy.addListener(import_socksProxy.SocksProxy.Events.SocksRequested, async (payload) => {
250
230
  try {
251
231
  const connection = new SocksProxyConnection(this, payload.uid, payload.host, payload.port);
252
232
  await connection.connect();
253
233
  this._connections.set(payload.uid, connection);
254
234
  } catch (error) {
255
- this._socksProxy.socketFailed({
256
- uid: payload.uid,
257
- errorCode: error.code
258
- });
235
+ this._socksProxy.socketFailed({ uid: payload.uid, errorCode: error.code });
259
236
  }
260
237
  });
261
- this._socksProxy.addListener(_socksProxy.SocksProxy.Events.SocksData, async payload => {
262
- var _this$_connections$ge;
263
- (_this$_connections$ge = this._connections.get(payload.uid)) === null || _this$_connections$ge === void 0 || _this$_connections$ge.onData(payload.data);
238
+ this._socksProxy.addListener(import_socksProxy.SocksProxy.Events.SocksData, async (payload) => {
239
+ this._connections.get(payload.uid)?.onData(payload.data);
264
240
  });
265
- this._socksProxy.addListener(_socksProxy.SocksProxy.Events.SocksClosed, payload => {
266
- var _this$_connections$ge2;
267
- (_this$_connections$ge2 = this._connections.get(payload.uid)) === null || _this$_connections$ge2 === void 0 || _this$_connections$ge2.onClose();
241
+ this._socksProxy.addListener(import_socksProxy.SocksProxy.Events.SocksClosed, (payload) => {
242
+ this._connections.get(payload.uid)?.onClose();
268
243
  this._connections.delete(payload.uid);
269
244
  });
270
245
  loadDummyServerCertsIfNeeded();
271
246
  }
272
247
  _initSecureContexts(clientCertificates) {
273
- // Step 1. Group certificates by origin.
274
- const origin2certs = new Map();
248
+ const origin2certs = /* @__PURE__ */ new Map();
275
249
  for (const cert of clientCertificates || []) {
276
250
  const origin = normalizeOrigin(cert.origin);
277
251
  const certs = origin2certs.get(origin) || [];
278
252
  certs.push(cert);
279
253
  origin2certs.set(origin, certs);
280
254
  }
281
-
282
- // Step 2. Create secure contexts for each origin.
283
255
  for (const [origin, certs] of origin2certs) {
284
256
  try {
285
- this.secureContextMap.set(origin, _tls.default.createSecureContext(convertClientCertificatesToTLSOptions(certs)));
257
+ this.secureContextMap.set(origin, import_tls.default.createSecureContext(convertClientCertificatesToTLSOptions(certs)));
286
258
  } catch (error) {
287
259
  error = rewriteOpenSSLErrorIfNeeded(error);
288
- throw (0, _utils.rewriteErrorMessage)(error, `Failed to load client certificate: ${error.message}`);
260
+ throw (0, import_utils.rewriteErrorMessage)(error, `Failed to load client certificate: ${error.message}`);
289
261
  }
290
262
  }
291
263
  }
292
264
  async listen() {
293
- const port = await this._socksProxy.listen(0, '127.0.0.1');
294
- return {
295
- server: `socks5://127.0.0.1:${port}`
296
- };
265
+ const port = await this._socksProxy.listen(0, "127.0.0.1");
266
+ return { server: `socks5://127.0.0.1:${port}` };
297
267
  }
298
268
  async close() {
299
269
  await this._socksProxy.close();
300
270
  }
301
271
  }
302
- exports.ClientCertificatesProxy = ClientCertificatesProxy;
303
272
  function normalizeOrigin(origin) {
304
273
  try {
305
274
  return new URL(origin).origin;
@@ -308,33 +277,45 @@ function normalizeOrigin(origin) {
308
277
  }
309
278
  }
310
279
  function convertClientCertificatesToTLSOptions(clientCertificates) {
311
- if (!clientCertificates || !clientCertificates.length) return;
280
+ if (!clientCertificates || !clientCertificates.length)
281
+ return;
312
282
  const tlsOptions = {
313
283
  pfx: [],
314
284
  key: [],
315
285
  cert: []
316
286
  };
317
287
  for (const cert of clientCertificates) {
318
- if (cert.cert) tlsOptions.cert.push(cert.cert);
319
- if (cert.key) tlsOptions.key.push({
320
- pem: cert.key,
321
- passphrase: cert.passphrase
322
- });
323
- if (cert.pfx) tlsOptions.pfx.push({
324
- buf: cert.pfx,
325
- passphrase: cert.passphrase
326
- });
288
+ if (cert.cert)
289
+ tlsOptions.cert.push(cert.cert);
290
+ if (cert.key)
291
+ tlsOptions.key.push({ pem: cert.key, passphrase: cert.passphrase });
292
+ if (cert.pfx)
293
+ tlsOptions.pfx.push({ buf: cert.pfx, passphrase: cert.passphrase });
327
294
  }
328
295
  return tlsOptions;
329
296
  }
330
297
  function getMatchingTLSOptionsForOrigin(clientCertificates, origin) {
331
- const matchingCerts = clientCertificates === null || clientCertificates === void 0 ? void 0 : clientCertificates.filter(c => normalizeOrigin(c.origin) === origin);
298
+ const matchingCerts = clientCertificates?.filter(
299
+ (c) => normalizeOrigin(c.origin) === origin
300
+ );
332
301
  return convertClientCertificatesToTLSOptions(matchingCerts);
333
302
  }
334
303
  function rewriteToLocalhostIfNeeded(host) {
335
- return host === 'local.playwright' ? 'localhost' : host;
304
+ return host === "local.playwright" ? "localhost" : host;
336
305
  }
337
306
  function rewriteOpenSSLErrorIfNeeded(error) {
338
- if (error.message !== 'unsupported' && error.code !== 'ERR_CRYPTO_UNSUPPORTED_OPERATION') return error;
339
- return (0, _utils.rewriteErrorMessage)(error, ['Unsupported TLS certificate.', 'Most likely, the security algorithm of the given certificate was deprecated by OpenSSL.', 'For more details, see https://github.com/openssl/openssl/blob/master/README-PROVIDERS.md#the-legacy-provider', 'You could probably modernize the certificate by following the steps at https://github.com/nodejs/node/issues/40672#issuecomment-1243648223'].join('\n'));
340
- }
307
+ if (error.message !== "unsupported" && error.code !== "ERR_CRYPTO_UNSUPPORTED_OPERATION")
308
+ return error;
309
+ return (0, import_utils.rewriteErrorMessage)(error, [
310
+ "Unsupported TLS certificate.",
311
+ "Most likely, the security algorithm of the given certificate was deprecated by OpenSSL.",
312
+ "For more details, see https://github.com/openssl/openssl/blob/master/README-PROVIDERS.md#the-legacy-provider",
313
+ "You could probably modernize the certificate by following the steps at https://github.com/nodejs/node/issues/40672#issuecomment-1243648223"
314
+ ].join("\n"));
315
+ }
316
+ // Annotate the CommonJS export names for ESM import in node:
317
+ 0 && (module.exports = {
318
+ ClientCertificatesProxy,
319
+ getMatchingTLSOptionsForOrigin,
320
+ rewriteOpenSSLErrorIfNeeded
321
+ });