@checkly/playwright-core 1.41.2-beta.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.
- package/LICENSE +202 -0
- package/NOTICE +5 -0
- package/README.md +3 -0
- package/ThirdPartyNotices.txt +1513 -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 +23 -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 +23 -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 +22 -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 +22 -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 +23 -0
- package/browsers.json +64 -0
- package/cli.js +17 -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 +97 -0
- package/lib/cli/program.js +582 -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 +272 -0
- package/lib/client/artifact.js +79 -0
- package/lib/client/browser.js +145 -0
- package/lib/client/browserContext.js +509 -0
- package/lib/client/browserType.js +233 -0
- package/lib/client/cdpSession.js +53 -0
- package/lib/client/channelOwner.js +229 -0
- package/lib/client/clientHelper.js +57 -0
- package/lib/client/clientInstrumentation.js +40 -0
- package/lib/client/connection.js +327 -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 +130 -0
- package/lib/client/elementHandle.js +291 -0
- package/lib/client/errors.js +77 -0
- package/lib/client/events.js +93 -0
- package/lib/client/fetch.js +343 -0
- package/lib/client/fileChooser.js +45 -0
- package/lib/client/frame.js +506 -0
- package/lib/client/harRouter.js +93 -0
- package/lib/client/input.js +111 -0
- package/lib/client/jsHandle.js +123 -0
- package/lib/client/jsonPipe.js +35 -0
- package/lib/client/localUtils.js +35 -0
- package/lib/client/locator.js +432 -0
- package/lib/client/network.js +601 -0
- package/lib/client/page.js +707 -0
- package/lib/client/playwright.js +74 -0
- package/lib/client/selectors.js +67 -0
- package/lib/client/stream.js +54 -0
- package/lib/client/tracing.js +135 -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/consoleApiSource.js +7 -0
- package/lib/generated/injectedScriptSource.js +7 -0
- package/lib/generated/recorderSource.js +7 -0
- package/lib/generated/utilityScriptSource.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 +172 -0
- package/lib/protocol/transport.js +82 -0
- package/lib/protocol/validator.js +2599 -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/browser.js +129 -0
- package/lib/server/browserContext.js +609 -0
- package/lib/server/browserType.js +300 -0
- package/lib/server/chromium/appIcon.png +0 -0
- package/lib/server/chromium/chromium.js +346 -0
- package/lib/server/chromium/chromiumSwitches.js +41 -0
- package/lib/server/chromium/crAccessibility.js +237 -0
- package/lib/server/chromium/crBrowser.js +521 -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 +144 -0
- package/lib/server/chromium/crExecutionContext.js +156 -0
- package/lib/server/chromium/crInput.js +171 -0
- package/lib/server/chromium/crNetworkManager.js +723 -0
- package/lib/server/chromium/crPage.js +1173 -0
- package/lib/server/chromium/crPdf.js +147 -0
- package/lib/server/chromium/crProtocolHelper.js +131 -0
- package/lib/server/chromium/crServiceWorker.js +115 -0
- package/lib/server/chromium/defaultFontFamilies.js +145 -0
- package/lib/server/chromium/videoRecorder.js +155 -0
- package/lib/server/console.js +59 -0
- package/lib/server/cookieStore.js +112 -0
- package/lib/server/debugController.js +236 -0
- package/lib/server/debugger.js +132 -0
- package/lib/server/deviceDescriptors.js +21 -0
- package/lib/server/deviceDescriptorsSource.json +1549 -0
- package/lib/server/dialog.js +70 -0
- package/lib/server/dispatchers/androidDispatcher.js +193 -0
- package/lib/server/dispatchers/artifactDispatcher.js +118 -0
- package/lib/server/dispatchers/browserContextDispatcher.js +306 -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 +400 -0
- package/lib/server/dispatchers/electronDispatcher.js +80 -0
- package/lib/server/dispatchers/elementHandlerDispatcher.js +228 -0
- package/lib/server/dispatchers/frameDispatcher.js +287 -0
- package/lib/server/dispatchers/jsHandleDispatcher.js +102 -0
- package/lib/server/dispatchers/jsonPipeDispatcher.js +61 -0
- package/lib/server/dispatchers/localUtilsDispatcher.js +399 -0
- package/lib/server/dispatchers/networkDispatchers.js +221 -0
- package/lib/server/dispatchers/pageDispatcher.js +363 -0
- package/lib/server/dispatchers/playwrightDispatcher.js +105 -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/writableStreamDispatcher.js +55 -0
- package/lib/server/dom.js +808 -0
- package/lib/server/download.js +53 -0
- package/lib/server/electron/electron.js +254 -0
- package/lib/server/electron/loader.js +57 -0
- package/lib/server/errors.js +68 -0
- package/lib/server/fetch.js +611 -0
- package/lib/server/fileChooser.js +42 -0
- package/lib/server/fileUploadUtils.js +71 -0
- package/lib/server/firefox/ffAccessibility.js +215 -0
- package/lib/server/firefox/ffBrowser.js +447 -0
- package/lib/server/firefox/ffConnection.js +168 -0
- package/lib/server/firefox/ffExecutionContext.js +138 -0
- package/lib/server/firefox/ffInput.js +150 -0
- package/lib/server/firefox/ffNetworkManager.js +231 -0
- package/lib/server/firefox/ffPage.js +558 -0
- package/lib/server/firefox/firefox.js +91 -0
- package/lib/server/formData.js +75 -0
- package/lib/server/frameSelectors.js +171 -0
- package/lib/server/frames.js +1597 -0
- package/lib/server/har/harRecorder.js +139 -0
- package/lib/server/har/harTracer.js +539 -0
- package/lib/server/helper.js +103 -0
- package/lib/server/index.js +96 -0
- package/lib/server/input.js +301 -0
- package/lib/server/instrumentation.js +74 -0
- package/lib/server/isomorphic/utilityScriptSerializers.js +212 -0
- package/lib/server/javascript.js +305 -0
- package/lib/server/launchApp.js +90 -0
- package/lib/server/macEditingCommands.js +139 -0
- package/lib/server/network.js +607 -0
- package/lib/server/page.js +793 -0
- package/lib/server/pipeTransport.js +85 -0
- package/lib/server/playwright.js +82 -0
- package/lib/server/progress.js +102 -0
- package/lib/server/protocolError.js +49 -0
- package/lib/server/recorder/codeGenerator.js +153 -0
- package/lib/server/recorder/csharp.js +310 -0
- package/lib/server/recorder/java.js +216 -0
- package/lib/server/recorder/javascript.js +229 -0
- package/lib/server/recorder/jsonl.js +47 -0
- package/lib/server/recorder/language.js +44 -0
- package/lib/server/recorder/python.js +275 -0
- package/lib/server/recorder/recorderActions.js +5 -0
- package/lib/server/recorder/recorderApp.js +181 -0
- package/lib/server/recorder/recorderUtils.js +48 -0
- package/lib/server/recorder/utils.js +45 -0
- package/lib/server/recorder.js +700 -0
- package/lib/server/registry/browserFetcher.js +168 -0
- package/lib/server/registry/dependencies.js +322 -0
- package/lib/server/registry/index.js +925 -0
- package/lib/server/registry/nativeDeps.js +383 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +138 -0
- package/lib/server/screenshotter.js +354 -0
- package/lib/server/selectors.js +73 -0
- package/lib/server/socksInterceptor.js +100 -0
- package/lib/server/trace/recorder/snapshotter.js +168 -0
- package/lib/server/trace/recorder/snapshotterInjected.js +493 -0
- package/lib/server/trace/recorder/tracing.js +552 -0
- package/lib/server/trace/test/inMemorySnapshotter.js +93 -0
- package/lib/server/trace/viewer/traceViewer.js +229 -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 +328 -0
- package/lib/server/webkit/wkConnection.js +173 -0
- package/lib/server/webkit/wkExecutionContext.js +146 -0
- package/lib/server/webkit/wkInput.js +169 -0
- package/lib/server/webkit/wkInterceptableRequest.js +158 -0
- package/lib/server/webkit/wkPage.js +1198 -0
- package/lib/server/webkit/wkProvisionalPage.js +59 -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 +33 -0
- package/lib/utils/debug.js +46 -0
- package/lib/utils/debugLogger.js +89 -0
- package/lib/utils/env.js +47 -0
- package/lib/utils/eventsHelper.js +38 -0
- package/lib/utils/fileUtils.js +66 -0
- package/lib/utils/glob.js +83 -0
- package/lib/utils/happy-eyeballs.js +154 -0
- package/lib/utils/headers.js +52 -0
- package/lib/utils/hostPlatform.js +124 -0
- package/lib/utils/httpServer.js +195 -0
- package/lib/utils/index.js +324 -0
- package/lib/utils/isomorphic/cssParser.js +250 -0
- package/lib/utils/isomorphic/cssTokenizer.js +979 -0
- package/lib/utils/isomorphic/locatorGenerators.js +651 -0
- package/lib/utils/isomorphic/locatorParser.js +179 -0
- package/lib/utils/isomorphic/locatorUtils.js +62 -0
- package/lib/utils/isomorphic/selectorParser.js +397 -0
- package/lib/utils/isomorphic/stringUtils.js +107 -0
- package/lib/utils/isomorphic/traceUtils.js +39 -0
- package/lib/utils/linuxUtils.js +78 -0
- package/lib/utils/manualPromise.js +109 -0
- package/lib/utils/mimeType.js +29 -0
- package/lib/utils/multimap.js +75 -0
- package/lib/utils/network.js +189 -0
- package/lib/utils/processLauncher.js +248 -0
- package/lib/utils/profiler.js +53 -0
- package/lib/utils/rtti.js +41 -0
- package/lib/utils/semaphore.js +51 -0
- package/lib/utils/spawnAsync.js +45 -0
- package/lib/utils/stackTrace.js +123 -0
- package/lib/utils/task.js +58 -0
- package/lib/utils/time.js +37 -0
- package/lib/utils/timeoutRunner.js +131 -0
- package/lib/utils/traceUtils.js +44 -0
- package/lib/utils/userAgent.js +105 -0
- package/lib/utils/wsServer.js +125 -0
- package/lib/utils/zipFile.js +75 -0
- package/lib/utils/zones.js +99 -0
- package/lib/utilsBundle.js +81 -0
- package/lib/utilsBundleImpl/index.js +51 -0
- package/lib/utilsBundleImpl/xdg-open +1066 -0
- package/lib/vite/htmlReport/index.html +66 -0
- package/lib/vite/recorder/assets/codeMirrorModule-Hs9-1ZG4.css +1 -0
- package/lib/vite/recorder/assets/codeMirrorModule-I9ks4y7D.js +24 -0
- package/lib/vite/recorder/assets/codicon-zGuYmc9o.ttf +0 -0
- package/lib/vite/recorder/assets/index-ljsTwXtJ.css +1 -0
- package/lib/vite/recorder/assets/index-yg8ypzl6.js +47 -0
- package/lib/vite/recorder/index.html +29 -0
- package/lib/vite/recorder/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-GluP1cQ1.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-fqJB1XDu.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-y3M3aAqy.js +24 -0
- package/lib/vite/traceViewer/assets/wsPort-Rvwd4WC-.js +69 -0
- package/lib/vite/traceViewer/assets/wsPort-dlD7vDkY.js +69 -0
- package/lib/vite/traceViewer/assets/wsPort-qOE2NWrO.js +69 -0
- package/lib/vite/traceViewer/assets/xtermModule-Yt6xwiJ_.js +9 -0
- package/lib/vite/traceViewer/codeMirrorModule.Hs9-1ZG4.css +1 -0
- package/lib/vite/traceViewer/codicon.zGuYmc9o.ttf +0 -0
- package/lib/vite/traceViewer/index.-g_5lMbJ.css +1 -0
- package/lib/vite/traceViewer/index.4X7zDysg.js +2 -0
- package/lib/vite/traceViewer/index.HkJgzlGy.js +2 -0
- package/lib/vite/traceViewer/index.html +26 -0
- package/lib/vite/traceViewer/index.kRjx5sAJ.js +2 -0
- package/lib/vite/traceViewer/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/snapshot.html +21 -0
- package/lib/vite/traceViewer/sw.bundle.js +4 -0
- package/lib/vite/traceViewer/uiMode.1Wcp_Kto.js +10 -0
- package/lib/vite/traceViewer/uiMode.GTNzARcV.js +10 -0
- package/lib/vite/traceViewer/uiMode.html +17 -0
- package/lib/vite/traceViewer/uiMode.pWy0Re7G.css +1 -0
- package/lib/vite/traceViewer/uiMode.zV-7Lf9v.js +10 -0
- package/lib/vite/traceViewer/wsPort.kSgQKQ0y.css +1 -0
- package/lib/vite/traceViewer/xtermModule.0lwXJFHT.css +32 -0
- package/lib/zipBundle.js +25 -0
- package/lib/zipBundleImpl.js +5 -0
- package/package.json +43 -0
- package/types/protocol.d.ts +20304 -0
- package/types/structs.d.ts +45 -0
- package/types/types.d.ts +20626 -0
|
@@ -0,0 +1,399 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.LocalUtilsDispatcher = void 0;
|
|
7
|
+
exports.urlToWSEndpoint = urlToWSEndpoint;
|
|
8
|
+
var _fs = _interopRequireDefault(require("fs"));
|
|
9
|
+
var _path = _interopRequireDefault(require("path"));
|
|
10
|
+
var _os = _interopRequireDefault(require("os"));
|
|
11
|
+
var _manualPromise = require("../../utils/manualPromise");
|
|
12
|
+
var _utils = require("../../utils");
|
|
13
|
+
var _dispatcher = require("./dispatcher");
|
|
14
|
+
var _zipBundle = require("../../zipBundle");
|
|
15
|
+
var _zipFile = require("../../utils/zipFile");
|
|
16
|
+
var _jsonPipeDispatcher = require("../dispatchers/jsonPipeDispatcher");
|
|
17
|
+
var _transport = require("../transport");
|
|
18
|
+
var _socksInterceptor = require("../socksInterceptor");
|
|
19
|
+
var _userAgent = require("../../utils/userAgent");
|
|
20
|
+
var _progress = require("../progress");
|
|
21
|
+
var _network = require("../../utils/network");
|
|
22
|
+
var _instrumentation = require("../../server/instrumentation");
|
|
23
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
24
|
+
/**
|
|
25
|
+
* Copyright (c) Microsoft Corporation.
|
|
26
|
+
*
|
|
27
|
+
* Licensed under the Apache License, Version 2.0 (the 'License");
|
|
28
|
+
* you may not use this file except in compliance with the License.
|
|
29
|
+
* You may obtain a copy of the License at
|
|
30
|
+
*
|
|
31
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
32
|
+
*
|
|
33
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
34
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
35
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
36
|
+
* See the License for the specific language governing permissions and
|
|
37
|
+
* limitations under the License.
|
|
38
|
+
*/
|
|
39
|
+
|
|
40
|
+
class LocalUtilsDispatcher extends _dispatcher.Dispatcher {
|
|
41
|
+
constructor(scope, playwright) {
|
|
42
|
+
const localUtils = new _instrumentation.SdkObject(playwright, 'localUtils', 'localUtils');
|
|
43
|
+
const descriptors = require('../deviceDescriptors');
|
|
44
|
+
const deviceDescriptors = Object.entries(descriptors).map(([name, descriptor]) => ({
|
|
45
|
+
name,
|
|
46
|
+
descriptor
|
|
47
|
+
}));
|
|
48
|
+
super(scope, localUtils, 'LocalUtils', {
|
|
49
|
+
deviceDescriptors
|
|
50
|
+
});
|
|
51
|
+
this._type_LocalUtils = void 0;
|
|
52
|
+
this._harBackends = new Map();
|
|
53
|
+
this._stackSessions = new Map();
|
|
54
|
+
this._type_LocalUtils = true;
|
|
55
|
+
}
|
|
56
|
+
async zip(params) {
|
|
57
|
+
const promise = new _manualPromise.ManualPromise();
|
|
58
|
+
const zipFile = new _zipBundle.yazl.ZipFile();
|
|
59
|
+
zipFile.on('error', error => promise.reject(error));
|
|
60
|
+
const addFile = (file, name) => {
|
|
61
|
+
try {
|
|
62
|
+
if (_fs.default.statSync(file).isFile()) zipFile.addFile(file, name);
|
|
63
|
+
} catch (e) {}
|
|
64
|
+
};
|
|
65
|
+
for (const entry of params.entries) addFile(entry.value, entry.name);
|
|
66
|
+
|
|
67
|
+
// Add stacks and the sources.
|
|
68
|
+
const stackSession = params.stacksId ? this._stackSessions.get(params.stacksId) : undefined;
|
|
69
|
+
if (stackSession !== null && stackSession !== void 0 && stackSession.callStacks.length) {
|
|
70
|
+
await stackSession.writer;
|
|
71
|
+
if (process.env.PW_LIVE_TRACE_STACKS) {
|
|
72
|
+
zipFile.addFile(stackSession.file, 'trace.stacks');
|
|
73
|
+
} else {
|
|
74
|
+
const buffer = Buffer.from(JSON.stringify((0, _utils.serializeClientSideCallMetadata)(stackSession.callStacks)));
|
|
75
|
+
zipFile.addBuffer(buffer, 'trace.stacks');
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Collect sources from stacks.
|
|
80
|
+
if (params.includeSources) {
|
|
81
|
+
const sourceFiles = new Set();
|
|
82
|
+
for (const {
|
|
83
|
+
stack
|
|
84
|
+
} of (stackSession === null || stackSession === void 0 ? void 0 : stackSession.callStacks) || []) {
|
|
85
|
+
if (!stack) continue;
|
|
86
|
+
for (const {
|
|
87
|
+
file
|
|
88
|
+
} of stack) sourceFiles.add(file);
|
|
89
|
+
}
|
|
90
|
+
for (const sourceFile of sourceFiles) addFile(sourceFile, 'resources/src@' + (0, _utils.calculateSha1)(sourceFile) + '.txt');
|
|
91
|
+
}
|
|
92
|
+
if (params.mode === 'write') {
|
|
93
|
+
// New file, just compress the entries.
|
|
94
|
+
await _fs.default.promises.mkdir(_path.default.dirname(params.zipFile), {
|
|
95
|
+
recursive: true
|
|
96
|
+
});
|
|
97
|
+
zipFile.end(undefined, () => {
|
|
98
|
+
zipFile.outputStream.pipe(_fs.default.createWriteStream(params.zipFile)).on('close', () => promise.resolve()).on('error', error => promise.reject(error));
|
|
99
|
+
});
|
|
100
|
+
await promise;
|
|
101
|
+
await this._deleteStackSession(params.stacksId);
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// File already exists. Repack and add new entries.
|
|
106
|
+
const tempFile = params.zipFile + '.tmp';
|
|
107
|
+
await _fs.default.promises.rename(params.zipFile, tempFile);
|
|
108
|
+
_zipBundle.yauzl.open(tempFile, (err, inZipFile) => {
|
|
109
|
+
if (err) {
|
|
110
|
+
promise.reject(err);
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
(0, _utils.assert)(inZipFile);
|
|
114
|
+
let pendingEntries = inZipFile.entryCount;
|
|
115
|
+
inZipFile.on('entry', entry => {
|
|
116
|
+
inZipFile.openReadStream(entry, (err, readStream) => {
|
|
117
|
+
if (err) {
|
|
118
|
+
promise.reject(err);
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
zipFile.addReadStream(readStream, entry.fileName);
|
|
122
|
+
if (--pendingEntries === 0) {
|
|
123
|
+
zipFile.end(undefined, () => {
|
|
124
|
+
zipFile.outputStream.pipe(_fs.default.createWriteStream(params.zipFile)).on('close', () => {
|
|
125
|
+
_fs.default.promises.unlink(tempFile).then(() => {
|
|
126
|
+
promise.resolve();
|
|
127
|
+
}).catch(error => promise.reject(error));
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
await promise;
|
|
135
|
+
await this._deleteStackSession(params.stacksId);
|
|
136
|
+
}
|
|
137
|
+
async harOpen(params, metadata) {
|
|
138
|
+
let harBackend;
|
|
139
|
+
if (params.file.endsWith('.zip')) {
|
|
140
|
+
const zipFile = new _zipFile.ZipFile(params.file);
|
|
141
|
+
const entryNames = await zipFile.entries();
|
|
142
|
+
const harEntryName = entryNames.find(e => e.endsWith('.har'));
|
|
143
|
+
if (!harEntryName) return {
|
|
144
|
+
error: 'Specified archive does not have a .har file'
|
|
145
|
+
};
|
|
146
|
+
const har = await zipFile.read(harEntryName);
|
|
147
|
+
const harFile = JSON.parse(har.toString());
|
|
148
|
+
harBackend = new HarBackend(harFile, null, zipFile);
|
|
149
|
+
} else {
|
|
150
|
+
const harFile = JSON.parse(await _fs.default.promises.readFile(params.file, 'utf-8'));
|
|
151
|
+
harBackend = new HarBackend(harFile, _path.default.dirname(params.file), null);
|
|
152
|
+
}
|
|
153
|
+
this._harBackends.set(harBackend.id, harBackend);
|
|
154
|
+
return {
|
|
155
|
+
harId: harBackend.id
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
async harLookup(params, metadata) {
|
|
159
|
+
const harBackend = this._harBackends.get(params.harId);
|
|
160
|
+
if (!harBackend) return {
|
|
161
|
+
action: 'error',
|
|
162
|
+
message: `Internal error: har was not opened`
|
|
163
|
+
};
|
|
164
|
+
return await harBackend.lookup(params.url, params.method, params.headers, params.postData, params.isNavigationRequest);
|
|
165
|
+
}
|
|
166
|
+
async harClose(params, metadata) {
|
|
167
|
+
const harBackend = this._harBackends.get(params.harId);
|
|
168
|
+
if (harBackend) {
|
|
169
|
+
this._harBackends.delete(harBackend.id);
|
|
170
|
+
harBackend.dispose();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
async harUnzip(params, metadata) {
|
|
174
|
+
const dir = _path.default.dirname(params.zipFile);
|
|
175
|
+
const zipFile = new _zipFile.ZipFile(params.zipFile);
|
|
176
|
+
for (const entry of await zipFile.entries()) {
|
|
177
|
+
const buffer = await zipFile.read(entry);
|
|
178
|
+
if (entry === 'har.har') await _fs.default.promises.writeFile(params.harFile, buffer);else await _fs.default.promises.writeFile(_path.default.join(dir, entry), buffer);
|
|
179
|
+
}
|
|
180
|
+
zipFile.close();
|
|
181
|
+
await _fs.default.promises.unlink(params.zipFile);
|
|
182
|
+
}
|
|
183
|
+
async connect(params, metadata) {
|
|
184
|
+
const controller = new _progress.ProgressController(metadata, this._object);
|
|
185
|
+
controller.setLogName('browser');
|
|
186
|
+
return await controller.run(async progress => {
|
|
187
|
+
var _params$exposeNetwork;
|
|
188
|
+
const wsHeaders = {
|
|
189
|
+
'User-Agent': (0, _userAgent.getUserAgent)(),
|
|
190
|
+
'x-playwright-proxy': (_params$exposeNetwork = params.exposeNetwork) !== null && _params$exposeNetwork !== void 0 ? _params$exposeNetwork : '',
|
|
191
|
+
...params.headers
|
|
192
|
+
};
|
|
193
|
+
const wsEndpoint = await urlToWSEndpoint(progress, params.wsEndpoint);
|
|
194
|
+
const transport = await _transport.WebSocketTransport.connect(progress, wsEndpoint, wsHeaders, true, 'x-playwright-debug-log');
|
|
195
|
+
const socksInterceptor = new _socksInterceptor.SocksInterceptor(transport, params.exposeNetwork, params.socksProxyRedirectPortForTest);
|
|
196
|
+
const pipe = new _jsonPipeDispatcher.JsonPipeDispatcher(this);
|
|
197
|
+
transport.onmessage = json => {
|
|
198
|
+
if (socksInterceptor.interceptMessage(json)) return;
|
|
199
|
+
const cb = () => {
|
|
200
|
+
try {
|
|
201
|
+
pipe.dispatch(json);
|
|
202
|
+
} catch (e) {
|
|
203
|
+
transport.close();
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
if (params.slowMo) setTimeout(cb, params.slowMo);else cb();
|
|
207
|
+
};
|
|
208
|
+
pipe.on('message', message => {
|
|
209
|
+
transport.send(message);
|
|
210
|
+
});
|
|
211
|
+
transport.onclose = () => {
|
|
212
|
+
socksInterceptor === null || socksInterceptor === void 0 || socksInterceptor.cleanup();
|
|
213
|
+
pipe.wasClosed();
|
|
214
|
+
};
|
|
215
|
+
pipe.on('close', () => transport.close());
|
|
216
|
+
return {
|
|
217
|
+
pipe,
|
|
218
|
+
headers: transport.headers
|
|
219
|
+
};
|
|
220
|
+
}, params.timeout || 0);
|
|
221
|
+
}
|
|
222
|
+
async tracingStarted(params, metadata) {
|
|
223
|
+
let tmpDir = undefined;
|
|
224
|
+
if (!params.tracesDir) tmpDir = await _fs.default.promises.mkdtemp(_path.default.join(_os.default.tmpdir(), 'playwright-tracing-'));
|
|
225
|
+
const traceStacksFile = _path.default.join(params.tracesDir || tmpDir, params.traceName + '.stacks');
|
|
226
|
+
this._stackSessions.set(traceStacksFile, {
|
|
227
|
+
callStacks: [],
|
|
228
|
+
file: traceStacksFile,
|
|
229
|
+
writer: Promise.resolve(),
|
|
230
|
+
tmpDir
|
|
231
|
+
});
|
|
232
|
+
return {
|
|
233
|
+
stacksId: traceStacksFile
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
async traceDiscarded(params, metadata) {
|
|
237
|
+
await this._deleteStackSession(params.stacksId);
|
|
238
|
+
}
|
|
239
|
+
async addStackToTracingNoReply(params, metadata) {
|
|
240
|
+
for (const session of this._stackSessions.values()) {
|
|
241
|
+
session.callStacks.push(params.callData);
|
|
242
|
+
if (process.env.PW_LIVE_TRACE_STACKS) {
|
|
243
|
+
session.writer = session.writer.then(() => {
|
|
244
|
+
const buffer = Buffer.from(JSON.stringify((0, _utils.serializeClientSideCallMetadata)(session.callStacks)));
|
|
245
|
+
return _fs.default.promises.writeFile(session.file, buffer);
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
async _deleteStackSession(stacksId) {
|
|
251
|
+
const session = stacksId ? this._stackSessions.get(stacksId) : undefined;
|
|
252
|
+
if (!session) return;
|
|
253
|
+
await session.writer;
|
|
254
|
+
if (session.tmpDir) await (0, _utils.removeFolders)([session.tmpDir]);
|
|
255
|
+
this._stackSessions.delete(stacksId);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
exports.LocalUtilsDispatcher = LocalUtilsDispatcher;
|
|
259
|
+
const redirectStatus = [301, 302, 303, 307, 308];
|
|
260
|
+
class HarBackend {
|
|
261
|
+
constructor(harFile, baseDir, zipFile) {
|
|
262
|
+
this.id = (0, _utils.createGuid)();
|
|
263
|
+
this._harFile = void 0;
|
|
264
|
+
this._zipFile = void 0;
|
|
265
|
+
this._baseDir = void 0;
|
|
266
|
+
this._harFile = harFile;
|
|
267
|
+
this._baseDir = baseDir;
|
|
268
|
+
this._zipFile = zipFile;
|
|
269
|
+
}
|
|
270
|
+
async lookup(url, method, headers, postData, isNavigationRequest) {
|
|
271
|
+
let entry;
|
|
272
|
+
try {
|
|
273
|
+
entry = await this._harFindResponse(url, method, headers, postData);
|
|
274
|
+
} catch (e) {
|
|
275
|
+
return {
|
|
276
|
+
action: 'error',
|
|
277
|
+
message: 'HAR error: ' + e.message
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
if (!entry) return {
|
|
281
|
+
action: 'noentry'
|
|
282
|
+
};
|
|
283
|
+
|
|
284
|
+
// If navigation is being redirected, restart it with the final url to ensure the document's url changes.
|
|
285
|
+
if (entry.request.url !== url && isNavigationRequest) return {
|
|
286
|
+
action: 'redirect',
|
|
287
|
+
redirectURL: entry.request.url
|
|
288
|
+
};
|
|
289
|
+
const response = entry.response;
|
|
290
|
+
try {
|
|
291
|
+
const buffer = await this._loadContent(response.content);
|
|
292
|
+
return {
|
|
293
|
+
action: 'fulfill',
|
|
294
|
+
status: response.status,
|
|
295
|
+
headers: response.headers,
|
|
296
|
+
body: buffer
|
|
297
|
+
};
|
|
298
|
+
} catch (e) {
|
|
299
|
+
return {
|
|
300
|
+
action: 'error',
|
|
301
|
+
message: e.message
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
async _loadContent(content) {
|
|
306
|
+
const file = content._file;
|
|
307
|
+
let buffer;
|
|
308
|
+
if (file) {
|
|
309
|
+
if (this._zipFile) buffer = await this._zipFile.read(file);else buffer = await _fs.default.promises.readFile(_path.default.resolve(this._baseDir, file));
|
|
310
|
+
} else {
|
|
311
|
+
buffer = Buffer.from(content.text || '', content.encoding === 'base64' ? 'base64' : 'utf-8');
|
|
312
|
+
}
|
|
313
|
+
return buffer;
|
|
314
|
+
}
|
|
315
|
+
async _harFindResponse(url, method, headers, postData) {
|
|
316
|
+
const harLog = this._harFile.log;
|
|
317
|
+
const visited = new Set();
|
|
318
|
+
while (true) {
|
|
319
|
+
const entries = [];
|
|
320
|
+
for (const candidate of harLog.entries) {
|
|
321
|
+
if (candidate.request.url !== url || candidate.request.method !== method) continue;
|
|
322
|
+
if (method === 'POST' && postData && candidate.request.postData) {
|
|
323
|
+
const buffer = await this._loadContent(candidate.request.postData);
|
|
324
|
+
if (!buffer.equals(postData)) continue;
|
|
325
|
+
}
|
|
326
|
+
entries.push(candidate);
|
|
327
|
+
}
|
|
328
|
+
if (!entries.length) return;
|
|
329
|
+
let entry = entries[0];
|
|
330
|
+
|
|
331
|
+
// Disambiguate using headers - then one with most matching headers wins.
|
|
332
|
+
if (entries.length > 1) {
|
|
333
|
+
const list = [];
|
|
334
|
+
for (const candidate of entries) {
|
|
335
|
+
const matchingHeaders = countMatchingHeaders(candidate.request.headers, headers);
|
|
336
|
+
list.push({
|
|
337
|
+
candidate,
|
|
338
|
+
matchingHeaders
|
|
339
|
+
});
|
|
340
|
+
}
|
|
341
|
+
list.sort((a, b) => b.matchingHeaders - a.matchingHeaders);
|
|
342
|
+
entry = list[0].candidate;
|
|
343
|
+
}
|
|
344
|
+
if (visited.has(entry)) throw new Error(`Found redirect cycle for ${url}`);
|
|
345
|
+
visited.add(entry);
|
|
346
|
+
|
|
347
|
+
// Follow redirects.
|
|
348
|
+
const locationHeader = entry.response.headers.find(h => h.name.toLowerCase() === 'location');
|
|
349
|
+
if (redirectStatus.includes(entry.response.status) && locationHeader) {
|
|
350
|
+
const locationURL = new URL(locationHeader.value, url);
|
|
351
|
+
url = locationURL.toString();
|
|
352
|
+
if ((entry.response.status === 301 || entry.response.status === 302) && method === 'POST' || entry.response.status === 303 && !['GET', 'HEAD'].includes(method)) {
|
|
353
|
+
// HTTP-redirect fetch step 13 (https://fetch.spec.whatwg.org/#http-redirect-fetch)
|
|
354
|
+
method = 'GET';
|
|
355
|
+
}
|
|
356
|
+
continue;
|
|
357
|
+
}
|
|
358
|
+
return entry;
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
dispose() {
|
|
362
|
+
var _this$_zipFile;
|
|
363
|
+
(_this$_zipFile = this._zipFile) === null || _this$_zipFile === void 0 || _this$_zipFile.close();
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
function countMatchingHeaders(harHeaders, headers) {
|
|
367
|
+
const set = new Set(headers.map(h => h.name.toLowerCase() + ':' + h.value));
|
|
368
|
+
let matches = 0;
|
|
369
|
+
for (const h of harHeaders) {
|
|
370
|
+
if (set.has(h.name.toLowerCase() + ':' + h.value)) ++matches;
|
|
371
|
+
}
|
|
372
|
+
return matches;
|
|
373
|
+
}
|
|
374
|
+
async function urlToWSEndpoint(progress, endpointURL) {
|
|
375
|
+
var _progress$timeUntilDe;
|
|
376
|
+
if (endpointURL.startsWith('ws')) return endpointURL;
|
|
377
|
+
progress === null || progress === void 0 || progress.log(`<ws preparing> retrieving websocket url from ${endpointURL}`);
|
|
378
|
+
const fetchUrl = new URL(endpointURL);
|
|
379
|
+
if (!fetchUrl.pathname.endsWith('/')) fetchUrl.pathname += '/';
|
|
380
|
+
fetchUrl.pathname += 'json';
|
|
381
|
+
const json = await (0, _network.fetchData)({
|
|
382
|
+
url: fetchUrl.toString(),
|
|
383
|
+
method: 'GET',
|
|
384
|
+
timeout: (_progress$timeUntilDe = progress === null || progress === void 0 ? void 0 : progress.timeUntilDeadline()) !== null && _progress$timeUntilDe !== void 0 ? _progress$timeUntilDe : 30_000,
|
|
385
|
+
headers: {
|
|
386
|
+
'User-Agent': (0, _userAgent.getUserAgent)()
|
|
387
|
+
}
|
|
388
|
+
}, async (params, response) => {
|
|
389
|
+
return new Error(`Unexpected status ${response.statusCode} when connecting to ${fetchUrl.toString()}.\n` + `This does not look like a Playwright server, try connecting via ws://.`);
|
|
390
|
+
});
|
|
391
|
+
progress === null || progress === void 0 || progress.throwIfAborted();
|
|
392
|
+
const wsUrl = new URL(endpointURL);
|
|
393
|
+
let wsEndpointPath = JSON.parse(json).wsEndpointPath;
|
|
394
|
+
if (wsEndpointPath.startsWith('/')) wsEndpointPath = wsEndpointPath.substring(1);
|
|
395
|
+
if (!wsUrl.pathname.endsWith('/')) wsUrl.pathname += '/';
|
|
396
|
+
wsUrl.pathname += wsEndpointPath;
|
|
397
|
+
wsUrl.protocol = wsUrl.protocol === 'https:' ? 'wss:' : 'ws:';
|
|
398
|
+
return wsUrl.toString();
|
|
399
|
+
}
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.WebSocketDispatcher = exports.RouteDispatcher = exports.ResponseDispatcher = exports.RequestDispatcher = exports.APIRequestContextDispatcher = void 0;
|
|
7
|
+
var _network = require("../network");
|
|
8
|
+
var _dispatcher = require("./dispatcher");
|
|
9
|
+
var _tracingDispatcher = require("./tracingDispatcher");
|
|
10
|
+
var _frameDispatcher = require("./frameDispatcher");
|
|
11
|
+
var _pageDispatcher = require("./pageDispatcher");
|
|
12
|
+
/**
|
|
13
|
+
* Copyright (c) Microsoft Corporation.
|
|
14
|
+
*
|
|
15
|
+
* Licensed under the Apache License, Version 2.0 (the 'License");
|
|
16
|
+
* you may not use this file except in compliance with the License.
|
|
17
|
+
* You may obtain a copy of the License at
|
|
18
|
+
*
|
|
19
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
20
|
+
*
|
|
21
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
22
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
23
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
24
|
+
* See the License for the specific language governing permissions and
|
|
25
|
+
* limitations under the License.
|
|
26
|
+
*/
|
|
27
|
+
|
|
28
|
+
class RequestDispatcher extends _dispatcher.Dispatcher {
|
|
29
|
+
static from(scope, request) {
|
|
30
|
+
const result = (0, _dispatcher.existingDispatcher)(request);
|
|
31
|
+
return result || new RequestDispatcher(scope, request);
|
|
32
|
+
}
|
|
33
|
+
static fromNullable(scope, request) {
|
|
34
|
+
return request ? RequestDispatcher.from(scope, request) : undefined;
|
|
35
|
+
}
|
|
36
|
+
constructor(scope, request) {
|
|
37
|
+
var _request$frame;
|
|
38
|
+
const postData = request.postDataBuffer();
|
|
39
|
+
// Always try to attach request to the page, if not, frame.
|
|
40
|
+
const frame = request.frame();
|
|
41
|
+
const page = (_request$frame = request.frame()) === null || _request$frame === void 0 ? void 0 : _request$frame._page;
|
|
42
|
+
const pageDispatcher = page ? (0, _dispatcher.existingDispatcher)(page) : null;
|
|
43
|
+
const frameDispatcher = frame ? _frameDispatcher.FrameDispatcher.from(scope, frame) : null;
|
|
44
|
+
super(pageDispatcher || frameDispatcher || scope, request, 'Request', {
|
|
45
|
+
frame: _frameDispatcher.FrameDispatcher.fromNullable(scope, request.frame()),
|
|
46
|
+
serviceWorker: _pageDispatcher.WorkerDispatcher.fromNullable(scope, request.serviceWorker()),
|
|
47
|
+
url: request.url(),
|
|
48
|
+
resourceType: request.resourceType(),
|
|
49
|
+
method: request.method(),
|
|
50
|
+
postData: postData === null ? undefined : postData,
|
|
51
|
+
headers: request.headers(),
|
|
52
|
+
isNavigationRequest: request.isNavigationRequest(),
|
|
53
|
+
redirectedFrom: RequestDispatcher.fromNullable(scope, request.redirectedFrom())
|
|
54
|
+
});
|
|
55
|
+
this._type_Request = void 0;
|
|
56
|
+
this._browserContextDispatcher = void 0;
|
|
57
|
+
this._type_Request = true;
|
|
58
|
+
this._browserContextDispatcher = scope;
|
|
59
|
+
}
|
|
60
|
+
async rawRequestHeaders(params) {
|
|
61
|
+
return {
|
|
62
|
+
headers: await this._object.rawRequestHeaders()
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
async response() {
|
|
66
|
+
return {
|
|
67
|
+
response: ResponseDispatcher.fromNullable(this._browserContextDispatcher, await this._object.response())
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.RequestDispatcher = RequestDispatcher;
|
|
72
|
+
class ResponseDispatcher extends _dispatcher.Dispatcher {
|
|
73
|
+
static from(scope, response) {
|
|
74
|
+
const result = (0, _dispatcher.existingDispatcher)(response);
|
|
75
|
+
const requestDispatcher = RequestDispatcher.from(scope, response.request());
|
|
76
|
+
return result || new ResponseDispatcher(requestDispatcher, response);
|
|
77
|
+
}
|
|
78
|
+
static fromNullable(scope, response) {
|
|
79
|
+
return response ? ResponseDispatcher.from(scope, response) : undefined;
|
|
80
|
+
}
|
|
81
|
+
constructor(scope, response) {
|
|
82
|
+
super(scope, response, 'Response', {
|
|
83
|
+
// TODO: responses in popups can point to non-reported requests.
|
|
84
|
+
request: scope,
|
|
85
|
+
url: response.url(),
|
|
86
|
+
status: response.status(),
|
|
87
|
+
statusText: response.statusText(),
|
|
88
|
+
headers: response.headers(),
|
|
89
|
+
timing: response.timing(),
|
|
90
|
+
fromServiceWorker: response.fromServiceWorker()
|
|
91
|
+
});
|
|
92
|
+
this._type_Response = true;
|
|
93
|
+
}
|
|
94
|
+
async body() {
|
|
95
|
+
return {
|
|
96
|
+
binary: await this._object.body()
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
async securityDetails() {
|
|
100
|
+
return {
|
|
101
|
+
value: (await this._object.securityDetails()) || undefined
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
async serverAddr() {
|
|
105
|
+
return {
|
|
106
|
+
value: (await this._object.serverAddr()) || undefined
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
async rawResponseHeaders(params) {
|
|
110
|
+
return {
|
|
111
|
+
headers: await this._object.rawResponseHeaders()
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
async sizes(params) {
|
|
115
|
+
return {
|
|
116
|
+
sizes: await this._object.sizes()
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
exports.ResponseDispatcher = ResponseDispatcher;
|
|
121
|
+
class RouteDispatcher extends _dispatcher.Dispatcher {
|
|
122
|
+
static from(scope, route) {
|
|
123
|
+
const result = (0, _dispatcher.existingDispatcher)(route);
|
|
124
|
+
return result || new RouteDispatcher(scope, route);
|
|
125
|
+
}
|
|
126
|
+
constructor(scope, route) {
|
|
127
|
+
super(scope, route, 'Route', {
|
|
128
|
+
// Context route can point to a non-reported request, so we send the request in the initializer.
|
|
129
|
+
request: scope
|
|
130
|
+
});
|
|
131
|
+
this._type_Route = true;
|
|
132
|
+
}
|
|
133
|
+
async continue(params, metadata) {
|
|
134
|
+
await this._object.continue({
|
|
135
|
+
url: params.url,
|
|
136
|
+
method: params.method,
|
|
137
|
+
headers: params.headers,
|
|
138
|
+
postData: params.postData,
|
|
139
|
+
isFallback: params.isFallback
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
async fulfill(params, metadata) {
|
|
143
|
+
await this._object.fulfill(params);
|
|
144
|
+
}
|
|
145
|
+
async abort(params, metadata) {
|
|
146
|
+
await this._object.abort(params.errorCode || 'failed');
|
|
147
|
+
}
|
|
148
|
+
async redirectNavigationRequest(params) {
|
|
149
|
+
await this._object.redirectNavigationRequest(params.url);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
exports.RouteDispatcher = RouteDispatcher;
|
|
153
|
+
class WebSocketDispatcher extends _dispatcher.Dispatcher {
|
|
154
|
+
constructor(scope, webSocket) {
|
|
155
|
+
super(scope, webSocket, 'WebSocket', {
|
|
156
|
+
url: webSocket.url()
|
|
157
|
+
});
|
|
158
|
+
this._type_EventTarget = true;
|
|
159
|
+
this._type_WebSocket = true;
|
|
160
|
+
this.addObjectListener(_network.WebSocket.Events.FrameSent, event => this._dispatchEvent('frameSent', event));
|
|
161
|
+
this.addObjectListener(_network.WebSocket.Events.FrameReceived, event => this._dispatchEvent('frameReceived', event));
|
|
162
|
+
this.addObjectListener(_network.WebSocket.Events.SocketError, error => this._dispatchEvent('socketError', {
|
|
163
|
+
error
|
|
164
|
+
}));
|
|
165
|
+
this.addObjectListener(_network.WebSocket.Events.Close, () => this._dispatchEvent('close', {}));
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
exports.WebSocketDispatcher = WebSocketDispatcher;
|
|
169
|
+
class APIRequestContextDispatcher extends _dispatcher.Dispatcher {
|
|
170
|
+
static from(scope, request) {
|
|
171
|
+
const result = (0, _dispatcher.existingDispatcher)(request);
|
|
172
|
+
return result || new APIRequestContextDispatcher(scope, request);
|
|
173
|
+
}
|
|
174
|
+
static fromNullable(scope, request) {
|
|
175
|
+
return request ? APIRequestContextDispatcher.from(scope, request) : undefined;
|
|
176
|
+
}
|
|
177
|
+
constructor(parentScope, request) {
|
|
178
|
+
// We will reparent these to the context below.
|
|
179
|
+
const tracing = _tracingDispatcher.TracingDispatcher.from(parentScope, request.tracing());
|
|
180
|
+
super(parentScope, request, 'APIRequestContext', {
|
|
181
|
+
tracing
|
|
182
|
+
});
|
|
183
|
+
this._type_APIRequestContext = true;
|
|
184
|
+
this.adopt(tracing);
|
|
185
|
+
}
|
|
186
|
+
async storageState() {
|
|
187
|
+
return this._object.storageState();
|
|
188
|
+
}
|
|
189
|
+
async dispose(_, metadata) {
|
|
190
|
+
metadata.potentiallyClosesScope = true;
|
|
191
|
+
await this._object.dispose();
|
|
192
|
+
this._dispose();
|
|
193
|
+
}
|
|
194
|
+
async fetch(params, metadata) {
|
|
195
|
+
const fetchResponse = await this._object.fetch(params, metadata);
|
|
196
|
+
return {
|
|
197
|
+
response: {
|
|
198
|
+
url: fetchResponse.url,
|
|
199
|
+
status: fetchResponse.status,
|
|
200
|
+
statusText: fetchResponse.statusText,
|
|
201
|
+
headers: fetchResponse.headers,
|
|
202
|
+
fetchUid: fetchResponse.fetchUid
|
|
203
|
+
}
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
async fetchResponseBody(params) {
|
|
207
|
+
return {
|
|
208
|
+
binary: this._object.fetchResponses.get(params.fetchUid)
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
async fetchLog(params) {
|
|
212
|
+
const log = this._object.fetchLog.get(params.fetchUid) || [];
|
|
213
|
+
return {
|
|
214
|
+
log
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
async disposeAPIResponse(params) {
|
|
218
|
+
this._object.disposeResponse(params.fetchUid);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
exports.APIRequestContextDispatcher = APIRequestContextDispatcher;
|