@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,601 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
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 _network = require("../utils/network");
|
|
19
|
+
var _multimap = require("../utils/multimap");
|
|
20
|
+
var _fetch = require("./fetch");
|
|
21
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
22
|
+
/**
|
|
23
|
+
* Copyright (c) Microsoft Corporation.
|
|
24
|
+
*
|
|
25
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
26
|
+
* you may not use this file except in compliance with the License.
|
|
27
|
+
* You may obtain a copy of the License at
|
|
28
|
+
*
|
|
29
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
30
|
+
*
|
|
31
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
32
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
33
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
34
|
+
* See the License for the specific language governing permissions and
|
|
35
|
+
* limitations under the License.
|
|
36
|
+
*/
|
|
37
|
+
|
|
38
|
+
class Request extends _channelOwner.ChannelOwner {
|
|
39
|
+
static from(request) {
|
|
40
|
+
return request._object;
|
|
41
|
+
}
|
|
42
|
+
static fromNullable(request) {
|
|
43
|
+
return request ? Request.from(request) : null;
|
|
44
|
+
}
|
|
45
|
+
constructor(parent, type, guid, initializer) {
|
|
46
|
+
super(parent, type, guid, initializer);
|
|
47
|
+
this._redirectedFrom = null;
|
|
48
|
+
this._redirectedTo = null;
|
|
49
|
+
this._failureText = null;
|
|
50
|
+
this._provisionalHeaders = void 0;
|
|
51
|
+
this._actualHeadersPromise = void 0;
|
|
52
|
+
this._timing = void 0;
|
|
53
|
+
this._fallbackOverrides = {};
|
|
54
|
+
this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
|
|
55
|
+
if (this._redirectedFrom) this._redirectedFrom._redirectedTo = this;
|
|
56
|
+
this._provisionalHeaders = new RawHeaders(initializer.headers);
|
|
57
|
+
this._fallbackOverrides.postDataBuffer = initializer.postData;
|
|
58
|
+
this._timing = {
|
|
59
|
+
startTime: 0,
|
|
60
|
+
domainLookupStart: -1,
|
|
61
|
+
domainLookupEnd: -1,
|
|
62
|
+
connectStart: -1,
|
|
63
|
+
secureConnectionStart: -1,
|
|
64
|
+
connectEnd: -1,
|
|
65
|
+
requestStart: -1,
|
|
66
|
+
responseStart: -1,
|
|
67
|
+
responseEnd: -1
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
url() {
|
|
71
|
+
return this._fallbackOverrides.url || this._initializer.url;
|
|
72
|
+
}
|
|
73
|
+
resourceType() {
|
|
74
|
+
return this._initializer.resourceType;
|
|
75
|
+
}
|
|
76
|
+
method() {
|
|
77
|
+
return this._fallbackOverrides.method || this._initializer.method;
|
|
78
|
+
}
|
|
79
|
+
postData() {
|
|
80
|
+
var _this$_fallbackOverri;
|
|
81
|
+
return ((_this$_fallbackOverri = this._fallbackOverrides.postDataBuffer) === null || _this$_fallbackOverri === void 0 ? void 0 : _this$_fallbackOverri.toString('utf-8')) || null;
|
|
82
|
+
}
|
|
83
|
+
postDataBuffer() {
|
|
84
|
+
return this._fallbackOverrides.postDataBuffer || null;
|
|
85
|
+
}
|
|
86
|
+
postDataJSON() {
|
|
87
|
+
const postData = this.postData();
|
|
88
|
+
if (!postData) return null;
|
|
89
|
+
const contentType = this.headers()['content-type'];
|
|
90
|
+
if (contentType === 'application/x-www-form-urlencoded') {
|
|
91
|
+
const entries = {};
|
|
92
|
+
const parsed = new _url.URLSearchParams(postData);
|
|
93
|
+
for (const [k, v] of parsed.entries()) entries[k] = v;
|
|
94
|
+
return entries;
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
return JSON.parse(postData);
|
|
98
|
+
} catch (e) {
|
|
99
|
+
throw new Error('POST data is not a valid JSON object: ' + postData);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* @deprecated
|
|
105
|
+
*/
|
|
106
|
+
headers() {
|
|
107
|
+
if (this._fallbackOverrides.headers) return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers).headers();
|
|
108
|
+
return this._provisionalHeaders.headers();
|
|
109
|
+
}
|
|
110
|
+
async _actualHeaders() {
|
|
111
|
+
if (this._fallbackOverrides.headers) return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers);
|
|
112
|
+
if (!this._actualHeadersPromise) {
|
|
113
|
+
this._actualHeadersPromise = this._wrapApiCall(async () => {
|
|
114
|
+
return new RawHeaders((await this._channel.rawRequestHeaders()).headers);
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
return await this._actualHeadersPromise;
|
|
118
|
+
}
|
|
119
|
+
async allHeaders() {
|
|
120
|
+
return (await this._actualHeaders()).headers();
|
|
121
|
+
}
|
|
122
|
+
async headersArray() {
|
|
123
|
+
return (await this._actualHeaders()).headersArray();
|
|
124
|
+
}
|
|
125
|
+
async headerValue(name) {
|
|
126
|
+
return (await this._actualHeaders()).get(name);
|
|
127
|
+
}
|
|
128
|
+
async response() {
|
|
129
|
+
return Response.fromNullable((await this._channel.response()).response);
|
|
130
|
+
}
|
|
131
|
+
async _internalResponse() {
|
|
132
|
+
return await this._wrapApiCall(async () => {
|
|
133
|
+
return Response.fromNullable((await this._channel.response()).response);
|
|
134
|
+
}, true);
|
|
135
|
+
}
|
|
136
|
+
frame() {
|
|
137
|
+
if (!this._initializer.frame) {
|
|
138
|
+
(0, _utils.assert)(this.serviceWorker());
|
|
139
|
+
throw new Error('Service Worker requests do not have an associated frame.');
|
|
140
|
+
}
|
|
141
|
+
const frame = _frame.Frame.from(this._initializer.frame);
|
|
142
|
+
if (!frame._page) {
|
|
143
|
+
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'));
|
|
144
|
+
}
|
|
145
|
+
return frame;
|
|
146
|
+
}
|
|
147
|
+
_safePage() {
|
|
148
|
+
var _Frame$fromNullable;
|
|
149
|
+
return ((_Frame$fromNullable = _frame.Frame.fromNullable(this._initializer.frame)) === null || _Frame$fromNullable === void 0 ? void 0 : _Frame$fromNullable._page) || null;
|
|
150
|
+
}
|
|
151
|
+
serviceWorker() {
|
|
152
|
+
return this._initializer.serviceWorker ? _worker.Worker.from(this._initializer.serviceWorker) : null;
|
|
153
|
+
}
|
|
154
|
+
isNavigationRequest() {
|
|
155
|
+
return this._initializer.isNavigationRequest;
|
|
156
|
+
}
|
|
157
|
+
redirectedFrom() {
|
|
158
|
+
return this._redirectedFrom;
|
|
159
|
+
}
|
|
160
|
+
redirectedTo() {
|
|
161
|
+
return this._redirectedTo;
|
|
162
|
+
}
|
|
163
|
+
failure() {
|
|
164
|
+
if (this._failureText === null) return null;
|
|
165
|
+
return {
|
|
166
|
+
errorText: this._failureText
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
timing() {
|
|
170
|
+
return this._timing;
|
|
171
|
+
}
|
|
172
|
+
async sizes() {
|
|
173
|
+
const response = await this.response();
|
|
174
|
+
if (!response) throw new Error('Unable to fetch sizes for failed request');
|
|
175
|
+
return (await response._channel.sizes()).sizes;
|
|
176
|
+
}
|
|
177
|
+
_setResponseEndTiming(responseEndTiming) {
|
|
178
|
+
this._timing.responseEnd = responseEndTiming;
|
|
179
|
+
if (this._timing.responseStart === -1) this._timing.responseStart = responseEndTiming;
|
|
180
|
+
}
|
|
181
|
+
_finalRequest() {
|
|
182
|
+
return this._redirectedTo ? this._redirectedTo._finalRequest() : this;
|
|
183
|
+
}
|
|
184
|
+
_applyFallbackOverrides(overrides) {
|
|
185
|
+
if (overrides.url) this._fallbackOverrides.url = overrides.url;
|
|
186
|
+
if (overrides.method) this._fallbackOverrides.method = overrides.method;
|
|
187
|
+
if (overrides.headers) this._fallbackOverrides.headers = overrides.headers;
|
|
188
|
+
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');
|
|
189
|
+
}
|
|
190
|
+
_fallbackOverridesForContinue() {
|
|
191
|
+
return this._fallbackOverrides;
|
|
192
|
+
}
|
|
193
|
+
_targetClosedScope() {
|
|
194
|
+
var _this$serviceWorker, _this$_safePage;
|
|
195
|
+
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();
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
exports.Request = Request;
|
|
199
|
+
class Route extends _channelOwner.ChannelOwner {
|
|
200
|
+
static from(route) {
|
|
201
|
+
return route._object;
|
|
202
|
+
}
|
|
203
|
+
constructor(parent, type, guid, initializer) {
|
|
204
|
+
super(parent, type, guid, initializer);
|
|
205
|
+
this._handlingPromise = null;
|
|
206
|
+
this._context = void 0;
|
|
207
|
+
this._didThrow = false;
|
|
208
|
+
}
|
|
209
|
+
request() {
|
|
210
|
+
return Request.from(this._initializer.request);
|
|
211
|
+
}
|
|
212
|
+
async _raceWithTargetClose(promise) {
|
|
213
|
+
// When page closes or crashes, we catch any potential rejects from this Route.
|
|
214
|
+
// Note that page could be missing when routing popup's initial request that
|
|
215
|
+
// does not have a Page initialized just yet.
|
|
216
|
+
return await this.request()._targetClosedScope().safeRace(promise);
|
|
217
|
+
}
|
|
218
|
+
async _startHandling() {
|
|
219
|
+
this._handlingPromise = new _manualPromise.ManualPromise();
|
|
220
|
+
return await this._handlingPromise;
|
|
221
|
+
}
|
|
222
|
+
async fallback(options = {}) {
|
|
223
|
+
this._checkNotHandled();
|
|
224
|
+
this.request()._applyFallbackOverrides(options);
|
|
225
|
+
this._reportHandled(false);
|
|
226
|
+
}
|
|
227
|
+
async abort(errorCode) {
|
|
228
|
+
await this._handleRoute(async () => {
|
|
229
|
+
await this._raceWithTargetClose(this._channel.abort({
|
|
230
|
+
requestUrl: this.request()._initializer.url,
|
|
231
|
+
errorCode
|
|
232
|
+
}));
|
|
233
|
+
});
|
|
234
|
+
}
|
|
235
|
+
async _redirectNavigationRequest(url) {
|
|
236
|
+
await this._handleRoute(async () => {
|
|
237
|
+
await this._raceWithTargetClose(this._channel.redirectNavigationRequest({
|
|
238
|
+
url
|
|
239
|
+
}));
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
async fetch(options = {}) {
|
|
243
|
+
return await this._wrapApiCall(async () => {
|
|
244
|
+
return await this._context.request._innerFetch({
|
|
245
|
+
request: this.request(),
|
|
246
|
+
data: options.postData,
|
|
247
|
+
...options
|
|
248
|
+
});
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
async fulfill(options = {}) {
|
|
252
|
+
await this._handleRoute(async () => {
|
|
253
|
+
await this._wrapApiCall(async () => {
|
|
254
|
+
await this._innerFulfill(options);
|
|
255
|
+
});
|
|
256
|
+
});
|
|
257
|
+
}
|
|
258
|
+
async _handleRoute(callback) {
|
|
259
|
+
this._checkNotHandled();
|
|
260
|
+
try {
|
|
261
|
+
await callback();
|
|
262
|
+
this._reportHandled(true);
|
|
263
|
+
} catch (e) {
|
|
264
|
+
this._didThrow = true;
|
|
265
|
+
throw e;
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
async _innerFulfill(options = {}) {
|
|
269
|
+
let fetchResponseUid;
|
|
270
|
+
let {
|
|
271
|
+
status: statusOption,
|
|
272
|
+
headers: headersOption,
|
|
273
|
+
body
|
|
274
|
+
} = options;
|
|
275
|
+
if (options.json !== undefined) {
|
|
276
|
+
(0, _utils.assert)(options.body === undefined, 'Can specify either body or json parameters');
|
|
277
|
+
body = JSON.stringify(options.json);
|
|
278
|
+
}
|
|
279
|
+
if (options.response instanceof _fetch.APIResponse) {
|
|
280
|
+
var _statusOption, _headersOption;
|
|
281
|
+
(_statusOption = statusOption) !== null && _statusOption !== void 0 ? _statusOption : statusOption = options.response.status();
|
|
282
|
+
(_headersOption = headersOption) !== null && _headersOption !== void 0 ? _headersOption : headersOption = options.response.headers();
|
|
283
|
+
if (body === undefined && options.path === undefined) {
|
|
284
|
+
if (options.response._request._connection === this._connection) fetchResponseUid = options.response._fetchUid();else body = await options.response.body();
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
let isBase64 = false;
|
|
288
|
+
let length = 0;
|
|
289
|
+
if (options.path) {
|
|
290
|
+
const buffer = await _fs.default.promises.readFile(options.path);
|
|
291
|
+
body = buffer.toString('base64');
|
|
292
|
+
isBase64 = true;
|
|
293
|
+
length = buffer.length;
|
|
294
|
+
} else if ((0, _utils.isString)(body)) {
|
|
295
|
+
isBase64 = false;
|
|
296
|
+
length = Buffer.byteLength(body);
|
|
297
|
+
} else if (body) {
|
|
298
|
+
length = body.length;
|
|
299
|
+
body = body.toString('base64');
|
|
300
|
+
isBase64 = true;
|
|
301
|
+
}
|
|
302
|
+
const headers = {};
|
|
303
|
+
for (const header of Object.keys(headersOption || {})) headers[header.toLowerCase()] = String(headersOption[header]);
|
|
304
|
+
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';
|
|
305
|
+
if (length && !('content-length' in headers)) headers['content-length'] = String(length);
|
|
306
|
+
await this._raceWithTargetClose(this._channel.fulfill({
|
|
307
|
+
requestUrl: this.request()._initializer.url,
|
|
308
|
+
status: statusOption || 200,
|
|
309
|
+
headers: (0, _utils.headersObjectToArray)(headers),
|
|
310
|
+
body,
|
|
311
|
+
isBase64,
|
|
312
|
+
fetchResponseUid
|
|
313
|
+
}));
|
|
314
|
+
}
|
|
315
|
+
async continue(options = {}) {
|
|
316
|
+
await this._handleRoute(async () => {
|
|
317
|
+
this.request()._applyFallbackOverrides(options);
|
|
318
|
+
await this._innerContinue();
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
_checkNotHandled() {
|
|
322
|
+
if (!this._handlingPromise) throw new Error('Route is already handled!');
|
|
323
|
+
}
|
|
324
|
+
_reportHandled(done) {
|
|
325
|
+
const chain = this._handlingPromise;
|
|
326
|
+
this._handlingPromise = null;
|
|
327
|
+
chain.resolve(done);
|
|
328
|
+
}
|
|
329
|
+
async _innerContinue(internal = false) {
|
|
330
|
+
const options = this.request()._fallbackOverridesForContinue();
|
|
331
|
+
return await this._wrapApiCall(async () => {
|
|
332
|
+
await this._raceWithTargetClose(this._channel.continue({
|
|
333
|
+
requestUrl: this.request()._initializer.url,
|
|
334
|
+
url: options.url,
|
|
335
|
+
method: options.method,
|
|
336
|
+
headers: options.headers ? (0, _utils.headersObjectToArray)(options.headers) : undefined,
|
|
337
|
+
postData: options.postDataBuffer,
|
|
338
|
+
isFallback: internal
|
|
339
|
+
}));
|
|
340
|
+
}, !!internal);
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
exports.Route = Route;
|
|
344
|
+
class Response extends _channelOwner.ChannelOwner {
|
|
345
|
+
static from(response) {
|
|
346
|
+
return response._object;
|
|
347
|
+
}
|
|
348
|
+
static fromNullable(response) {
|
|
349
|
+
return response ? Response.from(response) : null;
|
|
350
|
+
}
|
|
351
|
+
constructor(parent, type, guid, initializer) {
|
|
352
|
+
super(parent, type, guid, initializer);
|
|
353
|
+
this._provisionalHeaders = void 0;
|
|
354
|
+
this._actualHeadersPromise = void 0;
|
|
355
|
+
this._request = void 0;
|
|
356
|
+
this._finishedPromise = new _manualPromise.ManualPromise();
|
|
357
|
+
this._provisionalHeaders = new RawHeaders(initializer.headers);
|
|
358
|
+
this._request = Request.from(this._initializer.request);
|
|
359
|
+
Object.assign(this._request._timing, this._initializer.timing);
|
|
360
|
+
}
|
|
361
|
+
url() {
|
|
362
|
+
return this._initializer.url;
|
|
363
|
+
}
|
|
364
|
+
ok() {
|
|
365
|
+
// Status 0 is for file:// URLs
|
|
366
|
+
return this._initializer.status === 0 || this._initializer.status >= 200 && this._initializer.status <= 299;
|
|
367
|
+
}
|
|
368
|
+
status() {
|
|
369
|
+
return this._initializer.status;
|
|
370
|
+
}
|
|
371
|
+
statusText() {
|
|
372
|
+
return this._initializer.statusText;
|
|
373
|
+
}
|
|
374
|
+
fromServiceWorker() {
|
|
375
|
+
return this._initializer.fromServiceWorker;
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
/**
|
|
379
|
+
* @deprecated
|
|
380
|
+
*/
|
|
381
|
+
headers() {
|
|
382
|
+
return this._provisionalHeaders.headers();
|
|
383
|
+
}
|
|
384
|
+
async _actualHeaders() {
|
|
385
|
+
if (!this._actualHeadersPromise) {
|
|
386
|
+
this._actualHeadersPromise = (async () => {
|
|
387
|
+
return new RawHeaders((await this._channel.rawResponseHeaders()).headers);
|
|
388
|
+
})();
|
|
389
|
+
}
|
|
390
|
+
return await this._actualHeadersPromise;
|
|
391
|
+
}
|
|
392
|
+
async allHeaders() {
|
|
393
|
+
return (await this._actualHeaders()).headers();
|
|
394
|
+
}
|
|
395
|
+
async headersArray() {
|
|
396
|
+
return (await this._actualHeaders()).headersArray().slice();
|
|
397
|
+
}
|
|
398
|
+
async headerValue(name) {
|
|
399
|
+
return (await this._actualHeaders()).get(name);
|
|
400
|
+
}
|
|
401
|
+
async headerValues(name) {
|
|
402
|
+
return (await this._actualHeaders()).getAll(name);
|
|
403
|
+
}
|
|
404
|
+
async finished() {
|
|
405
|
+
return await this.request()._targetClosedScope().race(this._finishedPromise);
|
|
406
|
+
}
|
|
407
|
+
async body() {
|
|
408
|
+
return (await this._channel.body()).binary;
|
|
409
|
+
}
|
|
410
|
+
async text() {
|
|
411
|
+
const content = await this.body();
|
|
412
|
+
return content.toString('utf8');
|
|
413
|
+
}
|
|
414
|
+
async json() {
|
|
415
|
+
const content = await this.text();
|
|
416
|
+
return JSON.parse(content);
|
|
417
|
+
}
|
|
418
|
+
request() {
|
|
419
|
+
return this._request;
|
|
420
|
+
}
|
|
421
|
+
frame() {
|
|
422
|
+
return this._request.frame();
|
|
423
|
+
}
|
|
424
|
+
async serverAddr() {
|
|
425
|
+
return (await this._channel.serverAddr()).value || null;
|
|
426
|
+
}
|
|
427
|
+
async securityDetails() {
|
|
428
|
+
return (await this._channel.securityDetails()).value || null;
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
exports.Response = Response;
|
|
432
|
+
class WebSocket extends _channelOwner.ChannelOwner {
|
|
433
|
+
static from(webSocket) {
|
|
434
|
+
return webSocket._object;
|
|
435
|
+
}
|
|
436
|
+
constructor(parent, type, guid, initializer) {
|
|
437
|
+
super(parent, type, guid, initializer);
|
|
438
|
+
this._page = void 0;
|
|
439
|
+
this._isClosed = void 0;
|
|
440
|
+
this._isClosed = false;
|
|
441
|
+
this._page = parent;
|
|
442
|
+
this._channel.on('frameSent', event => {
|
|
443
|
+
if (event.opcode === 1) this.emit(_events.Events.WebSocket.FrameSent, {
|
|
444
|
+
payload: event.data
|
|
445
|
+
});else if (event.opcode === 2) this.emit(_events.Events.WebSocket.FrameSent, {
|
|
446
|
+
payload: Buffer.from(event.data, 'base64')
|
|
447
|
+
});
|
|
448
|
+
});
|
|
449
|
+
this._channel.on('frameReceived', event => {
|
|
450
|
+
if (event.opcode === 1) this.emit(_events.Events.WebSocket.FrameReceived, {
|
|
451
|
+
payload: event.data
|
|
452
|
+
});else if (event.opcode === 2) this.emit(_events.Events.WebSocket.FrameReceived, {
|
|
453
|
+
payload: Buffer.from(event.data, 'base64')
|
|
454
|
+
});
|
|
455
|
+
});
|
|
456
|
+
this._channel.on('socketError', ({
|
|
457
|
+
error
|
|
458
|
+
}) => this.emit(_events.Events.WebSocket.Error, error));
|
|
459
|
+
this._channel.on('close', () => {
|
|
460
|
+
this._isClosed = true;
|
|
461
|
+
this.emit(_events.Events.WebSocket.Close, this);
|
|
462
|
+
});
|
|
463
|
+
}
|
|
464
|
+
url() {
|
|
465
|
+
return this._initializer.url;
|
|
466
|
+
}
|
|
467
|
+
isClosed() {
|
|
468
|
+
return this._isClosed;
|
|
469
|
+
}
|
|
470
|
+
async waitForEvent(event, optionsOrPredicate = {}) {
|
|
471
|
+
return await this._wrapApiCall(async () => {
|
|
472
|
+
const timeout = this._page._timeoutSettings.timeout(typeof optionsOrPredicate === 'function' ? {} : optionsOrPredicate);
|
|
473
|
+
const predicate = typeof optionsOrPredicate === 'function' ? optionsOrPredicate : optionsOrPredicate.predicate;
|
|
474
|
+
const waiter = _waiter.Waiter.createForEvent(this, event);
|
|
475
|
+
waiter.rejectOnTimeout(timeout, `Timeout ${timeout}ms exceeded while waiting for event "${event}"`);
|
|
476
|
+
if (event !== _events.Events.WebSocket.Error) waiter.rejectOnEvent(this, _events.Events.WebSocket.Error, new Error('Socket error'));
|
|
477
|
+
if (event !== _events.Events.WebSocket.Close) waiter.rejectOnEvent(this, _events.Events.WebSocket.Close, new Error('Socket closed'));
|
|
478
|
+
waiter.rejectOnEvent(this._page, _events.Events.Page.Close, () => this._page._closeErrorWithReason());
|
|
479
|
+
const result = await waiter.waitForEvent(this, event, predicate);
|
|
480
|
+
waiter.dispose();
|
|
481
|
+
return result;
|
|
482
|
+
});
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
exports.WebSocket = WebSocket;
|
|
486
|
+
function validateHeaders(headers) {
|
|
487
|
+
for (const key of Object.keys(headers)) {
|
|
488
|
+
const value = headers[key];
|
|
489
|
+
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.`);
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
class RouteHandler {
|
|
493
|
+
constructor(baseURL, url, handler, times = Number.MAX_SAFE_INTEGER) {
|
|
494
|
+
this.handledCount = 0;
|
|
495
|
+
this._baseURL = void 0;
|
|
496
|
+
this._times = void 0;
|
|
497
|
+
this.url = void 0;
|
|
498
|
+
this.handler = void 0;
|
|
499
|
+
this._ignoreException = false;
|
|
500
|
+
this._activeInvocations = new Set();
|
|
501
|
+
this._baseURL = baseURL;
|
|
502
|
+
this._times = times;
|
|
503
|
+
this.url = url;
|
|
504
|
+
this.handler = handler;
|
|
505
|
+
}
|
|
506
|
+
static prepareInterceptionPatterns(handlers) {
|
|
507
|
+
const patterns = [];
|
|
508
|
+
let all = false;
|
|
509
|
+
for (const handler of handlers) {
|
|
510
|
+
if ((0, _utils.isString)(handler.url)) patterns.push({
|
|
511
|
+
glob: handler.url
|
|
512
|
+
});else if ((0, _utils.isRegExp)(handler.url)) patterns.push({
|
|
513
|
+
regexSource: handler.url.source,
|
|
514
|
+
regexFlags: handler.url.flags
|
|
515
|
+
});else all = true;
|
|
516
|
+
}
|
|
517
|
+
if (all) return [{
|
|
518
|
+
glob: '**/*'
|
|
519
|
+
}];
|
|
520
|
+
return patterns;
|
|
521
|
+
}
|
|
522
|
+
matches(requestURL) {
|
|
523
|
+
return (0, _network.urlMatches)(this._baseURL, requestURL, this.url);
|
|
524
|
+
}
|
|
525
|
+
async handle(route) {
|
|
526
|
+
const handlerInvocation = {
|
|
527
|
+
complete: new _manualPromise.ManualPromise(),
|
|
528
|
+
route
|
|
529
|
+
};
|
|
530
|
+
this._activeInvocations.add(handlerInvocation);
|
|
531
|
+
try {
|
|
532
|
+
return await this._handleInternal(route);
|
|
533
|
+
} catch (e) {
|
|
534
|
+
// If the handler was stopped (without waiting for completion), we ignore all exceptions.
|
|
535
|
+
if (this._ignoreException) return false;
|
|
536
|
+
throw e;
|
|
537
|
+
} finally {
|
|
538
|
+
handlerInvocation.complete.resolve();
|
|
539
|
+
this._activeInvocations.delete(handlerInvocation);
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
async stop(behavior) {
|
|
543
|
+
// When a handler is manually unrouted or its page/context is closed we either
|
|
544
|
+
// - wait for the current handler invocations to finish
|
|
545
|
+
// - or do not wait, if the user opted out of it, but swallow all exceptions
|
|
546
|
+
// that happen after the unroute/close.
|
|
547
|
+
if (behavior === 'ignoreErrors') {
|
|
548
|
+
this._ignoreException = true;
|
|
549
|
+
} else {
|
|
550
|
+
const promises = [];
|
|
551
|
+
for (const activation of this._activeInvocations) {
|
|
552
|
+
if (!activation.route._didThrow) promises.push(activation.complete);
|
|
553
|
+
}
|
|
554
|
+
await Promise.all(promises);
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
async _handleInternal(route) {
|
|
558
|
+
++this.handledCount;
|
|
559
|
+
const handledPromise = route._startHandling();
|
|
560
|
+
// Extract handler into a variable to avoid [RouteHandler.handler] in the stack.
|
|
561
|
+
const handler = this.handler;
|
|
562
|
+
const [handled] = await Promise.all([handledPromise, handler(route, route.request())]);
|
|
563
|
+
return handled;
|
|
564
|
+
}
|
|
565
|
+
willExpire() {
|
|
566
|
+
return this.handledCount + 1 >= this._times;
|
|
567
|
+
}
|
|
568
|
+
}
|
|
569
|
+
exports.RouteHandler = RouteHandler;
|
|
570
|
+
class RawHeaders {
|
|
571
|
+
static _fromHeadersObjectLossy(headers) {
|
|
572
|
+
const headersArray = Object.entries(headers).map(([name, value]) => ({
|
|
573
|
+
name,
|
|
574
|
+
value
|
|
575
|
+
})).filter(header => header.value !== undefined);
|
|
576
|
+
return new RawHeaders(headersArray);
|
|
577
|
+
}
|
|
578
|
+
constructor(headers) {
|
|
579
|
+
this._headersArray = void 0;
|
|
580
|
+
this._headersMap = new _multimap.MultiMap();
|
|
581
|
+
this._headersArray = headers;
|
|
582
|
+
for (const header of headers) this._headersMap.set(header.name.toLowerCase(), header.value);
|
|
583
|
+
}
|
|
584
|
+
get(name) {
|
|
585
|
+
const values = this.getAll(name);
|
|
586
|
+
if (!values || !values.length) return null;
|
|
587
|
+
return values.join(name.toLowerCase() === 'set-cookie' ? '\n' : ', ');
|
|
588
|
+
}
|
|
589
|
+
getAll(name) {
|
|
590
|
+
return [...this._headersMap.get(name.toLowerCase())];
|
|
591
|
+
}
|
|
592
|
+
headers() {
|
|
593
|
+
const result = {};
|
|
594
|
+
for (const name of this._headersMap.keys()) result[name] = this.get(name);
|
|
595
|
+
return result;
|
|
596
|
+
}
|
|
597
|
+
headersArray() {
|
|
598
|
+
return this._headersArray;
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
exports.RawHeaders = RawHeaders;
|