patchright-core 1.52.5 → 1.55.1
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/ThirdPartyNotices.txt +65 -123
- package/bin/reinstall_chrome_beta_mac.sh +1 -1
- package/bin/reinstall_chrome_stable_mac.sh +1 -1
- package/bin/reinstall_msedge_beta_mac.sh +1 -1
- package/bin/reinstall_msedge_dev_mac.sh +1 -1
- package/bin/reinstall_msedge_stable_mac.sh +1 -1
- package/browsers.json +14 -14
- package/index.js +1 -1
- package/lib/androidServerImpl.js +4 -2
- package/lib/browserServerImpl.js +47 -12
- package/lib/cli/program.js +116 -50
- package/lib/cli/programWithTestStub.js +1 -1
- package/lib/client/android.js +30 -34
- package/lib/client/browser.js +54 -17
- package/lib/client/browserContext.js +67 -71
- package/lib/client/browserType.js +25 -34
- package/lib/client/channelOwner.js +20 -24
- package/lib/client/connection.js +6 -10
- package/lib/client/electron.js +8 -3
- package/lib/client/elementHandle.js +18 -21
- package/lib/client/fetch.js +5 -3
- package/lib/client/frame.js +54 -32
- package/lib/client/input.js +3 -1
- package/lib/client/jsHandle.js +4 -0
- package/lib/client/localUtils.js +0 -1
- package/lib/client/locator.js +30 -26
- package/lib/client/network.js +5 -12
- package/lib/client/page.js +32 -32
- package/lib/client/playwright.js +6 -16
- package/lib/client/selectors.js +18 -38
- package/lib/client/timeoutSettings.js +12 -8
- package/lib/client/tracing.js +24 -20
- package/lib/client/waiter.js +2 -2
- package/lib/client/webSocket.js +4 -22
- package/lib/generated/bindingsControllerSource.js +28 -0
- package/lib/generated/clockSource.js +1 -1
- package/lib/generated/injectedScriptSource.js +1 -1
- package/lib/generated/pollingRecorderSource.js +1 -1
- package/lib/generated/storageScriptSource.js +28 -0
- package/lib/generated/utilityScriptSource.js +1 -1
- package/lib/generated/webSocketMockSource.js +12 -50
- package/lib/inProcessFactory.js +9 -6
- package/lib/outofprocess.js +0 -2
- package/lib/protocol/validator.js +421 -345
- package/lib/protocol/validatorPrimitives.js +18 -4
- package/lib/remote/playwrightConnection.js +29 -166
- package/lib/remote/playwrightServer.js +233 -35
- package/lib/server/android/android.js +97 -83
- package/lib/server/android/backendAdb.js +0 -2
- package/lib/server/bidi/bidiBrowser.js +139 -73
- package/lib/server/bidi/bidiChromium.js +23 -22
- package/lib/server/bidi/bidiExecutionContext.js +2 -1
- package/lib/server/bidi/bidiFirefox.js +17 -14
- package/lib/server/bidi/bidiInput.js +22 -22
- package/lib/server/bidi/bidiNetworkManager.js +8 -11
- package/lib/server/bidi/bidiPage.js +42 -86
- package/lib/server/bidi/third_party/bidiProtocol.js +5 -133
- package/lib/server/bidi/third_party/bidiProtocolCore.js +179 -0
- package/lib/server/{dispatchers/selectorsDispatcher.js → bidi/third_party/bidiProtocolPermissions.js} +20 -18
- package/lib/server/browser.js +30 -21
- package/lib/server/browserContext.js +203 -165
- package/lib/server/browserType.js +109 -107
- package/lib/server/chromium/chromium.js +84 -69
- package/lib/server/chromium/chromiumSwitches.js +13 -20
- package/lib/server/chromium/crBrowser.js +74 -40
- package/lib/server/chromium/crConnection.js +8 -9
- package/lib/server/chromium/crCoverage.js +11 -8
- package/lib/server/chromium/crDragDrop.js +25 -20
- package/lib/server/chromium/crExecutionContext.js +2 -1
- package/lib/server/chromium/crInput.js +32 -29
- package/lib/server/chromium/crNetworkManager.js +43 -31
- package/lib/server/chromium/crPage.js +98 -72
- package/lib/server/chromium/crServiceWorker.js +13 -18
- package/lib/server/chromium/videoRecorder.js +10 -18
- package/lib/server/clock.js +51 -39
- package/lib/server/codegen/csharp.js +10 -5
- package/lib/server/codegen/java.js +1 -1
- package/lib/server/codegen/javascript.js +1 -1
- package/lib/server/codegen/jsonl.js +2 -1
- package/lib/server/codegen/language.js +22 -1
- package/lib/server/codegen/languages.js +4 -4
- package/lib/server/codegen/python.js +1 -1
- package/lib/server/cookieStore.js +3 -1
- package/lib/server/debugController.js +105 -71
- package/lib/server/debugger.js +6 -23
- package/lib/server/deviceDescriptorsSource.json +237 -127
- package/lib/server/dialog.js +50 -6
- package/lib/server/dispatchers/androidDispatcher.js +77 -62
- package/lib/server/dispatchers/artifactDispatcher.js +18 -18
- package/lib/server/dispatchers/browserContextDispatcher.js +141 -91
- package/lib/server/dispatchers/browserDispatcher.js +55 -88
- package/lib/server/dispatchers/browserTypeDispatcher.js +18 -9
- package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -4
- package/lib/server/dispatchers/debugControllerDispatcher.js +12 -21
- package/lib/server/dispatchers/dialogDispatcher.js +4 -4
- package/lib/server/dispatchers/dispatcher.js +78 -53
- package/lib/server/dispatchers/electronDispatcher.js +19 -20
- package/lib/server/dispatchers/elementHandlerDispatcher.js +83 -93
- package/lib/server/dispatchers/frameDispatcher.js +98 -101
- package/lib/server/dispatchers/jsHandleDispatcher.js +21 -16
- package/lib/server/dispatchers/jsonPipeDispatcher.js +4 -4
- package/lib/server/dispatchers/localUtilsDispatcher.js +53 -59
- package/lib/server/dispatchers/networkDispatchers.js +41 -35
- package/lib/server/dispatchers/pageDispatcher.js +156 -107
- package/lib/server/dispatchers/playwrightDispatcher.js +37 -25
- package/lib/server/dispatchers/streamDispatcher.js +15 -8
- package/lib/server/dispatchers/tracingDispatcher.js +22 -13
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +46 -35
- package/lib/server/dispatchers/writableStreamDispatcher.js +16 -10
- package/lib/server/dom.js +198 -266
- package/lib/server/download.js +3 -3
- package/lib/server/electron/electron.js +96 -103
- package/lib/server/electron/loader.js +1 -1
- package/lib/server/fetch.js +22 -41
- package/lib/server/fileUploadUtils.js +1 -1
- package/lib/server/firefox/ffBrowser.js +79 -55
- package/lib/server/firefox/ffExecutionContext.js +2 -1
- package/lib/server/firefox/ffInput.js +23 -23
- package/lib/server/firefox/ffNetworkManager.js +8 -6
- package/lib/server/firefox/ffPage.js +39 -36
- package/lib/server/firefox/firefox.js +9 -10
- package/lib/server/frameSelectors.js +63 -20
- package/lib/server/frames.js +495 -555
- package/lib/server/har/harRecorder.js +1 -1
- package/lib/server/har/harTracer.js +4 -2
- package/lib/server/helper.js +3 -7
- package/lib/server/index.js +0 -3
- package/lib/server/input.js +47 -54
- package/lib/server/instrumentation.js +8 -14
- package/lib/server/javascript.js +8 -16
- package/lib/server/launchApp.js +48 -30
- package/lib/server/localUtils.js +45 -38
- package/lib/server/network.js +44 -10
- package/lib/server/page.js +232 -177
- package/lib/server/pageBinding.js +6 -7
- package/lib/server/playwright.js +4 -14
- package/lib/server/progress.js +57 -49
- package/lib/server/recorder/recorderApp.js +298 -95
- package/lib/server/recorder/recorderRunner.js +23 -24
- package/lib/server/recorder/recorderSignalProcessor.js +83 -0
- package/lib/server/recorder/recorderUtils.js +67 -10
- package/lib/server/recorder.js +284 -146
- package/lib/server/registry/index.js +83 -48
- package/lib/server/registry/nativeDeps.js +175 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +1 -1
- package/lib/server/screenshotter.js +84 -83
- package/lib/server/selectors.js +12 -12
- package/lib/server/socksClientCertificatesInterceptor.js +198 -136
- package/lib/server/trace/recorder/snapshotter.js +12 -19
- package/lib/server/trace/recorder/tracing.js +36 -27
- package/lib/server/trace/viewer/traceViewer.js +11 -20
- package/lib/server/transport.js +20 -22
- package/lib/server/utils/comparators.js +2 -2
- package/lib/server/utils/debug.js +3 -8
- package/lib/server/utils/debugLogger.js +8 -0
- package/lib/server/utils/hostPlatform.js +3 -1
- package/lib/server/utils/network.js +35 -25
- package/lib/server/utils/nodePlatform.js +1 -1
- package/lib/server/utils/processLauncher.js +4 -1
- package/lib/server/utils/wsServer.js +11 -17
- package/lib/server/webkit/webkit.js +5 -2
- package/lib/server/webkit/wkBrowser.js +51 -28
- package/lib/server/webkit/wkExecutionContext.js +2 -1
- package/lib/server/webkit/wkInput.js +25 -25
- package/lib/server/webkit/wkInterceptableRequest.js +1 -1
- package/lib/server/webkit/wkPage.js +80 -59
- package/lib/server/webkit/wkProvisionalPage.js +1 -1
- package/lib/server/webkit/wkWorkers.js +7 -7
- package/lib/utils/isomorphic/ariaSnapshot.js +13 -7
- package/lib/utils/isomorphic/cssParser.js +1 -2
- package/lib/utils/isomorphic/locatorGenerators.js +18 -0
- package/lib/utils/isomorphic/manualPromise.js +1 -2
- package/lib/utils/isomorphic/mimeType.js +1 -2
- package/lib/utils/isomorphic/multimap.js +1 -2
- package/lib/utils/isomorphic/oldUtilityScriptSerializers.js +248 -0
- package/lib/utils/isomorphic/protocolFormatter.js +78 -0
- package/lib/utils/isomorphic/protocolMetainfo.js +318 -0
- package/lib/utils/isomorphic/selectorParser.js +3 -4
- package/lib/utils/isomorphic/stringUtils.js +3 -24
- package/lib/utils/isomorphic/time.js +9 -4
- package/lib/utils/isomorphic/timeoutRunner.js +3 -4
- package/lib/utils/isomorphic/traceUtils.js +2 -3
- package/lib/utils/isomorphic/urlMatch.js +21 -7
- package/lib/utils/isomorphic/utilityScriptSerializers.js +208 -205
- package/lib/utils.js +8 -2
- package/lib/utilsBundleImpl/index.js +160 -150
- package/lib/vite/htmlReport/index.html +17 -17
- package/lib/vite/recorder/assets/{codeMirrorModule-CXVeovup.js → codeMirrorModule-DzQ0k89p.js} +1 -1
- package/lib/vite/recorder/assets/{index-eHBmevrY.css → index-CI4HQ-Zb.css} +1 -1
- package/lib/vite/recorder/assets/index-D7C7daHH.js +184 -0
- package/lib/vite/recorder/index.html +3 -3
- package/lib/vite/traceViewer/assets/{codeMirrorModule-_GLjJL-7.js → codeMirrorModule-Di48jgWx.js} +1 -1
- package/lib/vite/traceViewer/assets/defaultSettingsView-szBn8781.js +256 -0
- package/lib/vite/traceViewer/defaultSettingsView.DVJHpiGt.css +1 -0
- package/lib/vite/traceViewer/index.BFsek2M6.css +1 -0
- package/lib/vite/traceViewer/index.DQvXoPLL.js +2 -0
- package/lib/vite/traceViewer/index.html +6 -6
- package/lib/vite/traceViewer/sw.bundle.js +3 -3
- package/lib/vite/traceViewer/uiMode.dBV3oN9h.js +5 -0
- package/lib/vite/traceViewer/uiMode.html +4 -4
- package/lib/zipBundleImpl.js +4 -4
- package/package.json +1 -1
- package/types/protocol.d.ts +712 -107
- package/types/types.d.ts +128 -17
- package/lib/generated/consoleApiSource.js +0 -28
- package/lib/protocol/debug.js +0 -211
- package/lib/server/recorder/contextRecorder.js +0 -286
- package/lib/server/recorder/recorderCollection.js +0 -116
- package/lib/server/recorder/recorderFrontend.js +0 -16
- package/lib/server/storageScript.js +0 -154
- package/lib/server/timeoutSettings.js +0 -89
- package/lib/utils/isomorphic/builtins.js +0 -86
- package/lib/vite/recorder/assets/index-BsWQsSGl.js +0 -184
- package/lib/vite/traceViewer/assets/defaultSettingsView-DtCQiGHe.js +0 -265
- package/lib/vite/traceViewer/defaultSettingsView.QdHITyLI.css +0 -1
- package/lib/vite/traceViewer/index.CFOW-Ezb.css +0 -1
- package/lib/vite/traceViewer/index.cFZzK9RN.js +0 -2
- package/lib/vite/traceViewer/uiMode.XVPIqBeS.js +0 -5
|
@@ -69,13 +69,13 @@ class CRNetworkManager {
|
|
|
69
69
|
];
|
|
70
70
|
if (this._page) {
|
|
71
71
|
sessionInfo.eventListeners.push(...[
|
|
72
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketCreated", (e) => this._page.
|
|
73
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketWillSendHandshakeRequest", (e) => this._page.
|
|
74
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketHandshakeResponseReceived", (e) => this._page.
|
|
75
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameSent", (e) => e.response.payloadData && this._page.
|
|
76
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameReceived", (e) => e.response.payloadData && this._page.
|
|
77
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketClosed", (e) => this._page.
|
|
78
|
-
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameError", (e) => this._page.
|
|
72
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketCreated", (e) => this._page.frameManager.onWebSocketCreated(e.requestId, e.url)),
|
|
73
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketWillSendHandshakeRequest", (e) => this._page.frameManager.onWebSocketRequest(e.requestId)),
|
|
74
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketHandshakeResponseReceived", (e) => this._page.frameManager.onWebSocketResponse(e.requestId, e.response.status, e.response.statusText)),
|
|
75
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameSent", (e) => e.response.payloadData && this._page.frameManager.onWebSocketFrameSent(e.requestId, e.response.opcode, e.response.payloadData)),
|
|
76
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameReceived", (e) => e.response.payloadData && this._page.frameManager.webSocketFrameReceived(e.requestId, e.response.opcode, e.response.payloadData)),
|
|
77
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketClosed", (e) => this._page.frameManager.webSocketClosed(e.requestId)),
|
|
78
|
+
import_eventsHelper.eventsHelper.addEventListener(session, "Network.webSocketFrameError", (e) => this._page.frameManager.webSocketError(e.requestId, e.errorMessage))
|
|
79
79
|
]);
|
|
80
80
|
}
|
|
81
81
|
this._sessions.set(session, sessionInfo);
|
|
@@ -265,11 +265,11 @@ class CRNetworkManager {
|
|
|
265
265
|
redirectedFrom = request2;
|
|
266
266
|
}
|
|
267
267
|
}
|
|
268
|
-
let frame = requestWillBeSentEvent.frameId ? this._page?.
|
|
268
|
+
let frame = requestWillBeSentEvent.frameId ? this._page?.frameManager.frame(requestWillBeSentEvent.frameId) : requestWillBeSentSessionInfo.workerFrame;
|
|
269
269
|
if (!frame && this._page && requestPausedEvent && requestPausedEvent.frameId)
|
|
270
|
-
frame = this._page.
|
|
271
|
-
if (!frame && this._page && requestWillBeSentEvent.frameId === (this._page?.
|
|
272
|
-
frame = this._page.
|
|
270
|
+
frame = this._page.frameManager.frame(requestPausedEvent.frameId);
|
|
271
|
+
if (!frame && this._page && requestWillBeSentEvent.frameId === (this._page?.delegate)._targetId) {
|
|
272
|
+
frame = this._page.frameManager.frameAttached(requestWillBeSentEvent.frameId, null);
|
|
273
273
|
}
|
|
274
274
|
const isInterceptedOptionsPreflight = !!requestPausedEvent && requestPausedEvent.request.method === "OPTIONS" && requestWillBeSentEvent.initiator.type === "preflight";
|
|
275
275
|
if (isInterceptedOptionsPreflight && (this._page || this._serviceWorker).needsRequestInterception()) {
|
|
@@ -309,7 +309,7 @@ class CRNetworkManager {
|
|
|
309
309
|
const documentId = isNavigationRequest ? requestWillBeSentEvent.loaderId : void 0;
|
|
310
310
|
const request = new InterceptableRequest({
|
|
311
311
|
session: requestWillBeSentSessionInfo.session,
|
|
312
|
-
context: (this._page || this._serviceWorker).
|
|
312
|
+
context: (this._page || this._serviceWorker).browserContext,
|
|
313
313
|
frame: frame || null,
|
|
314
314
|
serviceWorker: this._serviceWorker || null,
|
|
315
315
|
documentId,
|
|
@@ -323,7 +323,7 @@ class CRNetworkManager {
|
|
|
323
323
|
if (route) {
|
|
324
324
|
request.request.setRawRequestHeaders((0, import_utils.headersObjectToArray)(requestPausedEvent.request.headers, "\n"));
|
|
325
325
|
}
|
|
326
|
-
(this._page?.
|
|
326
|
+
(this._page?.frameManager || this._serviceWorker).requestStarted(request.request, route || void 0);
|
|
327
327
|
}
|
|
328
328
|
_createResponse(request, responsePayload, hasExtraInfo) {
|
|
329
329
|
const getResponseBody = async () => {
|
|
@@ -402,8 +402,8 @@ class CRNetworkManager {
|
|
|
402
402
|
response.setEncodedBodySize(null);
|
|
403
403
|
response._requestFinished((timestamp - request._timestamp) * 1e3);
|
|
404
404
|
this._deleteRequest(request);
|
|
405
|
-
(this._page?.
|
|
406
|
-
(this._page?.
|
|
405
|
+
(this._page?.frameManager || this._serviceWorker).requestReceivedResponse(response);
|
|
406
|
+
(this._page?.frameManager || this._serviceWorker).reportRequestFinished(request.request, response);
|
|
407
407
|
}
|
|
408
408
|
_onResponseReceivedExtraInfo(event) {
|
|
409
409
|
this._responseExtraInfoTracker.responseReceivedExtraInfo(event);
|
|
@@ -421,14 +421,14 @@ class CRNetworkManager {
|
|
|
421
421
|
if (!request)
|
|
422
422
|
return;
|
|
423
423
|
const response = this._createResponse(request, event.response, event.hasExtraInfo);
|
|
424
|
-
(this._page?.
|
|
424
|
+
(this._page?.frameManager || this._serviceWorker).requestReceivedResponse(response);
|
|
425
425
|
}
|
|
426
426
|
_onLoadingFinished(sessionInfo, event) {
|
|
427
427
|
this._responseExtraInfoTracker.loadingFinished(event);
|
|
428
428
|
const request = this._requestIdToRequest.get(event.requestId);
|
|
429
429
|
if (!request)
|
|
430
430
|
return;
|
|
431
|
-
this.
|
|
431
|
+
this._maybeUpdateRequestSession(sessionInfo, request);
|
|
432
432
|
const response = request.request._existingResponse();
|
|
433
433
|
if (response) {
|
|
434
434
|
response.setTransferSize(event.encodedDataLength);
|
|
@@ -436,7 +436,7 @@ class CRNetworkManager {
|
|
|
436
436
|
response._requestFinished(import_helper.helper.secondsToRoundishMillis(event.timestamp - request._timestamp));
|
|
437
437
|
}
|
|
438
438
|
this._deleteRequest(request);
|
|
439
|
-
(this._page?.
|
|
439
|
+
(this._page?.frameManager || this._serviceWorker).reportRequestFinished(request.request, response);
|
|
440
440
|
}
|
|
441
441
|
_onLoadingFailed(sessionInfo, event) {
|
|
442
442
|
this._responseExtraInfoTracker.loadingFailed(event);
|
|
@@ -451,7 +451,7 @@ class CRNetworkManager {
|
|
|
451
451
|
}
|
|
452
452
|
if (!request)
|
|
453
453
|
return;
|
|
454
|
-
this.
|
|
454
|
+
this._maybeUpdateRequestSession(sessionInfo, request);
|
|
455
455
|
const response = request.request._existingResponse();
|
|
456
456
|
if (response) {
|
|
457
457
|
response.setTransferSize(null);
|
|
@@ -462,10 +462,10 @@ class CRNetworkManager {
|
|
|
462
462
|
}
|
|
463
463
|
this._deleteRequest(request);
|
|
464
464
|
request.request._setFailureText(event.errorText || event.blockedReason || "");
|
|
465
|
-
(this._page?.
|
|
465
|
+
(this._page?.frameManager || this._serviceWorker).requestFailed(request.request, !!event.canceled);
|
|
466
466
|
}
|
|
467
|
-
|
|
468
|
-
if (request.session !== sessionInfo.session && !sessionInfo.isMain && request._documentId === request._requestId)
|
|
467
|
+
_maybeUpdateRequestSession(sessionInfo, request) {
|
|
468
|
+
if (request.session !== sessionInfo.session && !sessionInfo.isMain && (request._documentId === request._requestId || sessionInfo.workerFrame))
|
|
469
469
|
request.session = sessionInfo.session;
|
|
470
470
|
}
|
|
471
471
|
}
|
|
@@ -527,24 +527,29 @@ class RouteImpl {
|
|
|
527
527
|
}
|
|
528
528
|
}
|
|
529
529
|
async fulfill(response) {
|
|
530
|
-
const isTextHtml = response.
|
|
531
|
-
var allInjections = [...this._page.
|
|
532
|
-
for (const binding of this._page.
|
|
530
|
+
const isTextHtml = response.headers.some((header) => header.name.toLowerCase() === "content-type" && header.value.includes("text/html"));
|
|
531
|
+
var allInjections = [...this._page.delegate._mainFrameSession._evaluateOnNewDocumentScripts];
|
|
532
|
+
for (const binding of this._page.delegate._browserContext._pageBindings.values()) {
|
|
533
533
|
if (!allInjections.includes(binding)) allInjections.push(binding);
|
|
534
534
|
}
|
|
535
535
|
if (isTextHtml && allInjections.length) {
|
|
536
536
|
let scriptNonce = import_crypto.default.randomBytes(22).toString("hex");
|
|
537
|
+
let useNonce = true;
|
|
537
538
|
for (let i = 0; i < response.headers.length; i++) {
|
|
538
|
-
if (response.headers[i].name === "content-security-policy" || response.headers[i].name === "content-security-policy-report-only") {
|
|
539
|
+
if (response.headers[i].name.toLowerCase() === "content-security-policy" || response.headers[i].name.toLowerCase() === "content-security-policy-report-only") {
|
|
539
540
|
let cspValue = response.headers[i].value;
|
|
540
541
|
const nonceRegex = /script-src[^;]*'nonce-([\w-]+)'/;
|
|
541
542
|
const nonceMatch = cspValue.match(nonceRegex);
|
|
542
543
|
if (nonceMatch) {
|
|
543
544
|
scriptNonce = nonceMatch[1];
|
|
544
545
|
} else {
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
546
|
+
if (/script-src[^;]*'unsafe-inline'/.test(cspValue)) {
|
|
547
|
+
useNonce = false;
|
|
548
|
+
} else {
|
|
549
|
+
const scriptSrcRegex = /(script-src[^;]*)(;|$)/;
|
|
550
|
+
const newCspValue = cspValue.replace(scriptSrcRegex, `$1 'nonce-${scriptNonce}'$2`);
|
|
551
|
+
response.headers[i].value = newCspValue;
|
|
552
|
+
}
|
|
548
553
|
}
|
|
549
554
|
break;
|
|
550
555
|
}
|
|
@@ -553,11 +558,18 @@ class RouteImpl {
|
|
|
553
558
|
allInjections.forEach((script) => {
|
|
554
559
|
let scriptId = import_crypto.default.randomBytes(22).toString("hex");
|
|
555
560
|
let scriptSource = script.source || script;
|
|
556
|
-
|
|
561
|
+
if (useNonce) {
|
|
562
|
+
injectionHTML += `<script class="${this._page.delegate.initScriptTag}" nonce="${scriptNonce}" id="${scriptId}" type="text/javascript">document.getElementById("${scriptId}")?.remove();${scriptSource}</script>`;
|
|
563
|
+
} else {
|
|
564
|
+
injectionHTML += `<script class="${this._page.delegate.initScriptTag}" id="${scriptId}" type="text/javascript">document.getElementById("${scriptId}")?.remove();${scriptSource}</script>`;
|
|
565
|
+
}
|
|
557
566
|
});
|
|
558
567
|
if (response.isBase64) {
|
|
559
568
|
response.isBase64 = false;
|
|
560
|
-
response.body =
|
|
569
|
+
response.body = Buffer.from(response.body, "base64").toString("utf-8");
|
|
570
|
+
}
|
|
571
|
+
if (/^<!DOCTYPE[sS]*?>/i.test(response.body)) {
|
|
572
|
+
response.body = response.body.replace(/^<!DOCTYPE[sS]*?>/i, (match) => `${match}${injectionHTML}`);
|
|
561
573
|
} else {
|
|
562
574
|
response.body = injectionHTML + response.body;
|
|
563
575
|
}
|