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.
- package/README.md +3 -0
- package/ThirdPartyNotices.txt +1548 -0
- package/bin/PrintDeps.exe +0 -0
- package/bin/README.md +2 -0
- package/bin/install_media_pack.ps1 +5 -0
- package/bin/reinstall_chrome_beta_linux.sh +40 -0
- package/bin/reinstall_chrome_beta_mac.sh +13 -0
- package/bin/reinstall_chrome_beta_win.ps1 +24 -0
- package/bin/reinstall_chrome_stable_linux.sh +40 -0
- package/bin/reinstall_chrome_stable_mac.sh +12 -0
- package/bin/reinstall_chrome_stable_win.ps1 +24 -0
- package/bin/reinstall_msedge_beta_linux.sh +40 -0
- package/bin/reinstall_msedge_beta_mac.sh +11 -0
- package/bin/reinstall_msedge_beta_win.ps1 +23 -0
- package/bin/reinstall_msedge_dev_linux.sh +40 -0
- package/bin/reinstall_msedge_dev_mac.sh +11 -0
- package/bin/reinstall_msedge_dev_win.ps1 +23 -0
- package/bin/reinstall_msedge_stable_linux.sh +40 -0
- package/bin/reinstall_msedge_stable_mac.sh +11 -0
- package/bin/reinstall_msedge_stable_win.ps1 +24 -0
- package/browsers.json +57 -0
- package/cli.js +18 -0
- package/index.d.ts +17 -0
- package/index.js +33 -0
- package/index.mjs +28 -0
- package/lib/androidServerImpl.js +69 -0
- package/lib/browserServerImpl.js +92 -0
- package/lib/cli/driver.js +95 -0
- package/lib/cli/program.js +589 -0
- package/lib/cli/programWithTestStub.js +67 -0
- package/lib/client/accessibility.js +50 -0
- package/lib/client/android.js +473 -0
- package/lib/client/api.js +285 -0
- package/lib/client/artifact.js +79 -0
- package/lib/client/browser.js +145 -0
- package/lib/client/browserContext.js +583 -0
- package/lib/client/browserType.js +241 -0
- package/lib/client/cdpSession.js +53 -0
- package/lib/client/channelOwner.js +235 -0
- package/lib/client/clientHelper.js +57 -0
- package/lib/client/clientInstrumentation.js +50 -0
- package/lib/client/clock.js +69 -0
- package/lib/client/connection.js +333 -0
- package/lib/client/consoleMessage.js +55 -0
- package/lib/client/coverage.js +41 -0
- package/lib/client/dialog.js +57 -0
- package/lib/client/download.js +62 -0
- package/lib/client/electron.js +135 -0
- package/lib/client/elementHandle.js +321 -0
- package/lib/client/errors.js +77 -0
- package/lib/client/eventEmitter.js +314 -0
- package/lib/client/events.js +94 -0
- package/lib/client/fetch.js +391 -0
- package/lib/client/fileChooser.js +45 -0
- package/lib/client/frame.js +504 -0
- package/lib/client/harRouter.js +99 -0
- package/lib/client/input.js +111 -0
- package/lib/client/jsHandle.js +121 -0
- package/lib/client/jsonPipe.js +35 -0
- package/lib/client/localUtils.js +36 -0
- package/lib/client/locator.js +441 -0
- package/lib/client/network.js +762 -0
- package/lib/client/page.js +770 -0
- package/lib/client/playwright.js +80 -0
- package/lib/client/selectors.js +67 -0
- package/lib/client/stream.js +54 -0
- package/lib/client/tracing.js +134 -0
- package/lib/client/types.js +24 -0
- package/lib/client/video.js +51 -0
- package/lib/client/waiter.js +158 -0
- package/lib/client/webError.js +37 -0
- package/lib/client/worker.js +71 -0
- package/lib/client/writableStream.js +54 -0
- package/lib/common/socksProxy.js +569 -0
- package/lib/common/timeoutSettings.js +73 -0
- package/lib/common/types.js +5 -0
- package/lib/generated/clockSource.js +7 -0
- package/lib/generated/consoleApiSource.js +7 -0
- package/lib/generated/injectedScriptSource.js +7 -0
- package/lib/generated/pollingRecorderSource.js +7 -0
- package/lib/generated/utilityScriptSource.js +7 -0
- package/lib/generated/webSocketMockSource.js +7 -0
- package/lib/image_tools/colorUtils.js +98 -0
- package/lib/image_tools/compare.js +108 -0
- package/lib/image_tools/imageChannel.js +70 -0
- package/lib/image_tools/stats.js +102 -0
- package/lib/inProcessFactory.js +54 -0
- package/lib/inprocess.js +20 -0
- package/lib/outofprocess.js +67 -0
- package/lib/protocol/debug.js +27 -0
- package/lib/protocol/serializers.js +173 -0
- package/lib/protocol/transport.js +82 -0
- package/lib/protocol/validator.js +2760 -0
- package/lib/protocol/validatorPrimitives.js +139 -0
- package/lib/remote/playwrightConnection.js +274 -0
- package/lib/remote/playwrightServer.js +110 -0
- package/lib/server/accessibility.js +62 -0
- package/lib/server/android/android.js +441 -0
- package/lib/server/android/backendAdb.js +172 -0
- package/lib/server/artifact.js +104 -0
- package/lib/server/bidi/bidiBrowser.js +311 -0
- package/lib/server/bidi/bidiChromium.js +124 -0
- package/lib/server/bidi/bidiConnection.js +206 -0
- package/lib/server/bidi/bidiExecutionContext.js +159 -0
- package/lib/server/bidi/bidiFirefox.js +104 -0
- package/lib/server/bidi/bidiInput.js +158 -0
- package/lib/server/bidi/bidiNetworkManager.js +338 -0
- package/lib/server/bidi/bidiOverCdp.js +103 -0
- package/lib/server/bidi/bidiPage.js +529 -0
- package/lib/server/bidi/bidiPdf.js +140 -0
- package/lib/server/bidi/third_party/bidiDeserializer.js +93 -0
- package/lib/server/bidi/third_party/bidiKeyboard.js +238 -0
- package/lib/server/bidi/third_party/bidiProtocol.js +139 -0
- package/lib/server/bidi/third_party/bidiSerializer.js +144 -0
- package/lib/server/bidi/third_party/firefoxPrefs.js +221 -0
- package/lib/server/browser.js +148 -0
- package/lib/server/browserContext.js +666 -0
- package/lib/server/browserType.js +335 -0
- package/lib/server/chromium/appIcon.png +0 -0
- package/lib/server/chromium/chromium.js +350 -0
- package/lib/server/chromium/chromiumSwitches.js +36 -0
- package/lib/server/chromium/crAccessibility.js +237 -0
- package/lib/server/chromium/crBrowser.js +522 -0
- package/lib/server/chromium/crConnection.js +228 -0
- package/lib/server/chromium/crCoverage.js +246 -0
- package/lib/server/chromium/crDevTools.js +104 -0
- package/lib/server/chromium/crDragDrop.js +143 -0
- package/lib/server/chromium/crExecutionContext.js +149 -0
- package/lib/server/chromium/crInput.js +171 -0
- package/lib/server/chromium/crNetworkManager.js +809 -0
- package/lib/server/chromium/crPage.js +1235 -0
- package/lib/server/chromium/crPdf.js +153 -0
- package/lib/server/chromium/crProtocolHelper.js +133 -0
- package/lib/server/chromium/crServiceWorker.js +111 -0
- package/lib/server/chromium/defaultFontFamilies.js +145 -0
- package/lib/server/chromium/videoRecorder.js +155 -0
- package/lib/server/clock.js +133 -0
- package/lib/server/codegen/csharp.js +299 -0
- package/lib/server/codegen/java.js +235 -0
- package/lib/server/codegen/javascript.js +223 -0
- package/lib/server/codegen/jsonl.js +47 -0
- package/lib/server/codegen/language.js +88 -0
- package/lib/server/codegen/languages.js +30 -0
- package/lib/server/codegen/python.js +265 -0
- package/lib/server/codegen/types.js +5 -0
- package/lib/server/console.js +57 -0
- package/lib/server/cookieStore.js +185 -0
- package/lib/server/debugController.js +234 -0
- package/lib/server/debugger.js +132 -0
- package/lib/server/deviceDescriptors.js +26 -0
- package/lib/server/deviceDescriptorsSource.json +1669 -0
- package/lib/server/dialog.js +71 -0
- package/lib/server/dispatchers/androidDispatcher.js +193 -0
- package/lib/server/dispatchers/artifactDispatcher.js +118 -0
- package/lib/server/dispatchers/browserContextDispatcher.js +368 -0
- package/lib/server/dispatchers/browserDispatcher.js +170 -0
- package/lib/server/dispatchers/browserTypeDispatcher.js +55 -0
- package/lib/server/dispatchers/cdpSessionDispatcher.js +48 -0
- package/lib/server/dispatchers/debugControllerDispatcher.js +103 -0
- package/lib/server/dispatchers/dialogDispatcher.js +44 -0
- package/lib/server/dispatchers/dispatcher.js +395 -0
- package/lib/server/dispatchers/electronDispatcher.js +93 -0
- package/lib/server/dispatchers/elementHandlerDispatcher.js +228 -0
- package/lib/server/dispatchers/frameDispatcher.js +286 -0
- package/lib/server/dispatchers/jsHandleDispatcher.js +97 -0
- package/lib/server/dispatchers/jsonPipeDispatcher.js +59 -0
- package/lib/server/dispatchers/localUtilsDispatcher.js +413 -0
- package/lib/server/dispatchers/networkDispatchers.js +221 -0
- package/lib/server/dispatchers/pageDispatcher.js +367 -0
- package/lib/server/dispatchers/playwrightDispatcher.js +107 -0
- package/lib/server/dispatchers/selectorsDispatcher.js +36 -0
- package/lib/server/dispatchers/streamDispatcher.js +62 -0
- package/lib/server/dispatchers/tracingDispatcher.js +54 -0
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +189 -0
- package/lib/server/dispatchers/writableStreamDispatcher.js +58 -0
- package/lib/server/dom.js +845 -0
- package/lib/server/download.js +60 -0
- package/lib/server/electron/electron.js +296 -0
- package/lib/server/electron/loader.js +57 -0
- package/lib/server/errors.js +68 -0
- package/lib/server/fetch.js +656 -0
- package/lib/server/fileChooser.js +42 -0
- package/lib/server/fileUploadUtils.js +75 -0
- package/lib/server/firefox/ffAccessibility.js +216 -0
- package/lib/server/firefox/ffBrowser.js +460 -0
- package/lib/server/firefox/ffConnection.js +168 -0
- package/lib/server/firefox/ffExecutionContext.js +135 -0
- package/lib/server/firefox/ffInput.js +150 -0
- package/lib/server/firefox/ffNetworkManager.js +233 -0
- package/lib/server/firefox/ffPage.js +559 -0
- package/lib/server/firefox/firefox.js +99 -0
- package/lib/server/formData.js +75 -0
- package/lib/server/frameSelectors.js +171 -0
- package/lib/server/frames.js +1808 -0
- package/lib/server/har/harRecorder.js +139 -0
- package/lib/server/har/harTracer.js +542 -0
- package/lib/server/helper.js +103 -0
- package/lib/server/index.js +114 -0
- package/lib/server/input.js +310 -0
- package/lib/server/instrumentation.js +70 -0
- package/lib/server/isomorphic/utilityScriptSerializers.js +226 -0
- package/lib/server/javascript.js +299 -0
- package/lib/server/launchApp.js +91 -0
- package/lib/server/macEditingCommands.js +139 -0
- package/lib/server/network.js +617 -0
- package/lib/server/page.js +819 -0
- package/lib/server/pipeTransport.js +85 -0
- package/lib/server/playwright.js +88 -0
- package/lib/server/progress.js +102 -0
- package/lib/server/protocolError.js +49 -0
- package/lib/server/recorder/contextRecorder.js +299 -0
- package/lib/server/recorder/recorderApp.js +196 -0
- package/lib/server/recorder/recorderCollection.js +116 -0
- package/lib/server/recorder/recorderFrontend.js +5 -0
- package/lib/server/recorder/recorderInTraceViewer.js +144 -0
- package/lib/server/recorder/recorderRunner.js +155 -0
- package/lib/server/recorder/recorderUtils.js +112 -0
- package/lib/server/recorder/throttledFile.js +46 -0
- package/lib/server/recorder.js +329 -0
- package/lib/server/registry/browserFetcher.js +168 -0
- package/lib/server/registry/dependencies.js +322 -0
- package/lib/server/registry/index.js +1005 -0
- package/lib/server/registry/nativeDeps.js +490 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +138 -0
- package/lib/server/screenshotter.js +348 -0
- package/lib/server/selectors.js +73 -0
- package/lib/server/socksClientCertificatesInterceptor.js +340 -0
- package/lib/server/socksInterceptor.js +100 -0
- package/lib/server/trace/recorder/snapshotter.js +172 -0
- package/lib/server/trace/recorder/snapshotterInjected.js +493 -0
- package/lib/server/trace/recorder/tracing.js +542 -0
- package/lib/server/trace/test/inMemorySnapshotter.js +93 -0
- package/lib/server/trace/viewer/traceViewer.js +213 -0
- package/lib/server/transport.js +191 -0
- package/lib/server/types.js +24 -0
- package/lib/server/usKeyboardLayout.js +555 -0
- package/lib/server/webkit/webkit.js +87 -0
- package/lib/server/webkit/wkAccessibility.js +194 -0
- package/lib/server/webkit/wkBrowser.js +329 -0
- package/lib/server/webkit/wkConnection.js +173 -0
- package/lib/server/webkit/wkExecutionContext.js +143 -0
- package/lib/server/webkit/wkInput.js +169 -0
- package/lib/server/webkit/wkInterceptableRequest.js +162 -0
- package/lib/server/webkit/wkPage.js +1219 -0
- package/lib/server/webkit/wkProvisionalPage.js +94 -0
- package/lib/server/webkit/wkWorkers.js +104 -0
- package/lib/third_party/diff_match_patch.js +2222 -0
- package/lib/third_party/pixelmatch.js +255 -0
- package/lib/utils/ascii.js +31 -0
- package/lib/utils/comparators.js +171 -0
- package/lib/utils/crypto.js +174 -0
- package/lib/utils/debug.js +46 -0
- package/lib/utils/debugLogger.js +91 -0
- package/lib/utils/env.js +49 -0
- package/lib/utils/eventsHelper.js +38 -0
- package/lib/utils/expectUtils.js +33 -0
- package/lib/utils/fileUtils.js +205 -0
- package/lib/utils/happy-eyeballs.js +194 -0
- package/lib/utils/headers.js +52 -0
- package/lib/utils/hostPlatform.js +133 -0
- package/lib/utils/httpServer.js +237 -0
- package/lib/utils/index.js +368 -0
- package/lib/utils/isomorphic/cssParser.js +250 -0
- package/lib/utils/isomorphic/cssTokenizer.js +979 -0
- package/lib/utils/isomorphic/locatorGenerators.js +642 -0
- package/lib/utils/isomorphic/locatorParser.js +179 -0
- package/lib/utils/isomorphic/locatorUtils.js +62 -0
- package/lib/utils/isomorphic/mimeType.js +29 -0
- package/lib/utils/isomorphic/recorderUtils.js +195 -0
- package/lib/utils/isomorphic/selectorParser.js +397 -0
- package/lib/utils/isomorphic/stringUtils.js +139 -0
- package/lib/utils/isomorphic/traceUtils.js +39 -0
- package/lib/utils/isomorphic/urlMatch.js +120 -0
- package/lib/utils/linuxUtils.js +78 -0
- package/lib/utils/manualPromise.js +109 -0
- package/lib/utils/multimap.js +75 -0
- package/lib/utils/network.js +160 -0
- package/lib/utils/processLauncher.js +248 -0
- package/lib/utils/profiler.js +53 -0
- package/lib/utils/rtti.js +44 -0
- package/lib/utils/semaphore.js +51 -0
- package/lib/utils/spawnAsync.js +45 -0
- package/lib/utils/stackTrace.js +121 -0
- package/lib/utils/task.js +58 -0
- package/lib/utils/time.js +37 -0
- package/lib/utils/timeoutRunner.js +66 -0
- package/lib/utils/traceUtils.js +44 -0
- package/lib/utils/userAgent.js +105 -0
- package/lib/utils/wsServer.js +127 -0
- package/lib/utils/zipFile.js +75 -0
- package/lib/utils/zones.js +62 -0
- package/lib/utilsBundle.js +82 -0
- package/lib/utilsBundleImpl/index.js +53 -0
- package/lib/utilsBundleImpl/xdg-open +1066 -0
- package/lib/vite/htmlReport/index.html +66 -0
- package/lib/vite/recorder/assets/codeMirrorModule-baozm8ur.js +24 -0
- package/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +1 -0
- package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/recorder/assets/index-2ElAIWFB.js +42 -0
- package/lib/vite/recorder/assets/index-BW-aOBcL.css +1 -0
- package/lib/vite/recorder/index.html +29 -0
- package/lib/vite/recorder/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-Bh1rfd2w.js +24 -0
- package/lib/vite/traceViewer/assets/inspectorTab-7GHnKvSD.js +64 -0
- package/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +1 -0
- package/lib/vite/traceViewer/assets/workbench-DPQnTHYP.js +9 -0
- package/lib/vite/traceViewer/assets/xtermModule-BeNbaIVa.js +9 -0
- package/lib/vite/traceViewer/codeMirrorModule.ez37Vkbh.css +1 -0
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/embedded.BlHoW5LY.js +2 -0
- package/lib/vite/traceViewer/embedded.html +18 -0
- package/lib/vite/traceViewer/embedded.w7WN2u1R.css +1 -0
- package/lib/vite/traceViewer/index.CrbWWHbf.css +1 -0
- package/lib/vite/traceViewer/index.DaWVfou1.js +2 -0
- package/lib/vite/traceViewer/index.html +29 -0
- package/lib/vite/traceViewer/inspectorTab.DLjBDrQR.css +1 -0
- package/lib/vite/traceViewer/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/recorder.B_SY1GJM.css +0 -0
- package/lib/vite/traceViewer/recorder.C4zxcvd2.js +2 -0
- package/lib/vite/traceViewer/recorder.html +17 -0
- package/lib/vite/traceViewer/snapshot.html +21 -0
- package/lib/vite/traceViewer/sw.bundle.js +3 -0
- package/lib/vite/traceViewer/uiMode.CAYqod-m.css +1 -0
- package/lib/vite/traceViewer/uiMode.html +20 -0
- package/lib/vite/traceViewer/uiMode.mTXWniJb.js +5 -0
- package/lib/vite/traceViewer/workbench.D3JVcA9K.css +1 -0
- package/lib/vite/traceViewer/xtermModule.DSXBckUd.css +32 -0
- package/lib/zipBundle.js +25 -0
- package/lib/zipBundleImpl.js +5 -0
- package/package.json +44 -0
- package/types/protocol.d.ts +21571 -0
- package/types/structs.d.ts +45 -0
- package/types/types.d.ts +22519 -0
|
@@ -0,0 +1,762 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.WebSocketRouteHandler = exports.WebSocketRoute = exports.WebSocket = exports.RouteHandler = exports.Route = exports.Response = exports.Request = exports.RawHeaders = void 0;
|
|
7
|
+
exports.validateHeaders = validateHeaders;
|
|
8
|
+
var _url = require("url");
|
|
9
|
+
var _channelOwner = require("./channelOwner");
|
|
10
|
+
var _frame = require("./frame");
|
|
11
|
+
var _worker = require("./worker");
|
|
12
|
+
var _fs = _interopRequireDefault(require("fs"));
|
|
13
|
+
var _utilsBundle = require("../utilsBundle");
|
|
14
|
+
var _utils = require("../utils");
|
|
15
|
+
var _manualPromise = require("../utils/manualPromise");
|
|
16
|
+
var _events = require("./events");
|
|
17
|
+
var _waiter = require("./waiter");
|
|
18
|
+
var _fetch = require("./fetch");
|
|
19
|
+
var _errors = require("./errors");
|
|
20
|
+
let _Symbol$asyncDispose;
|
|
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
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
37
|
+
class Request extends _channelOwner.ChannelOwner {
|
|
38
|
+
static from(request) {
|
|
39
|
+
return request._object;
|
|
40
|
+
}
|
|
41
|
+
static fromNullable(request) {
|
|
42
|
+
return request ? Request.from(request) : null;
|
|
43
|
+
}
|
|
44
|
+
constructor(parent, type, guid, initializer) {
|
|
45
|
+
super(parent, type, guid, initializer);
|
|
46
|
+
this._redirectedFrom = null;
|
|
47
|
+
this._redirectedTo = null;
|
|
48
|
+
this._failureText = null;
|
|
49
|
+
this._provisionalHeaders = void 0;
|
|
50
|
+
this._actualHeadersPromise = void 0;
|
|
51
|
+
this._timing = void 0;
|
|
52
|
+
this._fallbackOverrides = {};
|
|
53
|
+
this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
|
|
54
|
+
if (this._redirectedFrom) this._redirectedFrom._redirectedTo = this;
|
|
55
|
+
this._provisionalHeaders = new RawHeaders(initializer.headers);
|
|
56
|
+
this._timing = {
|
|
57
|
+
startTime: 0,
|
|
58
|
+
domainLookupStart: -1,
|
|
59
|
+
domainLookupEnd: -1,
|
|
60
|
+
connectStart: -1,
|
|
61
|
+
secureConnectionStart: -1,
|
|
62
|
+
connectEnd: -1,
|
|
63
|
+
requestStart: -1,
|
|
64
|
+
responseStart: -1,
|
|
65
|
+
responseEnd: -1
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
url() {
|
|
69
|
+
return this._fallbackOverrides.url || this._initializer.url;
|
|
70
|
+
}
|
|
71
|
+
resourceType() {
|
|
72
|
+
return this._initializer.resourceType;
|
|
73
|
+
}
|
|
74
|
+
method() {
|
|
75
|
+
return this._fallbackOverrides.method || this._initializer.method;
|
|
76
|
+
}
|
|
77
|
+
postData() {
|
|
78
|
+
var _ref;
|
|
79
|
+
return ((_ref = this._fallbackOverrides.postDataBuffer || this._initializer.postData) === null || _ref === void 0 ? void 0 : _ref.toString('utf-8')) || null;
|
|
80
|
+
}
|
|
81
|
+
postDataBuffer() {
|
|
82
|
+
return this._fallbackOverrides.postDataBuffer || this._initializer.postData || null;
|
|
83
|
+
}
|
|
84
|
+
postDataJSON() {
|
|
85
|
+
const postData = this.postData();
|
|
86
|
+
if (!postData) return null;
|
|
87
|
+
const contentType = this.headers()['content-type'];
|
|
88
|
+
if (contentType !== null && contentType !== void 0 && contentType.includes('application/x-www-form-urlencoded')) {
|
|
89
|
+
const entries = {};
|
|
90
|
+
const parsed = new _url.URLSearchParams(postData);
|
|
91
|
+
for (const [k, v] of parsed.entries()) entries[k] = v;
|
|
92
|
+
return entries;
|
|
93
|
+
}
|
|
94
|
+
try {
|
|
95
|
+
return JSON.parse(postData);
|
|
96
|
+
} catch (e) {
|
|
97
|
+
throw new Error('POST data is not a valid JSON object: ' + postData);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* @deprecated
|
|
103
|
+
*/
|
|
104
|
+
headers() {
|
|
105
|
+
if (this._fallbackOverrides.headers) return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers).headers();
|
|
106
|
+
return this._provisionalHeaders.headers();
|
|
107
|
+
}
|
|
108
|
+
async _actualHeaders() {
|
|
109
|
+
if (this._fallbackOverrides.headers) return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers);
|
|
110
|
+
if (!this._actualHeadersPromise) {
|
|
111
|
+
this._actualHeadersPromise = this._wrapApiCall(async () => {
|
|
112
|
+
return new RawHeaders((await this._channel.rawRequestHeaders()).headers);
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
return await this._actualHeadersPromise;
|
|
116
|
+
}
|
|
117
|
+
async allHeaders() {
|
|
118
|
+
return (await this._actualHeaders()).headers();
|
|
119
|
+
}
|
|
120
|
+
async headersArray() {
|
|
121
|
+
return (await this._actualHeaders()).headersArray();
|
|
122
|
+
}
|
|
123
|
+
async headerValue(name) {
|
|
124
|
+
return (await this._actualHeaders()).get(name);
|
|
125
|
+
}
|
|
126
|
+
async response() {
|
|
127
|
+
return Response.fromNullable((await this._channel.response()).response);
|
|
128
|
+
}
|
|
129
|
+
async _internalResponse() {
|
|
130
|
+
return await this._wrapApiCall(async () => {
|
|
131
|
+
return Response.fromNullable((await this._channel.response()).response);
|
|
132
|
+
}, true);
|
|
133
|
+
}
|
|
134
|
+
frame() {
|
|
135
|
+
if (!this._initializer.frame) {
|
|
136
|
+
(0, _utils.assert)(this.serviceWorker());
|
|
137
|
+
throw new Error('Service Worker requests do not have an associated frame.');
|
|
138
|
+
}
|
|
139
|
+
const frame = _frame.Frame.from(this._initializer.frame);
|
|
140
|
+
if (!frame._page) {
|
|
141
|
+
throw new Error(['Frame for this navigation request is not available, because the request', 'was issued before the frame is created. You can check whether the request', 'is a navigation request by calling isNavigationRequest() method.'].join('\n'));
|
|
142
|
+
}
|
|
143
|
+
return frame;
|
|
144
|
+
}
|
|
145
|
+
_safePage() {
|
|
146
|
+
var _Frame$fromNullable;
|
|
147
|
+
return ((_Frame$fromNullable = _frame.Frame.fromNullable(this._initializer.frame)) === null || _Frame$fromNullable === void 0 ? void 0 : _Frame$fromNullable._page) || null;
|
|
148
|
+
}
|
|
149
|
+
serviceWorker() {
|
|
150
|
+
return this._initializer.serviceWorker ? _worker.Worker.from(this._initializer.serviceWorker) : null;
|
|
151
|
+
}
|
|
152
|
+
isNavigationRequest() {
|
|
153
|
+
return this._initializer.isNavigationRequest;
|
|
154
|
+
}
|
|
155
|
+
redirectedFrom() {
|
|
156
|
+
return this._redirectedFrom;
|
|
157
|
+
}
|
|
158
|
+
redirectedTo() {
|
|
159
|
+
return this._redirectedTo;
|
|
160
|
+
}
|
|
161
|
+
failure() {
|
|
162
|
+
if (this._failureText === null) return null;
|
|
163
|
+
return {
|
|
164
|
+
errorText: this._failureText
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
timing() {
|
|
168
|
+
return this._timing;
|
|
169
|
+
}
|
|
170
|
+
async sizes() {
|
|
171
|
+
const response = await this.response();
|
|
172
|
+
if (!response) throw new Error('Unable to fetch sizes for failed request');
|
|
173
|
+
return (await response._channel.sizes()).sizes;
|
|
174
|
+
}
|
|
175
|
+
_setResponseEndTiming(responseEndTiming) {
|
|
176
|
+
this._timing.responseEnd = responseEndTiming;
|
|
177
|
+
if (this._timing.responseStart === -1) this._timing.responseStart = responseEndTiming;
|
|
178
|
+
}
|
|
179
|
+
_finalRequest() {
|
|
180
|
+
return this._redirectedTo ? this._redirectedTo._finalRequest() : this;
|
|
181
|
+
}
|
|
182
|
+
_applyFallbackOverrides(overrides) {
|
|
183
|
+
if (overrides.url) this._fallbackOverrides.url = overrides.url;
|
|
184
|
+
if (overrides.method) this._fallbackOverrides.method = overrides.method;
|
|
185
|
+
if (overrides.headers) this._fallbackOverrides.headers = overrides.headers;
|
|
186
|
+
if ((0, _utils.isString)(overrides.postData)) this._fallbackOverrides.postDataBuffer = Buffer.from(overrides.postData, 'utf-8');else if (overrides.postData instanceof Buffer) this._fallbackOverrides.postDataBuffer = overrides.postData;else if (overrides.postData) this._fallbackOverrides.postDataBuffer = Buffer.from(JSON.stringify(overrides.postData), 'utf-8');
|
|
187
|
+
}
|
|
188
|
+
_fallbackOverridesForContinue() {
|
|
189
|
+
return this._fallbackOverrides;
|
|
190
|
+
}
|
|
191
|
+
_targetClosedScope() {
|
|
192
|
+
var _this$serviceWorker, _this$_safePage;
|
|
193
|
+
return ((_this$serviceWorker = this.serviceWorker()) === null || _this$serviceWorker === void 0 ? void 0 : _this$serviceWorker._closedScope) || ((_this$_safePage = this._safePage()) === null || _this$_safePage === void 0 ? void 0 : _this$_safePage._closedOrCrashedScope) || new _manualPromise.LongStandingScope();
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
exports.Request = Request;
|
|
197
|
+
class Route extends _channelOwner.ChannelOwner {
|
|
198
|
+
static from(route) {
|
|
199
|
+
return route._object;
|
|
200
|
+
}
|
|
201
|
+
constructor(parent, type, guid, initializer) {
|
|
202
|
+
super(parent, type, guid, initializer);
|
|
203
|
+
this._handlingPromise = null;
|
|
204
|
+
this._context = void 0;
|
|
205
|
+
this._didThrow = false;
|
|
206
|
+
this.markAsInternalType();
|
|
207
|
+
}
|
|
208
|
+
request() {
|
|
209
|
+
return Request.from(this._initializer.request);
|
|
210
|
+
}
|
|
211
|
+
async _raceWithTargetClose(promise) {
|
|
212
|
+
// When page closes or crashes, we catch any potential rejects from this Route.
|
|
213
|
+
// Note that page could be missing when routing popup's initial request that
|
|
214
|
+
// does not have a Page initialized just yet.
|
|
215
|
+
return await this.request()._targetClosedScope().safeRace(promise);
|
|
216
|
+
}
|
|
217
|
+
async _startHandling() {
|
|
218
|
+
this._handlingPromise = new _manualPromise.ManualPromise();
|
|
219
|
+
return await this._handlingPromise;
|
|
220
|
+
}
|
|
221
|
+
async fallback(options = {}) {
|
|
222
|
+
this._checkNotHandled();
|
|
223
|
+
this.request()._applyFallbackOverrides(options);
|
|
224
|
+
this._reportHandled(false);
|
|
225
|
+
}
|
|
226
|
+
async abort(errorCode) {
|
|
227
|
+
await this._handleRoute(async () => {
|
|
228
|
+
await this._raceWithTargetClose(this._channel.abort({
|
|
229
|
+
errorCode
|
|
230
|
+
}));
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
async _redirectNavigationRequest(url) {
|
|
234
|
+
await this._handleRoute(async () => {
|
|
235
|
+
await this._raceWithTargetClose(this._channel.redirectNavigationRequest({
|
|
236
|
+
url
|
|
237
|
+
}));
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
async fetch(options = {}) {
|
|
241
|
+
return await this._wrapApiCall(async () => {
|
|
242
|
+
return await this._context.request._innerFetch({
|
|
243
|
+
request: this.request(),
|
|
244
|
+
data: options.postData,
|
|
245
|
+
...options
|
|
246
|
+
});
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
async fulfill(options = {}) {
|
|
250
|
+
await this._handleRoute(async () => {
|
|
251
|
+
await this._wrapApiCall(async () => {
|
|
252
|
+
await this._innerFulfill(options);
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
async _handleRoute(callback) {
|
|
257
|
+
this._checkNotHandled();
|
|
258
|
+
try {
|
|
259
|
+
await callback();
|
|
260
|
+
this._reportHandled(true);
|
|
261
|
+
} catch (e) {
|
|
262
|
+
this._didThrow = true;
|
|
263
|
+
throw e;
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
async _innerFulfill(options = {}) {
|
|
267
|
+
let fetchResponseUid;
|
|
268
|
+
let {
|
|
269
|
+
status: statusOption,
|
|
270
|
+
headers: headersOption,
|
|
271
|
+
body
|
|
272
|
+
} = options;
|
|
273
|
+
if (options.json !== undefined) {
|
|
274
|
+
(0, _utils.assert)(options.body === undefined, 'Can specify either body or json parameters');
|
|
275
|
+
body = JSON.stringify(options.json);
|
|
276
|
+
}
|
|
277
|
+
if (options.response instanceof _fetch.APIResponse) {
|
|
278
|
+
var _statusOption, _headersOption;
|
|
279
|
+
(_statusOption = statusOption) !== null && _statusOption !== void 0 ? _statusOption : statusOption = options.response.status();
|
|
280
|
+
(_headersOption = headersOption) !== null && _headersOption !== void 0 ? _headersOption : headersOption = options.response.headers();
|
|
281
|
+
if (body === undefined && options.path === undefined) {
|
|
282
|
+
if (options.response._request._connection === this._connection) fetchResponseUid = options.response._fetchUid();else body = await options.response.body();
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
let isBase64 = false;
|
|
286
|
+
let length = 0;
|
|
287
|
+
if (options.path) {
|
|
288
|
+
const buffer = await _fs.default.promises.readFile(options.path);
|
|
289
|
+
body = buffer.toString('base64');
|
|
290
|
+
isBase64 = true;
|
|
291
|
+
length = buffer.length;
|
|
292
|
+
} else if ((0, _utils.isString)(body)) {
|
|
293
|
+
isBase64 = false;
|
|
294
|
+
length = Buffer.byteLength(body);
|
|
295
|
+
} else if (body) {
|
|
296
|
+
length = body.length;
|
|
297
|
+
body = body.toString('base64');
|
|
298
|
+
isBase64 = true;
|
|
299
|
+
}
|
|
300
|
+
const headers = {};
|
|
301
|
+
for (const header of Object.keys(headersOption || {})) headers[header.toLowerCase()] = String(headersOption[header]);
|
|
302
|
+
if (options.contentType) headers['content-type'] = String(options.contentType);else if (options.json) headers['content-type'] = 'application/json';else if (options.path) headers['content-type'] = _utilsBundle.mime.getType(options.path) || 'application/octet-stream';
|
|
303
|
+
if (length && !('content-length' in headers)) headers['content-length'] = String(length);
|
|
304
|
+
await this._raceWithTargetClose(this._channel.fulfill({
|
|
305
|
+
status: statusOption || 200,
|
|
306
|
+
headers: (0, _utils.headersObjectToArray)(headers),
|
|
307
|
+
body,
|
|
308
|
+
isBase64,
|
|
309
|
+
fetchResponseUid
|
|
310
|
+
}));
|
|
311
|
+
}
|
|
312
|
+
async continue(options = {}) {
|
|
313
|
+
await this._handleRoute(async () => {
|
|
314
|
+
this.request()._applyFallbackOverrides(options);
|
|
315
|
+
await this._innerContinue(false /* isFallback */);
|
|
316
|
+
});
|
|
317
|
+
}
|
|
318
|
+
_checkNotHandled() {
|
|
319
|
+
if (!this._handlingPromise) throw new Error('Route is already handled!');
|
|
320
|
+
}
|
|
321
|
+
_reportHandled(done) {
|
|
322
|
+
const chain = this._handlingPromise;
|
|
323
|
+
this._handlingPromise = null;
|
|
324
|
+
chain.resolve(done);
|
|
325
|
+
}
|
|
326
|
+
async _innerContinue(isFallback) {
|
|
327
|
+
const options = this.request()._fallbackOverridesForContinue();
|
|
328
|
+
return await this._raceWithTargetClose(this._channel.continue({
|
|
329
|
+
url: options.url,
|
|
330
|
+
method: options.method,
|
|
331
|
+
headers: options.headers ? (0, _utils.headersObjectToArray)(options.headers) : undefined,
|
|
332
|
+
postData: options.postDataBuffer,
|
|
333
|
+
isFallback
|
|
334
|
+
}));
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
exports.Route = Route;
|
|
338
|
+
_Symbol$asyncDispose = Symbol.asyncDispose;
|
|
339
|
+
class WebSocketRoute extends _channelOwner.ChannelOwner {
|
|
340
|
+
static from(route) {
|
|
341
|
+
return route._object;
|
|
342
|
+
}
|
|
343
|
+
constructor(parent, type, guid, initializer) {
|
|
344
|
+
super(parent, type, guid, initializer);
|
|
345
|
+
this._onPageMessage = void 0;
|
|
346
|
+
this._onPageClose = void 0;
|
|
347
|
+
this._onServerMessage = void 0;
|
|
348
|
+
this._onServerClose = void 0;
|
|
349
|
+
this._server = void 0;
|
|
350
|
+
this._connected = false;
|
|
351
|
+
this.markAsInternalType();
|
|
352
|
+
this._server = {
|
|
353
|
+
onMessage: handler => {
|
|
354
|
+
this._onServerMessage = handler;
|
|
355
|
+
},
|
|
356
|
+
onClose: handler => {
|
|
357
|
+
this._onServerClose = handler;
|
|
358
|
+
},
|
|
359
|
+
connectToServer: () => {
|
|
360
|
+
throw new Error(`connectToServer must be called on the page-side WebSocketRoute`);
|
|
361
|
+
},
|
|
362
|
+
url: () => {
|
|
363
|
+
return this._initializer.url;
|
|
364
|
+
},
|
|
365
|
+
close: async (options = {}) => {
|
|
366
|
+
await this._channel.closeServer({
|
|
367
|
+
...options,
|
|
368
|
+
wasClean: true
|
|
369
|
+
}).catch(() => {});
|
|
370
|
+
},
|
|
371
|
+
send: message => {
|
|
372
|
+
if ((0, _utils.isString)(message)) this._channel.sendToServer({
|
|
373
|
+
message,
|
|
374
|
+
isBase64: false
|
|
375
|
+
}).catch(() => {});else this._channel.sendToServer({
|
|
376
|
+
message: message.toString('base64'),
|
|
377
|
+
isBase64: true
|
|
378
|
+
}).catch(() => {});
|
|
379
|
+
},
|
|
380
|
+
async [Symbol.asyncDispose]() {
|
|
381
|
+
await this.close();
|
|
382
|
+
}
|
|
383
|
+
};
|
|
384
|
+
this._channel.on('messageFromPage', ({
|
|
385
|
+
message,
|
|
386
|
+
isBase64
|
|
387
|
+
}) => {
|
|
388
|
+
if (this._onPageMessage) this._onPageMessage(isBase64 ? Buffer.from(message, 'base64') : message);else if (this._connected) this._channel.sendToServer({
|
|
389
|
+
message,
|
|
390
|
+
isBase64
|
|
391
|
+
}).catch(() => {});
|
|
392
|
+
});
|
|
393
|
+
this._channel.on('messageFromServer', ({
|
|
394
|
+
message,
|
|
395
|
+
isBase64
|
|
396
|
+
}) => {
|
|
397
|
+
if (this._onServerMessage) this._onServerMessage(isBase64 ? Buffer.from(message, 'base64') : message);else this._channel.sendToPage({
|
|
398
|
+
message,
|
|
399
|
+
isBase64
|
|
400
|
+
}).catch(() => {});
|
|
401
|
+
});
|
|
402
|
+
this._channel.on('closePage', ({
|
|
403
|
+
code,
|
|
404
|
+
reason,
|
|
405
|
+
wasClean
|
|
406
|
+
}) => {
|
|
407
|
+
if (this._onPageClose) this._onPageClose(code, reason);else this._channel.closeServer({
|
|
408
|
+
code,
|
|
409
|
+
reason,
|
|
410
|
+
wasClean
|
|
411
|
+
}).catch(() => {});
|
|
412
|
+
});
|
|
413
|
+
this._channel.on('closeServer', ({
|
|
414
|
+
code,
|
|
415
|
+
reason,
|
|
416
|
+
wasClean
|
|
417
|
+
}) => {
|
|
418
|
+
if (this._onServerClose) this._onServerClose(code, reason);else this._channel.closePage({
|
|
419
|
+
code,
|
|
420
|
+
reason,
|
|
421
|
+
wasClean
|
|
422
|
+
}).catch(() => {});
|
|
423
|
+
});
|
|
424
|
+
}
|
|
425
|
+
url() {
|
|
426
|
+
return this._initializer.url;
|
|
427
|
+
}
|
|
428
|
+
async close(options = {}) {
|
|
429
|
+
await this._channel.closePage({
|
|
430
|
+
...options,
|
|
431
|
+
wasClean: true
|
|
432
|
+
}).catch(() => {});
|
|
433
|
+
}
|
|
434
|
+
connectToServer() {
|
|
435
|
+
if (this._connected) throw new Error('Already connected to the server');
|
|
436
|
+
this._connected = true;
|
|
437
|
+
this._channel.connect().catch(() => {});
|
|
438
|
+
return this._server;
|
|
439
|
+
}
|
|
440
|
+
send(message) {
|
|
441
|
+
if ((0, _utils.isString)(message)) this._channel.sendToPage({
|
|
442
|
+
message,
|
|
443
|
+
isBase64: false
|
|
444
|
+
}).catch(() => {});else this._channel.sendToPage({
|
|
445
|
+
message: message.toString('base64'),
|
|
446
|
+
isBase64: true
|
|
447
|
+
}).catch(() => {});
|
|
448
|
+
}
|
|
449
|
+
onMessage(handler) {
|
|
450
|
+
this._onPageMessage = handler;
|
|
451
|
+
}
|
|
452
|
+
onClose(handler) {
|
|
453
|
+
this._onPageClose = handler;
|
|
454
|
+
}
|
|
455
|
+
async [_Symbol$asyncDispose]() {
|
|
456
|
+
await this.close();
|
|
457
|
+
}
|
|
458
|
+
async _afterHandle() {
|
|
459
|
+
if (this._connected) return;
|
|
460
|
+
// Ensure that websocket is "open" and can send messages without an actual server connection.
|
|
461
|
+
await this._channel.ensureOpened();
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
exports.WebSocketRoute = WebSocketRoute;
|
|
465
|
+
class WebSocketRouteHandler {
|
|
466
|
+
constructor(baseURL, url, handler) {
|
|
467
|
+
this._baseURL = void 0;
|
|
468
|
+
this.url = void 0;
|
|
469
|
+
this.handler = void 0;
|
|
470
|
+
this._baseURL = baseURL;
|
|
471
|
+
this.url = url;
|
|
472
|
+
this.handler = handler;
|
|
473
|
+
}
|
|
474
|
+
static prepareInterceptionPatterns(handlers) {
|
|
475
|
+
const patterns = [];
|
|
476
|
+
let all = false;
|
|
477
|
+
for (const handler of handlers) {
|
|
478
|
+
if ((0, _utils.isString)(handler.url)) patterns.push({
|
|
479
|
+
glob: handler.url
|
|
480
|
+
});else if ((0, _utils.isRegExp)(handler.url)) patterns.push({
|
|
481
|
+
regexSource: handler.url.source,
|
|
482
|
+
regexFlags: handler.url.flags
|
|
483
|
+
});else all = true;
|
|
484
|
+
}
|
|
485
|
+
if (all) return [{
|
|
486
|
+
glob: '**/*'
|
|
487
|
+
}];
|
|
488
|
+
return patterns;
|
|
489
|
+
}
|
|
490
|
+
matches(wsURL) {
|
|
491
|
+
return (0, _utils.urlMatches)(this._baseURL, wsURL, this.url);
|
|
492
|
+
}
|
|
493
|
+
async handle(webSocketRoute) {
|
|
494
|
+
const handler = this.handler;
|
|
495
|
+
await handler(webSocketRoute);
|
|
496
|
+
await webSocketRoute._afterHandle();
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
exports.WebSocketRouteHandler = WebSocketRouteHandler;
|
|
500
|
+
class Response extends _channelOwner.ChannelOwner {
|
|
501
|
+
static from(response) {
|
|
502
|
+
return response._object;
|
|
503
|
+
}
|
|
504
|
+
static fromNullable(response) {
|
|
505
|
+
return response ? Response.from(response) : null;
|
|
506
|
+
}
|
|
507
|
+
constructor(parent, type, guid, initializer) {
|
|
508
|
+
super(parent, type, guid, initializer);
|
|
509
|
+
this._provisionalHeaders = void 0;
|
|
510
|
+
this._actualHeadersPromise = void 0;
|
|
511
|
+
this._request = void 0;
|
|
512
|
+
this._finishedPromise = new _manualPromise.ManualPromise();
|
|
513
|
+
this._provisionalHeaders = new RawHeaders(initializer.headers);
|
|
514
|
+
this._request = Request.from(this._initializer.request);
|
|
515
|
+
Object.assign(this._request._timing, this._initializer.timing);
|
|
516
|
+
}
|
|
517
|
+
url() {
|
|
518
|
+
return this._initializer.url;
|
|
519
|
+
}
|
|
520
|
+
ok() {
|
|
521
|
+
// Status 0 is for file:// URLs
|
|
522
|
+
return this._initializer.status === 0 || this._initializer.status >= 200 && this._initializer.status <= 299;
|
|
523
|
+
}
|
|
524
|
+
status() {
|
|
525
|
+
return this._initializer.status;
|
|
526
|
+
}
|
|
527
|
+
statusText() {
|
|
528
|
+
return this._initializer.statusText;
|
|
529
|
+
}
|
|
530
|
+
fromServiceWorker() {
|
|
531
|
+
return this._initializer.fromServiceWorker;
|
|
532
|
+
}
|
|
533
|
+
|
|
534
|
+
/**
|
|
535
|
+
* @deprecated
|
|
536
|
+
*/
|
|
537
|
+
headers() {
|
|
538
|
+
return this._provisionalHeaders.headers();
|
|
539
|
+
}
|
|
540
|
+
async _actualHeaders() {
|
|
541
|
+
if (!this._actualHeadersPromise) {
|
|
542
|
+
this._actualHeadersPromise = (async () => {
|
|
543
|
+
return new RawHeaders((await this._channel.rawResponseHeaders()).headers);
|
|
544
|
+
})();
|
|
545
|
+
}
|
|
546
|
+
return await this._actualHeadersPromise;
|
|
547
|
+
}
|
|
548
|
+
async allHeaders() {
|
|
549
|
+
return (await this._actualHeaders()).headers();
|
|
550
|
+
}
|
|
551
|
+
async headersArray() {
|
|
552
|
+
return (await this._actualHeaders()).headersArray().slice();
|
|
553
|
+
}
|
|
554
|
+
async headerValue(name) {
|
|
555
|
+
return (await this._actualHeaders()).get(name);
|
|
556
|
+
}
|
|
557
|
+
async headerValues(name) {
|
|
558
|
+
return (await this._actualHeaders()).getAll(name);
|
|
559
|
+
}
|
|
560
|
+
async finished() {
|
|
561
|
+
return await this.request()._targetClosedScope().race(this._finishedPromise);
|
|
562
|
+
}
|
|
563
|
+
async body() {
|
|
564
|
+
return (await this._channel.body()).binary;
|
|
565
|
+
}
|
|
566
|
+
async text() {
|
|
567
|
+
const content = await this.body();
|
|
568
|
+
return content.toString('utf8');
|
|
569
|
+
}
|
|
570
|
+
async json() {
|
|
571
|
+
const content = await this.text();
|
|
572
|
+
return JSON.parse(content);
|
|
573
|
+
}
|
|
574
|
+
request() {
|
|
575
|
+
return this._request;
|
|
576
|
+
}
|
|
577
|
+
frame() {
|
|
578
|
+
return this._request.frame();
|
|
579
|
+
}
|
|
580
|
+
async serverAddr() {
|
|
581
|
+
return (await this._channel.serverAddr()).value || null;
|
|
582
|
+
}
|
|
583
|
+
async securityDetails() {
|
|
584
|
+
return (await this._channel.securityDetails()).value || null;
|
|
585
|
+
}
|
|
586
|
+
}
|
|
587
|
+
exports.Response = Response;
|
|
588
|
+
class WebSocket extends _channelOwner.ChannelOwner {
|
|
589
|
+
static from(webSocket) {
|
|
590
|
+
return webSocket._object;
|
|
591
|
+
}
|
|
592
|
+
constructor(parent, type, guid, initializer) {
|
|
593
|
+
super(parent, type, guid, initializer);
|
|
594
|
+
this._page = void 0;
|
|
595
|
+
this._isClosed = void 0;
|
|
596
|
+
this._isClosed = false;
|
|
597
|
+
this._page = parent;
|
|
598
|
+
this._channel.on('frameSent', event => {
|
|
599
|
+
if (event.opcode === 1) this.emit(_events.Events.WebSocket.FrameSent, {
|
|
600
|
+
payload: event.data
|
|
601
|
+
});else if (event.opcode === 2) this.emit(_events.Events.WebSocket.FrameSent, {
|
|
602
|
+
payload: Buffer.from(event.data, 'base64')
|
|
603
|
+
});
|
|
604
|
+
});
|
|
605
|
+
this._channel.on('frameReceived', event => {
|
|
606
|
+
if (event.opcode === 1) this.emit(_events.Events.WebSocket.FrameReceived, {
|
|
607
|
+
payload: event.data
|
|
608
|
+
});else if (event.opcode === 2) this.emit(_events.Events.WebSocket.FrameReceived, {
|
|
609
|
+
payload: Buffer.from(event.data, 'base64')
|
|
610
|
+
});
|
|
611
|
+
});
|
|
612
|
+
this._channel.on('socketError', ({
|
|
613
|
+
error
|
|
614
|
+
}) => this.emit(_events.Events.WebSocket.Error, error));
|
|
615
|
+
this._channel.on('close', () => {
|
|
616
|
+
this._isClosed = true;
|
|
617
|
+
this.emit(_events.Events.WebSocket.Close, this);
|
|
618
|
+
});
|
|
619
|
+
}
|
|
620
|
+
url() {
|
|
621
|
+
return this._initializer.url;
|
|
622
|
+
}
|
|
623
|
+
isClosed() {
|
|
624
|
+
return this._isClosed;
|
|
625
|
+
}
|
|
626
|
+
async waitForEvent(event, optionsOrPredicate = {}) {
|
|
627
|
+
return await this._wrapApiCall(async () => {
|
|
628
|
+
const timeout = this._page._timeoutSettings.timeout(typeof optionsOrPredicate === 'function' ? {} : optionsOrPredicate);
|
|
629
|
+
const predicate = typeof optionsOrPredicate === 'function' ? optionsOrPredicate : optionsOrPredicate.predicate;
|
|
630
|
+
const waiter = _waiter.Waiter.createForEvent(this, event);
|
|
631
|
+
waiter.rejectOnTimeout(timeout, `Timeout ${timeout}ms exceeded while waiting for event "${event}"`);
|
|
632
|
+
if (event !== _events.Events.WebSocket.Error) waiter.rejectOnEvent(this, _events.Events.WebSocket.Error, new Error('Socket error'));
|
|
633
|
+
if (event !== _events.Events.WebSocket.Close) waiter.rejectOnEvent(this, _events.Events.WebSocket.Close, new Error('Socket closed'));
|
|
634
|
+
waiter.rejectOnEvent(this._page, _events.Events.Page.Close, () => this._page._closeErrorWithReason());
|
|
635
|
+
const result = await waiter.waitForEvent(this, event, predicate);
|
|
636
|
+
waiter.dispose();
|
|
637
|
+
return result;
|
|
638
|
+
});
|
|
639
|
+
}
|
|
640
|
+
}
|
|
641
|
+
exports.WebSocket = WebSocket;
|
|
642
|
+
function validateHeaders(headers) {
|
|
643
|
+
for (const key of Object.keys(headers)) {
|
|
644
|
+
const value = headers[key];
|
|
645
|
+
if (!Object.is(value, undefined) && !(0, _utils.isString)(value)) throw new Error(`Expected value of header "${key}" to be String, but "${typeof value}" is found.`);
|
|
646
|
+
}
|
|
647
|
+
}
|
|
648
|
+
class RouteHandler {
|
|
649
|
+
constructor(baseURL, url, handler, times = Number.MAX_SAFE_INTEGER) {
|
|
650
|
+
this.handledCount = 0;
|
|
651
|
+
this._baseURL = void 0;
|
|
652
|
+
this._times = void 0;
|
|
653
|
+
this.url = void 0;
|
|
654
|
+
this.handler = void 0;
|
|
655
|
+
this._ignoreException = false;
|
|
656
|
+
this._activeInvocations = new Set();
|
|
657
|
+
this._baseURL = baseURL;
|
|
658
|
+
this._times = times;
|
|
659
|
+
this.url = url;
|
|
660
|
+
this.handler = handler;
|
|
661
|
+
}
|
|
662
|
+
static prepareInterceptionPatterns(handlers) {
|
|
663
|
+
const patterns = [];
|
|
664
|
+
let all = false;
|
|
665
|
+
for (const handler of handlers) {
|
|
666
|
+
if ((0, _utils.isString)(handler.url)) patterns.push({
|
|
667
|
+
glob: handler.url
|
|
668
|
+
});else if ((0, _utils.isRegExp)(handler.url)) patterns.push({
|
|
669
|
+
regexSource: handler.url.source,
|
|
670
|
+
regexFlags: handler.url.flags
|
|
671
|
+
});else all = true;
|
|
672
|
+
}
|
|
673
|
+
if (all) return [{
|
|
674
|
+
glob: '**/*'
|
|
675
|
+
}];
|
|
676
|
+
return patterns;
|
|
677
|
+
}
|
|
678
|
+
matches(requestURL) {
|
|
679
|
+
return (0, _utils.urlMatches)(this._baseURL, requestURL, this.url);
|
|
680
|
+
}
|
|
681
|
+
async handle(route) {
|
|
682
|
+
const handlerInvocation = {
|
|
683
|
+
complete: new _manualPromise.ManualPromise(),
|
|
684
|
+
route
|
|
685
|
+
};
|
|
686
|
+
this._activeInvocations.add(handlerInvocation);
|
|
687
|
+
try {
|
|
688
|
+
return await this._handleInternal(route);
|
|
689
|
+
} catch (e) {
|
|
690
|
+
// If the handler was stopped (without waiting for completion), we ignore all exceptions.
|
|
691
|
+
if (this._ignoreException) return false;
|
|
692
|
+
if ((0, _errors.isTargetClosedError)(e)) {
|
|
693
|
+
// We are failing in the handler because the target close closed.
|
|
694
|
+
// Give user a hint!
|
|
695
|
+
(0, _utils.rewriteErrorMessage)(e, `"${e.message}" while running route callback.\nConsider awaiting \`await page.unrouteAll({ behavior: 'ignoreErrors' })\`\nbefore the end of the test to ignore remaining routes in flight.`);
|
|
696
|
+
}
|
|
697
|
+
throw e;
|
|
698
|
+
} finally {
|
|
699
|
+
handlerInvocation.complete.resolve();
|
|
700
|
+
this._activeInvocations.delete(handlerInvocation);
|
|
701
|
+
}
|
|
702
|
+
}
|
|
703
|
+
async stop(behavior) {
|
|
704
|
+
// When a handler is manually unrouted or its page/context is closed we either
|
|
705
|
+
// - wait for the current handler invocations to finish
|
|
706
|
+
// - or do not wait, if the user opted out of it, but swallow all exceptions
|
|
707
|
+
// that happen after the unroute/close.
|
|
708
|
+
if (behavior === 'ignoreErrors') {
|
|
709
|
+
this._ignoreException = true;
|
|
710
|
+
} else {
|
|
711
|
+
const promises = [];
|
|
712
|
+
for (const activation of this._activeInvocations) {
|
|
713
|
+
if (!activation.route._didThrow) promises.push(activation.complete);
|
|
714
|
+
}
|
|
715
|
+
await Promise.all(promises);
|
|
716
|
+
}
|
|
717
|
+
}
|
|
718
|
+
async _handleInternal(route) {
|
|
719
|
+
++this.handledCount;
|
|
720
|
+
const handledPromise = route._startHandling();
|
|
721
|
+
// Extract handler into a variable to avoid [RouteHandler.handler] in the stack.
|
|
722
|
+
const handler = this.handler;
|
|
723
|
+
const [handled] = await Promise.all([handledPromise, handler(route, route.request())]);
|
|
724
|
+
return handled;
|
|
725
|
+
}
|
|
726
|
+
willExpire() {
|
|
727
|
+
return this.handledCount + 1 >= this._times;
|
|
728
|
+
}
|
|
729
|
+
}
|
|
730
|
+
exports.RouteHandler = RouteHandler;
|
|
731
|
+
class RawHeaders {
|
|
732
|
+
static _fromHeadersObjectLossy(headers) {
|
|
733
|
+
const headersArray = Object.entries(headers).map(([name, value]) => ({
|
|
734
|
+
name,
|
|
735
|
+
value
|
|
736
|
+
})).filter(header => header.value !== undefined);
|
|
737
|
+
return new RawHeaders(headersArray);
|
|
738
|
+
}
|
|
739
|
+
constructor(headers) {
|
|
740
|
+
this._headersArray = void 0;
|
|
741
|
+
this._headersMap = new _utils.MultiMap();
|
|
742
|
+
this._headersArray = headers;
|
|
743
|
+
for (const header of headers) this._headersMap.set(header.name.toLowerCase(), header.value);
|
|
744
|
+
}
|
|
745
|
+
get(name) {
|
|
746
|
+
const values = this.getAll(name);
|
|
747
|
+
if (!values || !values.length) return null;
|
|
748
|
+
return values.join(name.toLowerCase() === 'set-cookie' ? '\n' : ', ');
|
|
749
|
+
}
|
|
750
|
+
getAll(name) {
|
|
751
|
+
return [...this._headersMap.get(name.toLowerCase())];
|
|
752
|
+
}
|
|
753
|
+
headers() {
|
|
754
|
+
const result = {};
|
|
755
|
+
for (const name of this._headersMap.keys()) result[name] = this.get(name);
|
|
756
|
+
return result;
|
|
757
|
+
}
|
|
758
|
+
headersArray() {
|
|
759
|
+
return this._headersArray;
|
|
760
|
+
}
|
|
761
|
+
}
|
|
762
|
+
exports.RawHeaders = RawHeaders;
|