devtools-tracing 1.1.1 → 1.2.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/.claude/settings.local.json +14 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +28854 -0
- package/package.json +11 -8
- package/generate.ts +0 -649
- package/index.ts +0 -17
- package/lib/extension-api/ExtensionAPI.d.ts +0 -357
- package/lib/front_end/core/common/App.ts +0 -7
- package/lib/front_end/core/common/AppProvider.ts +0 -32
- package/lib/front_end/core/common/Base64.ts +0 -47
- package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
- package/lib/front_end/core/common/Color.ts +0 -2506
- package/lib/front_end/core/common/ColorConverter.ts +0 -402
- package/lib/front_end/core/common/ColorUtils.ts +0 -252
- package/lib/front_end/core/common/Console.ts +0 -114
- package/lib/front_end/core/common/Debouncer.ts +0 -15
- package/lib/front_end/core/common/EventTarget.ts +0 -52
- package/lib/front_end/core/common/Gzip.ts +0 -74
- package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
- package/lib/front_end/core/common/Lazy.ts +0 -31
- package/lib/front_end/core/common/Linkifier.ts +0 -55
- package/lib/front_end/core/common/MapWithDefault.ts +0 -26
- package/lib/front_end/core/common/Mutex.ts +0 -55
- package/lib/front_end/core/common/Object.ts +0 -145
- package/lib/front_end/core/common/ParsedURL.ts +0 -554
- package/lib/front_end/core/common/Progress.ts +0 -180
- package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
- package/lib/front_end/core/common/ResolverBase.ts +0 -85
- package/lib/front_end/core/common/ResourceType.ts +0 -588
- package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
- package/lib/front_end/core/common/Revealer.ts +0 -192
- package/lib/front_end/core/common/Runnable.ts +0 -41
- package/lib/front_end/core/common/SegmentedRange.ts +0 -87
- package/lib/front_end/core/common/SettingRegistration.ts +0 -339
- package/lib/front_end/core/common/Settings.ts +0 -1497
- package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
- package/lib/front_end/core/common/StringOutputStream.ts +0 -26
- package/lib/front_end/core/common/TextDictionary.ts +0 -48
- package/lib/front_end/core/common/Throttler.ts +0 -99
- package/lib/front_end/core/common/Trie.ts +0 -152
- package/lib/front_end/core/common/Worker.ts +0 -60
- package/lib/front_end/core/common/common.ts +0 -81
- package/lib/front_end/core/host/AidaClient.ts +0 -733
- package/lib/front_end/core/host/GdpClient.ts +0 -316
- package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
- package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
- package/lib/front_end/core/host/Platform.ts +0 -76
- package/lib/front_end/core/host/ResourceLoader.ts +0 -282
- package/lib/front_end/core/host/UserMetrics.ts +0 -1230
- package/lib/front_end/core/host/host.ts +0 -23
- package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
- package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
- package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
- package/lib/front_end/core/i18n/i18n.ts +0 -17
- package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
- package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
- package/lib/front_end/core/i18n/locales.js +0 -14
- package/lib/front_end/core/i18n/time-utilities.ts +0 -174
- package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
- package/lib/front_end/core/platform/Brand.ts +0 -23
- package/lib/front_end/core/platform/Constructor.ts +0 -10
- package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
- package/lib/front_end/core/platform/DateUtilities.ts +0 -15
- package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
- package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
- package/lib/front_end/core/platform/MapUtilities.ts +0 -95
- package/lib/front_end/core/platform/MimeType.ts +0 -175
- package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
- package/lib/front_end/core/platform/StringUtilities.ts +0 -588
- package/lib/front_end/core/platform/Timing.ts +0 -17
- package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
- package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
- package/lib/front_end/core/platform/UIString.ts +0 -39
- package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
- package/lib/front_end/core/platform/platform.ts +0 -45
- package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
- package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
- package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
- package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
- package/lib/front_end/core/root/Runtime.ts +0 -609
- package/lib/front_end/core/root/root.ts +0 -6
- package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
- package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
- package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
- package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
- package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
- package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
- package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
- package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
- package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
- package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
- package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
- package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
- package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
- package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
- package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
- package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
- package/lib/front_end/core/sdk/CSSRule.ts +0 -465
- package/lib/front_end/core/sdk/CSSScope.ts +0 -30
- package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
- package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
- package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
- package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
- package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
- package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
- package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
- package/lib/front_end/core/sdk/Connections.ts +0 -293
- package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
- package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
- package/lib/front_end/core/sdk/Cookie.ts +0 -319
- package/lib/front_end/core/sdk/CookieModel.ts +0 -239
- package/lib/front_end/core/sdk/CookieParser.ts +0 -185
- package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
- package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
- package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
- package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
- package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
- package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
- package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
- package/lib/front_end/core/sdk/FrameManager.ts +0 -259
- package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
- package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
- package/lib/front_end/core/sdk/IOModel.ts +0 -91
- package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
- package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
- package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
- package/lib/front_end/core/sdk/LogModel.ts +0 -56
- package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
- package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
- package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
- package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
- package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
- package/lib/front_end/core/sdk/PageLoad.ts +0 -35
- package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
- package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
- package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
- package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
- package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
- package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
- package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
- package/lib/front_end/core/sdk/Resource.ts +0 -232
- package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
- package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
- package/lib/front_end/core/sdk/SDKModel.ts +0 -65
- package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
- package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
- package/lib/front_end/core/sdk/Script.ts +0 -534
- package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
- package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
- package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
- package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
- package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
- package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
- package/lib/front_end/core/sdk/SourceMap.ts +0 -867
- package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
- package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
- package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
- package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
- package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
- package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
- package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
- package/lib/front_end/core/sdk/Target.ts +0 -332
- package/lib/front_end/core/sdk/TargetManager.ts +0 -453
- package/lib/front_end/core/sdk/TraceObject.ts +0 -61
- package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
- package/lib/front_end/core/sdk/sdk.ts +0 -174
- package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
- package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
- package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
- package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
- package/lib/front_end/generated/protocol.ts +0 -22014
- package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
- package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
- package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
- package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
- package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
- package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
- package/lib/front_end/models/bindings/FileUtils.ts +0 -228
- package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
- package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
- package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
- package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
- package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
- package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
- package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
- package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
- package/lib/front_end/models/bindings/TempFile.ts +0 -67
- package/lib/front_end/models/bindings/bindings.ts +0 -39
- package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
- package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
- package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
- package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
- package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
- package/lib/front_end/models/formatter/formatter.ts +0 -8
- package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
- package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
- package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
- package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
- package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
- package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
- package/lib/front_end/models/stack_trace/Trie.ts +0 -163
- package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
- package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
- package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
- package/lib/front_end/models/text_utils/ContentData.ts +0 -199
- package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
- package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
- package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
- package/lib/front_end/models/text_utils/Text.ts +0 -90
- package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
- package/lib/front_end/models/text_utils/TextRange.ts +0 -266
- package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
- package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
- package/lib/front_end/models/text_utils/text_utils.ts +0 -27
- package/lib/front_end/models/trace/EntityMapper.ts +0 -141
- package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
- package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
- package/lib/front_end/models/trace/ModelImpl.ts +0 -236
- package/lib/front_end/models/trace/Name.ts +0 -136
- package/lib/front_end/models/trace/Processor.ts +0 -652
- package/lib/front_end/models/trace/Styles.ts +0 -1138
- package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
- package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
- package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
- package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
- package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
- package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
- package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
- package/lib/front_end/models/trace/extras/extras.ts +0 -11
- package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
- package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
- package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
- package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
- package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
- package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
- package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
- package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
- package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
- package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
- package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
- package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
- package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
- package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
- package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
- package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
- package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
- package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
- package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
- package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
- package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
- package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
- package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
- package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
- package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
- package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
- package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
- package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
- package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
- package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
- package/lib/front_end/models/trace/handlers/types.ts +0 -75
- package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
- package/lib/front_end/models/trace/helpers/Network.ts +0 -129
- package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
- package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
- package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
- package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
- package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
- package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
- package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
- package/lib/front_end/models/trace/insights/Cache.ts +0 -269
- package/lib/front_end/models/trace/insights/Common.ts +0 -453
- package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
- package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
- package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
- package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
- package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
- package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
- package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
- package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
- package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
- package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
- package/lib/front_end/models/trace/insights/Models.ts +0 -22
- package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
- package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
- package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
- package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
- package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
- package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
- package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
- package/lib/front_end/models/trace/insights/insights.ts +0 -10
- package/lib/front_end/models/trace/insights/types.ts +0 -157
- package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
- package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
- package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
- package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
- package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
- package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
- package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
- package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
- package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
- package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
- package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
- package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
- package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
- package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
- package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
- package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
- package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
- package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
- package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
- package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
- package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
- package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
- package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
- package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
- package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
- package/lib/front_end/models/trace/trace.ts +0 -33
- package/lib/front_end/models/trace/types/Configuration.ts +0 -110
- package/lib/front_end/models/trace/types/Extensions.ts +0 -136
- package/lib/front_end/models/trace/types/File.ts +0 -281
- package/lib/front_end/models/trace/types/Overlays.ts +0 -138
- package/lib/front_end/models/trace/types/Timing.ts +0 -30
- package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
- package/lib/front_end/models/trace/types/types.ts +0 -10
- package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
- package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
- package/lib/front_end/models/workspace/FileManager.ts +0 -97
- package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
- package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
- package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
- package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
- package/lib/front_end/models/workspace/workspace.ts +0 -17
- package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
- package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
- package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
- package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
- package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
- package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
- package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
- package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/package.json +0 -43
- package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
- package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
- package/lib/front_end/third_party/i18n/LICENSE +0 -202
- package/lib/front_end/third_party/i18n/README.chromium +0 -15
- package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
- package/lib/front_end/third_party/i18n/i18n.ts +0 -11
- package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
- package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
- package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
- package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
- package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
- package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
- package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
- package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
- package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
- package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
- package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
- package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
- package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
- package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
- package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
- package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
- package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
- package/lib/front_end/third_party/third-party-web/package.json +0 -8
- package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
- package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
- package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
- package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
- package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
- package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
|
@@ -1,2823 +0,0 @@
|
|
|
1
|
-
// Copyright 2011 The Chromium Authors
|
|
2
|
-
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
-
// found in the LICENSE file.
|
|
4
|
-
|
|
5
|
-
import type * as ProtocolProxyApi from '../../generated/protocol-proxy-api.js';
|
|
6
|
-
import * as Protocol from '../../generated/protocol.js';
|
|
7
|
-
import * as TextUtils from '../../models/text_utils/text_utils.js';
|
|
8
|
-
import * as Common from '../common/common.js';
|
|
9
|
-
import * as Host from '../host/host.js';
|
|
10
|
-
import * as i18n from '../i18n/i18n.js';
|
|
11
|
-
import * as Platform from '../platform/platform.js';
|
|
12
|
-
import * as Root from '../root/root.js';
|
|
13
|
-
|
|
14
|
-
import {Cookie} from './Cookie.js';
|
|
15
|
-
import {
|
|
16
|
-
type BlockedCookieWithReason,
|
|
17
|
-
DirectSocketChunkType,
|
|
18
|
-
DirectSocketStatus,
|
|
19
|
-
DirectSocketType,
|
|
20
|
-
Events as NetworkRequestEvents,
|
|
21
|
-
type ExtraRequestInfo,
|
|
22
|
-
type ExtraResponseInfo,
|
|
23
|
-
type IncludedCookieWithReason,
|
|
24
|
-
type NameValue,
|
|
25
|
-
NetworkRequest,
|
|
26
|
-
} from './NetworkRequest.js';
|
|
27
|
-
import {SDKModel} from './SDKModel.js';
|
|
28
|
-
import {Capability, type Target} from './Target.js';
|
|
29
|
-
import {type SDKModelObserver, TargetManager} from './TargetManager.js';
|
|
30
|
-
|
|
31
|
-
const UIStrings = {
|
|
32
|
-
/**
|
|
33
|
-
* @description Explanation why no content is shown for WebSocket connection.
|
|
34
|
-
*/
|
|
35
|
-
noContentForWebSocket: 'Content for WebSockets is currently not supported',
|
|
36
|
-
/**
|
|
37
|
-
* @description Explanation why no content is shown for redirect response.
|
|
38
|
-
*/
|
|
39
|
-
noContentForRedirect: 'No content available because this request was redirected',
|
|
40
|
-
/**
|
|
41
|
-
* @description Explanation why no content is shown for preflight request.
|
|
42
|
-
*/
|
|
43
|
-
noContentForPreflight: 'No content available for preflight request',
|
|
44
|
-
/**
|
|
45
|
-
* @description Text to indicate that network throttling is disabled
|
|
46
|
-
*/
|
|
47
|
-
noThrottling: 'No throttling',
|
|
48
|
-
/**
|
|
49
|
-
* @description Text to indicate the network connectivity is offline
|
|
50
|
-
*/
|
|
51
|
-
offline: 'Offline',
|
|
52
|
-
/**
|
|
53
|
-
* @description Text in Network Manager representing the "3G" throttling preset.
|
|
54
|
-
*/
|
|
55
|
-
slowG: '3G', // Named `slowG` for legacy reasons and because this value
|
|
56
|
-
// is serialized locally on the user's machine: if we
|
|
57
|
-
// change it we break their stored throttling settings.
|
|
58
|
-
// (See crrev.com/c/2947255)
|
|
59
|
-
/**
|
|
60
|
-
* @description Text in Network Manager representing the "Slow 4G" throttling preset
|
|
61
|
-
*/
|
|
62
|
-
fastG: 'Slow 4G', // Named `fastG` for legacy reasons and because this value
|
|
63
|
-
// is serialized locally on the user's machine: if we
|
|
64
|
-
// change it we break their stored throttling settings.
|
|
65
|
-
// (See crrev.com/c/2947255)
|
|
66
|
-
/**
|
|
67
|
-
* @description Text in Network Manager representing the "Fast 4G" throttling preset
|
|
68
|
-
*/
|
|
69
|
-
fast4G: 'Fast 4G',
|
|
70
|
-
/**
|
|
71
|
-
* @description Text in Network Manager representing the "Blocking" throttling preset
|
|
72
|
-
*/
|
|
73
|
-
block: 'Block',
|
|
74
|
-
/**
|
|
75
|
-
* @description Text in Network Manager
|
|
76
|
-
* @example {https://example.com} PH1
|
|
77
|
-
*/
|
|
78
|
-
requestWasBlockedByDevtoolsS: 'Request was blocked by DevTools: "{PH1}"',
|
|
79
|
-
/**
|
|
80
|
-
* @description Message in Network Manager
|
|
81
|
-
* @example {XHR} PH1
|
|
82
|
-
* @example {GET} PH2
|
|
83
|
-
* @example {https://example.com} PH3
|
|
84
|
-
*/
|
|
85
|
-
sFailedLoadingSS: '{PH1} failed loading: {PH2} "{PH3}".',
|
|
86
|
-
/**
|
|
87
|
-
* @description Message in Network Manager
|
|
88
|
-
* @example {XHR} PH1
|
|
89
|
-
* @example {GET} PH2
|
|
90
|
-
* @example {https://example.com} PH3
|
|
91
|
-
*/
|
|
92
|
-
sFinishedLoadingSS: '{PH1} finished loading: {PH2} "{PH3}".',
|
|
93
|
-
/**
|
|
94
|
-
* @description One of direct socket connection statuses
|
|
95
|
-
*/
|
|
96
|
-
directSocketStatusOpening: 'Opening',
|
|
97
|
-
/**
|
|
98
|
-
* @description One of direct socket connection statuses
|
|
99
|
-
*/
|
|
100
|
-
directSocketStatusOpen: 'Open',
|
|
101
|
-
/**
|
|
102
|
-
* @description One of direct socket connection statuses
|
|
103
|
-
*/
|
|
104
|
-
directSocketStatusClosed: 'Closed',
|
|
105
|
-
/**
|
|
106
|
-
* @description One of direct socket connection statuses
|
|
107
|
-
*/
|
|
108
|
-
directSocketStatusAborted: 'Aborted',
|
|
109
|
-
} as const;
|
|
110
|
-
const str_ = i18n.i18n.registerUIStrings('core/sdk/NetworkManager.ts', UIStrings);
|
|
111
|
-
const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
|
|
112
|
-
const i18nLazyString = i18n.i18n.getLazilyComputedLocalizedString.bind(undefined, str_);
|
|
113
|
-
|
|
114
|
-
const requestToManagerMap = new WeakMap<NetworkRequest, NetworkManager>();
|
|
115
|
-
|
|
116
|
-
const CONNECTION_TYPES = new Map([
|
|
117
|
-
['2g', Protocol.Network.ConnectionType.Cellular2g],
|
|
118
|
-
['3g', Protocol.Network.ConnectionType.Cellular3g],
|
|
119
|
-
['4g', Protocol.Network.ConnectionType.Cellular4g],
|
|
120
|
-
['bluetooth', Protocol.Network.ConnectionType.Bluetooth],
|
|
121
|
-
['wifi', Protocol.Network.ConnectionType.Wifi],
|
|
122
|
-
['wimax', Protocol.Network.ConnectionType.Wimax],
|
|
123
|
-
]);
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* We store two settings to disk to persist network throttling.
|
|
127
|
-
* 1. The custom conditions that the user has defined.
|
|
128
|
-
* 2. The active `key` that applies the correct current preset.
|
|
129
|
-
* The reason the setting creation functions are defined here is because they are referred
|
|
130
|
-
* to in multiple places, and this ensures we don't have accidental typos which
|
|
131
|
-
* mean extra settings get mistakenly created.
|
|
132
|
-
*/
|
|
133
|
-
export function customUserNetworkConditionsSetting(): Common.Settings.Setting<Conditions[]> {
|
|
134
|
-
return Common.Settings.Settings.instance().moduleSetting<Conditions[]>('custom-network-conditions');
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
export function activeNetworkThrottlingKeySetting(): Common.Settings.Setting<ThrottlingConditionKey> {
|
|
138
|
-
return Common.Settings.Settings.instance().createSetting(
|
|
139
|
-
'active-network-condition-key', PredefinedThrottlingConditionKey.NO_THROTTLING);
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
export class NetworkManager extends SDKModel<EventTypes> {
|
|
143
|
-
readonly dispatcher: NetworkDispatcher;
|
|
144
|
-
readonly fetchDispatcher: FetchDispatcher;
|
|
145
|
-
readonly #networkAgent: ProtocolProxyApi.NetworkApi;
|
|
146
|
-
readonly #bypassServiceWorkerSetting: Common.Settings.Setting<boolean>;
|
|
147
|
-
|
|
148
|
-
readonly activeNetworkThrottlingKey: Common.Settings.Setting<ThrottlingConditionKey> =
|
|
149
|
-
activeNetworkThrottlingKeySetting();
|
|
150
|
-
|
|
151
|
-
constructor(target: Target) {
|
|
152
|
-
super(target);
|
|
153
|
-
this.dispatcher = new NetworkDispatcher(this);
|
|
154
|
-
this.fetchDispatcher = new FetchDispatcher(target.fetchAgent(), this);
|
|
155
|
-
this.#networkAgent = target.networkAgent();
|
|
156
|
-
target.registerNetworkDispatcher(this.dispatcher);
|
|
157
|
-
target.registerFetchDispatcher(this.fetchDispatcher);
|
|
158
|
-
if (Common.Settings.Settings.instance().moduleSetting('cache-disabled').get()) {
|
|
159
|
-
void this.#networkAgent.invoke_setCacheDisabled({cacheDisabled: true});
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
if (Root.Runtime.hostConfig.devToolsPrivacyUI?.enabled &&
|
|
163
|
-
Root.Runtime.hostConfig.thirdPartyCookieControls?.managedBlockThirdPartyCookies !== true &&
|
|
164
|
-
(Common.Settings.Settings.instance().createSetting('cookie-control-override-enabled', undefined).get() ||
|
|
165
|
-
Common.Settings.Settings.instance().createSetting('grace-period-mitigation-disabled', undefined).get() ||
|
|
166
|
-
Common.Settings.Settings.instance().createSetting('heuristic-mitigation-disabled', undefined).get())) {
|
|
167
|
-
this.cookieControlFlagsSettingChanged();
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
void this.#networkAgent.invoke_enable({
|
|
171
|
-
maxPostDataSize: MAX_EAGER_POST_REQUEST_BODY_LENGTH,
|
|
172
|
-
enableDurableMessages: Root.Runtime.hostConfig.devToolsEnableDurableMessages?.enabled,
|
|
173
|
-
maxTotalBufferSize: MAX_RESPONSE_BODY_TOTAL_BUFFER_LENGTH,
|
|
174
|
-
reportDirectSocketTraffic: true,
|
|
175
|
-
});
|
|
176
|
-
void this.#networkAgent.invoke_setAttachDebugStack({enabled: true});
|
|
177
|
-
|
|
178
|
-
this.#bypassServiceWorkerSetting =
|
|
179
|
-
Common.Settings.Settings.instance().createSetting('bypass-service-worker', false);
|
|
180
|
-
if (this.#bypassServiceWorkerSetting.get()) {
|
|
181
|
-
this.bypassServiceWorkerChanged();
|
|
182
|
-
}
|
|
183
|
-
this.#bypassServiceWorkerSetting.addChangeListener(this.bypassServiceWorkerChanged, this);
|
|
184
|
-
|
|
185
|
-
Common.Settings.Settings.instance()
|
|
186
|
-
.moduleSetting('cache-disabled')
|
|
187
|
-
.addChangeListener(this.cacheDisabledSettingChanged, this);
|
|
188
|
-
|
|
189
|
-
Common.Settings.Settings.instance()
|
|
190
|
-
.createSetting('cookie-control-override-enabled', undefined)
|
|
191
|
-
.addChangeListener(this.cookieControlFlagsSettingChanged, this);
|
|
192
|
-
Common.Settings.Settings.instance()
|
|
193
|
-
.createSetting('grace-period-mitigation-disabled', undefined)
|
|
194
|
-
.addChangeListener(this.cookieControlFlagsSettingChanged, this);
|
|
195
|
-
Common.Settings.Settings.instance()
|
|
196
|
-
.createSetting('heuristic-mitigation-disabled', undefined)
|
|
197
|
-
.addChangeListener(this.cookieControlFlagsSettingChanged, this);
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
static forRequest(request: NetworkRequest): NetworkManager|null {
|
|
201
|
-
return requestToManagerMap.get(request) || null;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
static canReplayRequest(request: NetworkRequest): boolean {
|
|
205
|
-
return Boolean(requestToManagerMap.get(request)) && Boolean(request.backendRequestId()) && !request.isRedirect() &&
|
|
206
|
-
request.resourceType() === Common.ResourceType.resourceTypes.XHR;
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
static replayRequest(request: NetworkRequest): void {
|
|
210
|
-
const manager = requestToManagerMap.get(request);
|
|
211
|
-
const requestId = request.backendRequestId();
|
|
212
|
-
if (!manager || !requestId || request.isRedirect()) {
|
|
213
|
-
return;
|
|
214
|
-
}
|
|
215
|
-
void manager.#networkAgent.invoke_replayXHR({requestId});
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
static async searchInRequest(request: NetworkRequest, query: string, caseSensitive: boolean, isRegex: boolean):
|
|
219
|
-
Promise<TextUtils.ContentProvider.SearchMatch[]> {
|
|
220
|
-
const manager = NetworkManager.forRequest(request);
|
|
221
|
-
const requestId = request.backendRequestId();
|
|
222
|
-
if (!manager || !requestId || request.isRedirect()) {
|
|
223
|
-
return [];
|
|
224
|
-
}
|
|
225
|
-
const response =
|
|
226
|
-
await manager.#networkAgent.invoke_searchInResponseBody({requestId, query, caseSensitive, isRegex});
|
|
227
|
-
return TextUtils.TextUtils.performSearchInSearchMatches(response.result || [], query, caseSensitive, isRegex);
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
static async requestContentData(request: NetworkRequest): Promise<TextUtils.ContentData.ContentDataOrError> {
|
|
231
|
-
if (request.resourceType() === Common.ResourceType.resourceTypes.WebSocket) {
|
|
232
|
-
return {error: i18nString(UIStrings.noContentForWebSocket)};
|
|
233
|
-
}
|
|
234
|
-
if (!request.finished) {
|
|
235
|
-
await request.once(NetworkRequestEvents.FINISHED_LOADING);
|
|
236
|
-
}
|
|
237
|
-
if (request.isRedirect()) {
|
|
238
|
-
return {error: i18nString(UIStrings.noContentForRedirect)};
|
|
239
|
-
}
|
|
240
|
-
if (request.isPreflightRequest()) {
|
|
241
|
-
return {error: i18nString(UIStrings.noContentForPreflight)};
|
|
242
|
-
}
|
|
243
|
-
const manager = NetworkManager.forRequest(request);
|
|
244
|
-
if (!manager) {
|
|
245
|
-
return {error: 'No network manager for request'};
|
|
246
|
-
}
|
|
247
|
-
const requestId = request.backendRequestId();
|
|
248
|
-
if (!requestId) {
|
|
249
|
-
return {error: 'No backend request id for request'};
|
|
250
|
-
}
|
|
251
|
-
const response = await manager.#networkAgent.invoke_getResponseBody({requestId});
|
|
252
|
-
const error = response.getError();
|
|
253
|
-
if (error) {
|
|
254
|
-
return {error};
|
|
255
|
-
}
|
|
256
|
-
return new TextUtils.ContentData.ContentData(
|
|
257
|
-
response.body, response.base64Encoded, request.mimeType, request.charset() ?? undefined);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
/**
|
|
261
|
-
* Returns the already received bytes for an in-flight request. After calling this method
|
|
262
|
-
* "dataReceived" events will contain additional data.
|
|
263
|
-
*/
|
|
264
|
-
static async streamResponseBody(request: NetworkRequest): Promise<TextUtils.ContentData.ContentDataOrError> {
|
|
265
|
-
if (request.finished) {
|
|
266
|
-
return {error: 'Streaming the response body is only available for in-flight requests.'};
|
|
267
|
-
}
|
|
268
|
-
const manager = NetworkManager.forRequest(request);
|
|
269
|
-
if (!manager) {
|
|
270
|
-
return {error: 'No network manager for request'};
|
|
271
|
-
}
|
|
272
|
-
const requestId = request.backendRequestId();
|
|
273
|
-
if (!requestId) {
|
|
274
|
-
return {error: 'No backend request id for request'};
|
|
275
|
-
}
|
|
276
|
-
const response = await manager.#networkAgent.invoke_streamResourceContent({requestId});
|
|
277
|
-
const error = response.getError();
|
|
278
|
-
if (error) {
|
|
279
|
-
return {error};
|
|
280
|
-
}
|
|
281
|
-
// Wait for at least the `responseReceived event so we have accurate mimetype and charset.
|
|
282
|
-
await request.waitForResponseReceived();
|
|
283
|
-
return new TextUtils.ContentData.ContentData(
|
|
284
|
-
response.bufferedData, /* isBase64=*/ true, request.mimeType, request.charset() ?? undefined);
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
static async requestPostData(request: NetworkRequest): Promise<string|null> {
|
|
288
|
-
const manager = NetworkManager.forRequest(request);
|
|
289
|
-
if (!manager) {
|
|
290
|
-
console.error('No network manager for request');
|
|
291
|
-
return null;
|
|
292
|
-
}
|
|
293
|
-
const requestId = request.backendRequestId();
|
|
294
|
-
if (!requestId) {
|
|
295
|
-
console.error('No backend request id for request');
|
|
296
|
-
return null;
|
|
297
|
-
}
|
|
298
|
-
try {
|
|
299
|
-
const {postData} = await manager.#networkAgent.invoke_getRequestPostData({requestId});
|
|
300
|
-
return postData;
|
|
301
|
-
} catch (e) {
|
|
302
|
-
return e.message;
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
static connectionType(conditions: Conditions): Protocol.Network.ConnectionType {
|
|
307
|
-
if (!conditions.download && !conditions.upload) {
|
|
308
|
-
return Protocol.Network.ConnectionType.None;
|
|
309
|
-
}
|
|
310
|
-
try {
|
|
311
|
-
const title =
|
|
312
|
-
typeof conditions.title === 'function' ? conditions.title().toLowerCase() : conditions.title.toLowerCase();
|
|
313
|
-
for (const [name, protocolType] of CONNECTION_TYPES) {
|
|
314
|
-
if (title.includes(name)) {
|
|
315
|
-
return protocolType;
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
} catch {
|
|
319
|
-
// If the i18nKey for this condition has changed, calling conditions.title() will break, so in that case we reset to NONE
|
|
320
|
-
return Protocol.Network.ConnectionType.None;
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
return Protocol.Network.ConnectionType.Other;
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
static lowercaseHeaders(headers: Protocol.Network.Headers): Protocol.Network.Headers {
|
|
327
|
-
const newHeaders: Protocol.Network.Headers = {};
|
|
328
|
-
for (const headerName in headers) {
|
|
329
|
-
newHeaders[headerName.toLowerCase()] = headers[headerName];
|
|
330
|
-
}
|
|
331
|
-
return newHeaders;
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
requestForURL(url: Platform.DevToolsPath.UrlString): NetworkRequest|null {
|
|
335
|
-
return this.dispatcher.requestForURL(url);
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
requestForId(id: string): NetworkRequest|null {
|
|
339
|
-
return this.dispatcher.requestForId(id);
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
requestForLoaderId(loaderId: Protocol.Network.LoaderId): NetworkRequest|null {
|
|
343
|
-
return this.dispatcher.requestForLoaderId(loaderId);
|
|
344
|
-
}
|
|
345
|
-
|
|
346
|
-
private cacheDisabledSettingChanged({data: enabled}: Common.EventTarget.EventTargetEvent<boolean>): void {
|
|
347
|
-
void this.#networkAgent.invoke_setCacheDisabled({cacheDisabled: enabled});
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
private cookieControlFlagsSettingChanged(): void {
|
|
351
|
-
const overridesEnabled =
|
|
352
|
-
Boolean(Common.Settings.Settings.instance().createSetting('cookie-control-override-enabled', undefined).get());
|
|
353
|
-
const gracePeriodEnabled = overridesEnabled ?
|
|
354
|
-
Boolean(
|
|
355
|
-
Common.Settings.Settings.instance().createSetting('grace-period-mitigation-disabled', undefined).get()) :
|
|
356
|
-
false;
|
|
357
|
-
const heuristicEnabled = overridesEnabled ?
|
|
358
|
-
Boolean(Common.Settings.Settings.instance().createSetting('heuristic-mitigation-disabled', undefined).get()) :
|
|
359
|
-
false;
|
|
360
|
-
void this.#networkAgent.invoke_setCookieControls({
|
|
361
|
-
enableThirdPartyCookieRestriction: overridesEnabled,
|
|
362
|
-
disableThirdPartyCookieMetadata: gracePeriodEnabled,
|
|
363
|
-
disableThirdPartyCookieHeuristics: heuristicEnabled,
|
|
364
|
-
});
|
|
365
|
-
}
|
|
366
|
-
|
|
367
|
-
override dispose(): void {
|
|
368
|
-
Common.Settings.Settings.instance()
|
|
369
|
-
.moduleSetting('cache-disabled')
|
|
370
|
-
.removeChangeListener(this.cacheDisabledSettingChanged, this);
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
private bypassServiceWorkerChanged(): void {
|
|
374
|
-
void this.#networkAgent.invoke_setBypassServiceWorker({bypass: this.#bypassServiceWorkerSetting.get()});
|
|
375
|
-
}
|
|
376
|
-
|
|
377
|
-
async getSecurityIsolationStatus(frameId: Protocol.Page.FrameId|null):
|
|
378
|
-
Promise<Protocol.Network.SecurityIsolationStatus|null> {
|
|
379
|
-
const result = await this.#networkAgent.invoke_getSecurityIsolationStatus({frameId: frameId ?? undefined});
|
|
380
|
-
if (result.getError()) {
|
|
381
|
-
return null;
|
|
382
|
-
}
|
|
383
|
-
return result.status;
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
async getIpProtectionProxyStatus(): Promise<Protocol.Network.IpProxyStatus|null> {
|
|
387
|
-
const result = await this.#networkAgent.invoke_getIPProtectionProxyStatus();
|
|
388
|
-
if (result.getError()) {
|
|
389
|
-
return null;
|
|
390
|
-
}
|
|
391
|
-
return result.status;
|
|
392
|
-
}
|
|
393
|
-
|
|
394
|
-
async enableReportingApi(enable = true): Promise<Promise<Protocol.ProtocolResponseWithError>> {
|
|
395
|
-
return await this.#networkAgent.invoke_enableReportingApi({enable});
|
|
396
|
-
}
|
|
397
|
-
|
|
398
|
-
async loadNetworkResource(
|
|
399
|
-
frameId: Protocol.Page.FrameId|null, url: Platform.DevToolsPath.UrlString,
|
|
400
|
-
options: Protocol.Network.LoadNetworkResourceOptions): Promise<Protocol.Network.LoadNetworkResourcePageResult> {
|
|
401
|
-
const result = await this.#networkAgent.invoke_loadNetworkResource({frameId: frameId ?? undefined, url, options});
|
|
402
|
-
if (result.getError()) {
|
|
403
|
-
throw new Error(result.getError());
|
|
404
|
-
}
|
|
405
|
-
return result.resource;
|
|
406
|
-
}
|
|
407
|
-
|
|
408
|
-
clearRequests(): void {
|
|
409
|
-
this.dispatcher.clearRequests();
|
|
410
|
-
}
|
|
411
|
-
}
|
|
412
|
-
|
|
413
|
-
export enum Events {
|
|
414
|
-
/* eslint-disable @typescript-eslint/naming-convention -- Used by web_tests. */
|
|
415
|
-
RequestStarted = 'RequestStarted',
|
|
416
|
-
RequestUpdated = 'RequestUpdated',
|
|
417
|
-
RequestFinished = 'RequestFinished',
|
|
418
|
-
RequestUpdateDropped = 'RequestUpdateDropped',
|
|
419
|
-
ResponseReceived = 'ResponseReceived',
|
|
420
|
-
MessageGenerated = 'MessageGenerated',
|
|
421
|
-
RequestRedirected = 'RequestRedirected',
|
|
422
|
-
LoadingFinished = 'LoadingFinished',
|
|
423
|
-
ReportingApiReportAdded = 'ReportingApiReportAdded',
|
|
424
|
-
ReportingApiReportUpdated = 'ReportingApiReportUpdated',
|
|
425
|
-
ReportingApiEndpointsChangedForOrigin = 'ReportingApiEndpointsChangedForOrigin',
|
|
426
|
-
/* eslint-enable @typescript-eslint/naming-convention */
|
|
427
|
-
}
|
|
428
|
-
|
|
429
|
-
export interface RequestStartedEvent {
|
|
430
|
-
request: NetworkRequest;
|
|
431
|
-
originalRequest: Protocol.Network.Request|null;
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
export interface ResponseReceivedEvent {
|
|
435
|
-
request: NetworkRequest;
|
|
436
|
-
response: Protocol.Network.Response;
|
|
437
|
-
}
|
|
438
|
-
|
|
439
|
-
export interface MessageGeneratedEvent {
|
|
440
|
-
message: Common.UIString.LocalizedString;
|
|
441
|
-
requestId: string;
|
|
442
|
-
warning: boolean;
|
|
443
|
-
}
|
|
444
|
-
|
|
445
|
-
export interface EventTypes {
|
|
446
|
-
[Events.RequestStarted]: RequestStartedEvent;
|
|
447
|
-
[Events.RequestUpdated]: NetworkRequest;
|
|
448
|
-
[Events.RequestFinished]: NetworkRequest;
|
|
449
|
-
[Events.RequestUpdateDropped]: RequestUpdateDroppedEventData;
|
|
450
|
-
[Events.ResponseReceived]: ResponseReceivedEvent;
|
|
451
|
-
[Events.MessageGenerated]: MessageGeneratedEvent;
|
|
452
|
-
[Events.RequestRedirected]: NetworkRequest;
|
|
453
|
-
[Events.LoadingFinished]: NetworkRequest;
|
|
454
|
-
[Events.ReportingApiReportAdded]: Protocol.Network.ReportingApiReport;
|
|
455
|
-
[Events.ReportingApiReportUpdated]: Protocol.Network.ReportingApiReport;
|
|
456
|
-
[Events.ReportingApiEndpointsChangedForOrigin]: Protocol.Network.ReportingApiEndpointsChangedForOriginEvent;
|
|
457
|
-
}
|
|
458
|
-
|
|
459
|
-
/**
|
|
460
|
-
* Define some built-in DevTools throttling presets.
|
|
461
|
-
* Note that for the download, upload and RTT values we multiply them by adjustment factors to make DevTools' emulation more accurate.
|
|
462
|
-
* @see https://docs.google.com/document/d/10lfVdS1iDWCRKQXPfbxEn4Or99D64mvNlugP1AQuFlE/edit for historical context.
|
|
463
|
-
* @see https://crbug.com/342406608#comment10 for context around the addition of 4G presets in June 2024.
|
|
464
|
-
*/
|
|
465
|
-
|
|
466
|
-
export const BlockingConditions: ThrottlingConditions = {
|
|
467
|
-
key: PredefinedThrottlingConditionKey.BLOCKING,
|
|
468
|
-
block: true,
|
|
469
|
-
title: i18nLazyString(UIStrings.block),
|
|
470
|
-
};
|
|
471
|
-
|
|
472
|
-
export const NoThrottlingConditions: Conditions = {
|
|
473
|
-
key: PredefinedThrottlingConditionKey.NO_THROTTLING,
|
|
474
|
-
title: i18nLazyString(UIStrings.noThrottling),
|
|
475
|
-
i18nTitleKey: UIStrings.noThrottling,
|
|
476
|
-
download: -1,
|
|
477
|
-
upload: -1,
|
|
478
|
-
latency: 0,
|
|
479
|
-
};
|
|
480
|
-
|
|
481
|
-
export const OfflineConditions: Conditions = {
|
|
482
|
-
key: PredefinedThrottlingConditionKey.OFFLINE,
|
|
483
|
-
title: i18nLazyString(UIStrings.offline),
|
|
484
|
-
i18nTitleKey: UIStrings.offline,
|
|
485
|
-
download: 0,
|
|
486
|
-
upload: 0,
|
|
487
|
-
latency: 0,
|
|
488
|
-
};
|
|
489
|
-
|
|
490
|
-
const slow3GTargetLatency = 400;
|
|
491
|
-
export const Slow3GConditions: Conditions = {
|
|
492
|
-
key: PredefinedThrottlingConditionKey.SPEED_3G,
|
|
493
|
-
title: i18nLazyString(UIStrings.slowG),
|
|
494
|
-
i18nTitleKey: UIStrings.slowG,
|
|
495
|
-
// ~500Kbps down
|
|
496
|
-
download: 500 * 1000 / 8 * .8,
|
|
497
|
-
// ~500Kbps up
|
|
498
|
-
upload: 500 * 1000 / 8 * .8,
|
|
499
|
-
// 400ms RTT
|
|
500
|
-
latency: slow3GTargetLatency * 5,
|
|
501
|
-
targetLatency: slow3GTargetLatency,
|
|
502
|
-
};
|
|
503
|
-
|
|
504
|
-
// Note for readers: this used to be called "Fast 3G" but it was renamed in May
|
|
505
|
-
// 2024 to align with LH (crbug.com/342406608).
|
|
506
|
-
const slow4GTargetLatency = 150;
|
|
507
|
-
export const Slow4GConditions: Conditions = {
|
|
508
|
-
key: PredefinedThrottlingConditionKey.SPEED_SLOW_4G,
|
|
509
|
-
title: i18nLazyString(UIStrings.fastG),
|
|
510
|
-
i18nTitleKey: UIStrings.fastG,
|
|
511
|
-
// ~1.6 Mbps down
|
|
512
|
-
download: 1.6 * 1000 * 1000 / 8 * .9,
|
|
513
|
-
// ~0.75 Mbps up
|
|
514
|
-
upload: 750 * 1000 / 8 * .9,
|
|
515
|
-
// 150ms RTT
|
|
516
|
-
latency: slow4GTargetLatency * 3.75,
|
|
517
|
-
targetLatency: slow4GTargetLatency,
|
|
518
|
-
};
|
|
519
|
-
|
|
520
|
-
const fast4GTargetLatency = 60;
|
|
521
|
-
export const Fast4GConditions: Conditions = {
|
|
522
|
-
key: PredefinedThrottlingConditionKey.SPEED_FAST_4G,
|
|
523
|
-
title: i18nLazyString(UIStrings.fast4G),
|
|
524
|
-
i18nTitleKey: UIStrings.fast4G,
|
|
525
|
-
// 9 Mbps down
|
|
526
|
-
download: 9 * 1000 * 1000 / 8 * .9,
|
|
527
|
-
// 1.5 Mbps up
|
|
528
|
-
upload: 1.5 * 1000 * 1000 / 8 * .9,
|
|
529
|
-
// 60ms RTT
|
|
530
|
-
latency: fast4GTargetLatency * 2.75,
|
|
531
|
-
targetLatency: fast4GTargetLatency,
|
|
532
|
-
};
|
|
533
|
-
|
|
534
|
-
const MAX_EAGER_POST_REQUEST_BODY_LENGTH = 64 * 1024; // bytes
|
|
535
|
-
const MAX_RESPONSE_BODY_TOTAL_BUFFER_LENGTH = 250 * 1024 * 1024; // bytes
|
|
536
|
-
|
|
537
|
-
export class FetchDispatcher implements ProtocolProxyApi.FetchDispatcher {
|
|
538
|
-
readonly #fetchAgent: ProtocolProxyApi.FetchApi;
|
|
539
|
-
readonly #manager: NetworkManager;
|
|
540
|
-
|
|
541
|
-
constructor(agent: ProtocolProxyApi.FetchApi, manager: NetworkManager) {
|
|
542
|
-
this.#fetchAgent = agent;
|
|
543
|
-
this.#manager = manager;
|
|
544
|
-
}
|
|
545
|
-
|
|
546
|
-
requestPaused({requestId, request, resourceType, responseStatusCode, responseHeaders, networkId}:
|
|
547
|
-
Protocol.Fetch.RequestPausedEvent): void {
|
|
548
|
-
const networkRequest = networkId ? this.#manager.requestForId(networkId) : null;
|
|
549
|
-
// If there was no 'Network.responseReceivedExtraInfo' event (e.g. for 'file:/' URLSs),
|
|
550
|
-
// populate 'originalResponseHeaders' with the headers from the 'Fetch.requestPaused' event.
|
|
551
|
-
if (networkRequest?.originalResponseHeaders.length === 0 && responseHeaders) {
|
|
552
|
-
networkRequest.originalResponseHeaders = responseHeaders;
|
|
553
|
-
}
|
|
554
|
-
void MultitargetNetworkManager.instance().requestIntercepted(new InterceptedRequest(
|
|
555
|
-
this.#fetchAgent, request, resourceType, requestId, networkRequest, responseStatusCode, responseHeaders));
|
|
556
|
-
}
|
|
557
|
-
|
|
558
|
-
authRequired({}: Protocol.Fetch.AuthRequiredEvent): void {
|
|
559
|
-
}
|
|
560
|
-
}
|
|
561
|
-
|
|
562
|
-
export class NetworkDispatcher implements ProtocolProxyApi.NetworkDispatcher {
|
|
563
|
-
readonly #manager: NetworkManager;
|
|
564
|
-
readonly #requestsById = new Map<string, NetworkRequest>();
|
|
565
|
-
readonly #requestsByURL = new Map<Platform.DevToolsPath.UrlString, NetworkRequest>();
|
|
566
|
-
readonly #requestsByLoaderId = new Map<Protocol.Network.LoaderId, NetworkRequest>();
|
|
567
|
-
readonly #requestIdToExtraInfoBuilder = new Map<string, ExtraInfoBuilder>();
|
|
568
|
-
/**
|
|
569
|
-
* In case of an early abort or a cache hit, the Trust Token done event is
|
|
570
|
-
* reported before the request itself is created in `requestWillBeSent`.
|
|
571
|
-
* This causes the event to be lost as no `NetworkRequest` instance has been
|
|
572
|
-
* created yet.
|
|
573
|
-
* This map caches the events temporarily and populates the NetworkRequest
|
|
574
|
-
* once it is created in `requestWillBeSent`.
|
|
575
|
-
*/
|
|
576
|
-
readonly #requestIdToTrustTokenEvent = new Map<string, Protocol.Network.TrustTokenOperationDoneEvent>();
|
|
577
|
-
|
|
578
|
-
constructor(manager: NetworkManager) {
|
|
579
|
-
this.#manager = manager;
|
|
580
|
-
|
|
581
|
-
MultitargetNetworkManager.instance().addEventListener(
|
|
582
|
-
MultitargetNetworkManager.Events.REQUEST_INTERCEPTED, this.#markAsIntercepted.bind(this));
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
#markAsIntercepted(event: Common.EventTarget.EventTargetEvent<string>): void {
|
|
586
|
-
const request = this.requestForId(event.data);
|
|
587
|
-
if (request) {
|
|
588
|
-
request.setWasIntercepted(true);
|
|
589
|
-
}
|
|
590
|
-
}
|
|
591
|
-
|
|
592
|
-
private headersMapToHeadersArray(headersMap: Protocol.Network.Headers): NameValue[] {
|
|
593
|
-
const result = [];
|
|
594
|
-
for (const name in headersMap) {
|
|
595
|
-
const values = headersMap[name].split('\n');
|
|
596
|
-
for (let i = 0; i < values.length; ++i) {
|
|
597
|
-
result.push({name, value: values[i]});
|
|
598
|
-
}
|
|
599
|
-
}
|
|
600
|
-
return result;
|
|
601
|
-
}
|
|
602
|
-
|
|
603
|
-
private updateNetworkRequestWithRequest(networkRequest: NetworkRequest, request: Protocol.Network.Request): void {
|
|
604
|
-
networkRequest.requestMethod = request.method;
|
|
605
|
-
networkRequest.setRequestHeaders(this.headersMapToHeadersArray(request.headers));
|
|
606
|
-
networkRequest.setRequestFormData(Boolean(request.hasPostData), request.postData || null);
|
|
607
|
-
networkRequest.setInitialPriority(request.initialPriority);
|
|
608
|
-
networkRequest.mixedContentType = request.mixedContentType || Protocol.Security.MixedContentType.None;
|
|
609
|
-
networkRequest.setReferrerPolicy(request.referrerPolicy);
|
|
610
|
-
networkRequest.setIsSameSite(request.isSameSite || false);
|
|
611
|
-
networkRequest.setIsAdRelated(request.isAdRelated || false);
|
|
612
|
-
}
|
|
613
|
-
|
|
614
|
-
private updateNetworkRequestWithResponse(networkRequest: NetworkRequest, response: Protocol.Network.Response): void {
|
|
615
|
-
if (response.url && networkRequest.url() !== response.url) {
|
|
616
|
-
networkRequest.setUrl(response.url as Platform.DevToolsPath.UrlString);
|
|
617
|
-
}
|
|
618
|
-
networkRequest.mimeType = response.mimeType;
|
|
619
|
-
networkRequest.setCharset(response.charset);
|
|
620
|
-
if (!networkRequest.statusCode || networkRequest.wasIntercepted()) {
|
|
621
|
-
networkRequest.statusCode = response.status;
|
|
622
|
-
}
|
|
623
|
-
if (!networkRequest.statusText || networkRequest.wasIntercepted()) {
|
|
624
|
-
networkRequest.statusText = response.statusText;
|
|
625
|
-
}
|
|
626
|
-
if (!networkRequest.hasExtraResponseInfo() || networkRequest.wasIntercepted()) {
|
|
627
|
-
networkRequest.responseHeaders = this.headersMapToHeadersArray(response.headers);
|
|
628
|
-
}
|
|
629
|
-
|
|
630
|
-
if (response.encodedDataLength >= 0) {
|
|
631
|
-
networkRequest.setTransferSize(response.encodedDataLength);
|
|
632
|
-
}
|
|
633
|
-
|
|
634
|
-
if (response.requestHeaders && !networkRequest.hasExtraRequestInfo()) {
|
|
635
|
-
// TODO(http://crbug.com/1004979): Stop using response.requestHeaders and
|
|
636
|
-
// response.requestHeadersText once shared workers
|
|
637
|
-
// emit Network.*ExtraInfo events for their network #requests.
|
|
638
|
-
networkRequest.setRequestHeaders(this.headersMapToHeadersArray(response.requestHeaders));
|
|
639
|
-
networkRequest.setRequestHeadersText(response.requestHeadersText || '');
|
|
640
|
-
}
|
|
641
|
-
|
|
642
|
-
networkRequest.connectionReused = response.connectionReused;
|
|
643
|
-
networkRequest.connectionId = String(response.connectionId);
|
|
644
|
-
if (response.remoteIPAddress) {
|
|
645
|
-
networkRequest.setRemoteAddress(response.remoteIPAddress, response.remotePort || -1);
|
|
646
|
-
}
|
|
647
|
-
|
|
648
|
-
if (response.fromServiceWorker) {
|
|
649
|
-
networkRequest.fetchedViaServiceWorker = true;
|
|
650
|
-
}
|
|
651
|
-
|
|
652
|
-
if (response.fromDiskCache) {
|
|
653
|
-
networkRequest.setFromDiskCache();
|
|
654
|
-
}
|
|
655
|
-
|
|
656
|
-
if (response.fromPrefetchCache) {
|
|
657
|
-
networkRequest.setFromPrefetchCache();
|
|
658
|
-
}
|
|
659
|
-
|
|
660
|
-
if (response.fromEarlyHints) {
|
|
661
|
-
networkRequest.setFromEarlyHints();
|
|
662
|
-
}
|
|
663
|
-
|
|
664
|
-
if (response.cacheStorageCacheName) {
|
|
665
|
-
networkRequest.setResponseCacheStorageCacheName(response.cacheStorageCacheName);
|
|
666
|
-
}
|
|
667
|
-
|
|
668
|
-
if (response.serviceWorkerRouterInfo) {
|
|
669
|
-
networkRequest.serviceWorkerRouterInfo = response.serviceWorkerRouterInfo;
|
|
670
|
-
}
|
|
671
|
-
|
|
672
|
-
if (response.responseTime) {
|
|
673
|
-
networkRequest.setResponseRetrievalTime(new Date(response.responseTime));
|
|
674
|
-
}
|
|
675
|
-
|
|
676
|
-
networkRequest.timing = response.timing;
|
|
677
|
-
|
|
678
|
-
networkRequest.protocol = response.protocol || '';
|
|
679
|
-
|
|
680
|
-
networkRequest.alternateProtocolUsage = response.alternateProtocolUsage;
|
|
681
|
-
|
|
682
|
-
if (response.serviceWorkerResponseSource) {
|
|
683
|
-
networkRequest.setServiceWorkerResponseSource(response.serviceWorkerResponseSource);
|
|
684
|
-
}
|
|
685
|
-
|
|
686
|
-
networkRequest.setSecurityState(response.securityState);
|
|
687
|
-
|
|
688
|
-
if (response.securityDetails) {
|
|
689
|
-
networkRequest.setSecurityDetails(response.securityDetails);
|
|
690
|
-
}
|
|
691
|
-
|
|
692
|
-
// TODO(crbug.com/425645896): Remove this guard once IP Protection is fully launched.
|
|
693
|
-
if (Root.Runtime.hostConfig.devToolsIpProtectionInDevTools?.enabled) {
|
|
694
|
-
if (response.isIpProtectionUsed) {
|
|
695
|
-
networkRequest.setIsIpProtectionUsed(response.isIpProtectionUsed);
|
|
696
|
-
}
|
|
697
|
-
}
|
|
698
|
-
|
|
699
|
-
const newResourceType = Common.ResourceType.ResourceType.fromMimeTypeOverride(networkRequest.mimeType);
|
|
700
|
-
if (newResourceType) {
|
|
701
|
-
networkRequest.setResourceType(newResourceType);
|
|
702
|
-
}
|
|
703
|
-
if (networkRequest.responseReceivedPromiseResolve) {
|
|
704
|
-
// Anyone interested in waiting for response headers being available?
|
|
705
|
-
networkRequest.responseReceivedPromiseResolve();
|
|
706
|
-
} else {
|
|
707
|
-
// If not, make sure no one will wait on it in the future.
|
|
708
|
-
networkRequest.responseReceivedPromise = Promise.resolve();
|
|
709
|
-
}
|
|
710
|
-
}
|
|
711
|
-
|
|
712
|
-
requestForId(id: string): NetworkRequest|null {
|
|
713
|
-
return this.#requestsById.get(id) || null;
|
|
714
|
-
}
|
|
715
|
-
|
|
716
|
-
requestForURL(url: Platform.DevToolsPath.UrlString): NetworkRequest|null {
|
|
717
|
-
return this.#requestsByURL.get(url) || null;
|
|
718
|
-
}
|
|
719
|
-
|
|
720
|
-
requestForLoaderId(loaderId: Protocol.Network.LoaderId): NetworkRequest|null {
|
|
721
|
-
return this.#requestsByLoaderId.get(loaderId) || null;
|
|
722
|
-
}
|
|
723
|
-
|
|
724
|
-
resourceChangedPriority({requestId, newPriority}: Protocol.Network.ResourceChangedPriorityEvent): void {
|
|
725
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
726
|
-
if (networkRequest) {
|
|
727
|
-
networkRequest.setPriority(newPriority);
|
|
728
|
-
}
|
|
729
|
-
}
|
|
730
|
-
|
|
731
|
-
signedExchangeReceived({requestId, info}: Protocol.Network.SignedExchangeReceivedEvent): void {
|
|
732
|
-
// While loading a signed exchange, a signedExchangeReceived event is sent
|
|
733
|
-
// between two requestWillBeSent events.
|
|
734
|
-
// 1. The first requestWillBeSent is sent while starting the navigation (or
|
|
735
|
-
// prefetching).
|
|
736
|
-
// 2. This signedExchangeReceived event is sent when the browser detects the
|
|
737
|
-
// signed exchange.
|
|
738
|
-
// 3. The second requestWillBeSent is sent with the generated redirect
|
|
739
|
-
// response and a new redirected request which URL is the inner request
|
|
740
|
-
// URL of the signed exchange.
|
|
741
|
-
let networkRequest = this.#requestsById.get(requestId);
|
|
742
|
-
// |requestId| is available only for navigation #requests. If the request was
|
|
743
|
-
// sent from a renderer process for prefetching, it is not available. In the
|
|
744
|
-
// case, need to fallback to look for the URL.
|
|
745
|
-
// TODO(crbug/841076): Sends the request ID of prefetching to the browser
|
|
746
|
-
// process and DevTools to find the matching request.
|
|
747
|
-
if (!networkRequest) {
|
|
748
|
-
networkRequest = this.#requestsByURL.get(info.outerResponse.url as Platform.DevToolsPath.UrlString);
|
|
749
|
-
if (!networkRequest) {
|
|
750
|
-
return;
|
|
751
|
-
}
|
|
752
|
-
// Or clause is never hit, but is here because we can't use non-null assertions.
|
|
753
|
-
const backendRequestId = networkRequest.backendRequestId() || requestId;
|
|
754
|
-
requestId = backendRequestId;
|
|
755
|
-
}
|
|
756
|
-
networkRequest.setSignedExchangeInfo(info);
|
|
757
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes.SignedExchange);
|
|
758
|
-
|
|
759
|
-
this.updateNetworkRequestWithResponse(networkRequest, info.outerResponse);
|
|
760
|
-
this.updateNetworkRequest(networkRequest);
|
|
761
|
-
this.getExtraInfoBuilder(requestId).addHasExtraInfo(info.hasExtraInfo);
|
|
762
|
-
|
|
763
|
-
this.#manager.dispatchEventToListeners(
|
|
764
|
-
Events.ResponseReceived, {request: networkRequest, response: info.outerResponse});
|
|
765
|
-
}
|
|
766
|
-
|
|
767
|
-
requestWillBeSent({
|
|
768
|
-
requestId,
|
|
769
|
-
loaderId,
|
|
770
|
-
documentURL,
|
|
771
|
-
request,
|
|
772
|
-
timestamp,
|
|
773
|
-
wallTime,
|
|
774
|
-
initiator,
|
|
775
|
-
redirectHasExtraInfo,
|
|
776
|
-
redirectResponse,
|
|
777
|
-
type,
|
|
778
|
-
frameId,
|
|
779
|
-
hasUserGesture,
|
|
780
|
-
}: Protocol.Network.RequestWillBeSentEvent): void {
|
|
781
|
-
let networkRequest = this.#requestsById.get(requestId);
|
|
782
|
-
if (networkRequest) {
|
|
783
|
-
// FIXME: move this check to the backend.
|
|
784
|
-
if (!redirectResponse) {
|
|
785
|
-
return;
|
|
786
|
-
}
|
|
787
|
-
// If signedExchangeReceived event has already been sent for the request,
|
|
788
|
-
// ignores the internally generated |redirectResponse|. The
|
|
789
|
-
// |outerResponse| of SignedExchangeInfo was set to |networkRequest| in
|
|
790
|
-
// signedExchangeReceived().
|
|
791
|
-
if (!networkRequest.signedExchangeInfo()) {
|
|
792
|
-
this.responseReceived({
|
|
793
|
-
requestId,
|
|
794
|
-
loaderId,
|
|
795
|
-
timestamp,
|
|
796
|
-
type: type || Protocol.Network.ResourceType.Other,
|
|
797
|
-
response: redirectResponse,
|
|
798
|
-
hasExtraInfo: redirectHasExtraInfo,
|
|
799
|
-
frameId,
|
|
800
|
-
});
|
|
801
|
-
}
|
|
802
|
-
networkRequest = this.appendRedirect(requestId, timestamp, request.url as Platform.DevToolsPath.UrlString);
|
|
803
|
-
this.#manager.dispatchEventToListeners(Events.RequestRedirected, networkRequest);
|
|
804
|
-
} else {
|
|
805
|
-
networkRequest = NetworkRequest.create(
|
|
806
|
-
requestId, request.url as Platform.DevToolsPath.UrlString, documentURL as Platform.DevToolsPath.UrlString,
|
|
807
|
-
frameId ?? null, loaderId, initiator, hasUserGesture);
|
|
808
|
-
requestToManagerMap.set(networkRequest, this.#manager);
|
|
809
|
-
}
|
|
810
|
-
networkRequest.hasNetworkData = true;
|
|
811
|
-
this.updateNetworkRequestWithRequest(networkRequest, request);
|
|
812
|
-
networkRequest.setIssueTime(timestamp, wallTime);
|
|
813
|
-
networkRequest.setResourceType(
|
|
814
|
-
type ? Common.ResourceType.resourceTypes[type] : Common.ResourceType.resourceTypes.Other);
|
|
815
|
-
if (request.trustTokenParams) {
|
|
816
|
-
networkRequest.setTrustTokenParams(request.trustTokenParams);
|
|
817
|
-
}
|
|
818
|
-
const maybeTrustTokenEvent = this.#requestIdToTrustTokenEvent.get(requestId);
|
|
819
|
-
if (maybeTrustTokenEvent) {
|
|
820
|
-
networkRequest.setTrustTokenOperationDoneEvent(maybeTrustTokenEvent);
|
|
821
|
-
this.#requestIdToTrustTokenEvent.delete(requestId);
|
|
822
|
-
}
|
|
823
|
-
|
|
824
|
-
this.getExtraInfoBuilder(requestId).addRequest(networkRequest);
|
|
825
|
-
|
|
826
|
-
this.startNetworkRequest(networkRequest, request);
|
|
827
|
-
}
|
|
828
|
-
|
|
829
|
-
requestServedFromCache({requestId}: Protocol.Network.RequestServedFromCacheEvent): void {
|
|
830
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
831
|
-
if (!networkRequest) {
|
|
832
|
-
return;
|
|
833
|
-
}
|
|
834
|
-
|
|
835
|
-
networkRequest.setFromMemoryCache();
|
|
836
|
-
}
|
|
837
|
-
|
|
838
|
-
responseReceived({requestId, loaderId, timestamp, type, response, hasExtraInfo, frameId}:
|
|
839
|
-
Protocol.Network.ResponseReceivedEvent): void {
|
|
840
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
841
|
-
const lowercaseHeaders = NetworkManager.lowercaseHeaders(response.headers);
|
|
842
|
-
if (!networkRequest) {
|
|
843
|
-
const lastModifiedHeader = lowercaseHeaders['last-modified'];
|
|
844
|
-
// We missed the requestWillBeSent.
|
|
845
|
-
const eventData: RequestUpdateDroppedEventData = {
|
|
846
|
-
url: response.url as Platform.DevToolsPath.UrlString,
|
|
847
|
-
frameId: frameId ?? null,
|
|
848
|
-
loaderId,
|
|
849
|
-
resourceType: type,
|
|
850
|
-
mimeType: response.mimeType,
|
|
851
|
-
lastModified: lastModifiedHeader ? new Date(lastModifiedHeader) : null,
|
|
852
|
-
};
|
|
853
|
-
this.#manager.dispatchEventToListeners(Events.RequestUpdateDropped, eventData);
|
|
854
|
-
return;
|
|
855
|
-
}
|
|
856
|
-
|
|
857
|
-
networkRequest.responseReceivedTime = timestamp;
|
|
858
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes[type]);
|
|
859
|
-
|
|
860
|
-
this.updateNetworkRequestWithResponse(networkRequest, response);
|
|
861
|
-
|
|
862
|
-
this.updateNetworkRequest(networkRequest);
|
|
863
|
-
this.getExtraInfoBuilder(requestId).addHasExtraInfo(hasExtraInfo);
|
|
864
|
-
this.#manager.dispatchEventToListeners(Events.ResponseReceived, {request: networkRequest, response});
|
|
865
|
-
}
|
|
866
|
-
|
|
867
|
-
dataReceived(event: Protocol.Network.DataReceivedEvent): void {
|
|
868
|
-
let networkRequest: NetworkRequest|null|undefined = this.#requestsById.get(event.requestId);
|
|
869
|
-
if (!networkRequest) {
|
|
870
|
-
networkRequest = this.maybeAdoptMainResourceRequest(event.requestId);
|
|
871
|
-
}
|
|
872
|
-
if (!networkRequest) {
|
|
873
|
-
return;
|
|
874
|
-
}
|
|
875
|
-
networkRequest.addDataReceivedEvent(event);
|
|
876
|
-
this.updateNetworkRequest(networkRequest);
|
|
877
|
-
}
|
|
878
|
-
|
|
879
|
-
loadingFinished({requestId, timestamp: finishTime, encodedDataLength}: Protocol.Network.LoadingFinishedEvent): void {
|
|
880
|
-
let networkRequest: NetworkRequest|null|undefined = this.#requestsById.get(requestId);
|
|
881
|
-
if (!networkRequest) {
|
|
882
|
-
networkRequest = this.maybeAdoptMainResourceRequest(requestId);
|
|
883
|
-
}
|
|
884
|
-
if (!networkRequest) {
|
|
885
|
-
return;
|
|
886
|
-
}
|
|
887
|
-
this.getExtraInfoBuilder(requestId).finished();
|
|
888
|
-
this.finishNetworkRequest(networkRequest, finishTime, encodedDataLength);
|
|
889
|
-
this.#manager.dispatchEventToListeners(Events.LoadingFinished, networkRequest);
|
|
890
|
-
}
|
|
891
|
-
|
|
892
|
-
loadingFailed({
|
|
893
|
-
requestId,
|
|
894
|
-
timestamp: time,
|
|
895
|
-
type: resourceType,
|
|
896
|
-
errorText: localizedDescription,
|
|
897
|
-
canceled,
|
|
898
|
-
blockedReason,
|
|
899
|
-
corsErrorStatus,
|
|
900
|
-
}: Protocol.Network.LoadingFailedEvent): void {
|
|
901
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
902
|
-
if (!networkRequest) {
|
|
903
|
-
return;
|
|
904
|
-
}
|
|
905
|
-
|
|
906
|
-
networkRequest.failed = true;
|
|
907
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes[resourceType]);
|
|
908
|
-
networkRequest.canceled = Boolean(canceled);
|
|
909
|
-
if (blockedReason) {
|
|
910
|
-
networkRequest.setBlockedReason(blockedReason);
|
|
911
|
-
if (blockedReason === Protocol.Network.BlockedReason.Inspector) {
|
|
912
|
-
const message = i18nString(UIStrings.requestWasBlockedByDevtoolsS, {PH1: networkRequest.url()});
|
|
913
|
-
this.#manager.dispatchEventToListeners(Events.MessageGenerated, {message, requestId, warning: true});
|
|
914
|
-
}
|
|
915
|
-
}
|
|
916
|
-
if (corsErrorStatus) {
|
|
917
|
-
networkRequest.setCorsErrorStatus(corsErrorStatus);
|
|
918
|
-
}
|
|
919
|
-
networkRequest.localizedFailDescription = localizedDescription;
|
|
920
|
-
this.getExtraInfoBuilder(requestId).finished();
|
|
921
|
-
this.finishNetworkRequest(networkRequest, time, -1);
|
|
922
|
-
}
|
|
923
|
-
|
|
924
|
-
webSocketCreated({requestId, url: requestURL, initiator}: Protocol.Network.WebSocketCreatedEvent): void {
|
|
925
|
-
const networkRequest =
|
|
926
|
-
NetworkRequest.createForSocket(requestId, requestURL as Platform.DevToolsPath.UrlString, initiator);
|
|
927
|
-
requestToManagerMap.set(networkRequest, this.#manager);
|
|
928
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes.WebSocket);
|
|
929
|
-
this.startNetworkRequest(networkRequest, null);
|
|
930
|
-
}
|
|
931
|
-
|
|
932
|
-
webSocketWillSendHandshakeRequest({requestId, timestamp: time, wallTime, request}:
|
|
933
|
-
Protocol.Network.WebSocketWillSendHandshakeRequestEvent): void {
|
|
934
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
935
|
-
if (!networkRequest) {
|
|
936
|
-
return;
|
|
937
|
-
}
|
|
938
|
-
|
|
939
|
-
networkRequest.requestMethod = 'GET';
|
|
940
|
-
networkRequest.setRequestHeaders(this.headersMapToHeadersArray(request.headers));
|
|
941
|
-
networkRequest.setIssueTime(time, wallTime);
|
|
942
|
-
|
|
943
|
-
this.updateNetworkRequest(networkRequest);
|
|
944
|
-
}
|
|
945
|
-
|
|
946
|
-
webSocketHandshakeResponseReceived({requestId, timestamp: time, response}:
|
|
947
|
-
Protocol.Network.WebSocketHandshakeResponseReceivedEvent): void {
|
|
948
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
949
|
-
if (!networkRequest) {
|
|
950
|
-
return;
|
|
951
|
-
}
|
|
952
|
-
|
|
953
|
-
networkRequest.statusCode = response.status;
|
|
954
|
-
networkRequest.statusText = response.statusText;
|
|
955
|
-
networkRequest.responseHeaders = this.headersMapToHeadersArray(response.headers);
|
|
956
|
-
networkRequest.responseHeadersText = response.headersText || '';
|
|
957
|
-
if (response.requestHeaders) {
|
|
958
|
-
networkRequest.setRequestHeaders(this.headersMapToHeadersArray(response.requestHeaders));
|
|
959
|
-
}
|
|
960
|
-
if (response.requestHeadersText) {
|
|
961
|
-
networkRequest.setRequestHeadersText(response.requestHeadersText);
|
|
962
|
-
}
|
|
963
|
-
networkRequest.responseReceivedTime = time;
|
|
964
|
-
networkRequest.protocol = 'websocket';
|
|
965
|
-
|
|
966
|
-
this.updateNetworkRequest(networkRequest);
|
|
967
|
-
}
|
|
968
|
-
|
|
969
|
-
webSocketFrameReceived({requestId, timestamp: time, response}: Protocol.Network.WebSocketFrameReceivedEvent): void {
|
|
970
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
971
|
-
if (!networkRequest) {
|
|
972
|
-
return;
|
|
973
|
-
}
|
|
974
|
-
|
|
975
|
-
networkRequest.addProtocolFrame(response, time, false);
|
|
976
|
-
networkRequest.responseReceivedTime = time;
|
|
977
|
-
|
|
978
|
-
this.updateNetworkRequest(networkRequest);
|
|
979
|
-
}
|
|
980
|
-
|
|
981
|
-
webSocketFrameSent({requestId, timestamp: time, response}: Protocol.Network.WebSocketFrameSentEvent): void {
|
|
982
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
983
|
-
if (!networkRequest) {
|
|
984
|
-
return;
|
|
985
|
-
}
|
|
986
|
-
|
|
987
|
-
networkRequest.addProtocolFrame(response, time, true);
|
|
988
|
-
networkRequest.responseReceivedTime = time;
|
|
989
|
-
|
|
990
|
-
this.updateNetworkRequest(networkRequest);
|
|
991
|
-
}
|
|
992
|
-
|
|
993
|
-
webSocketFrameError({requestId, timestamp: time, errorMessage}: Protocol.Network.WebSocketFrameErrorEvent): void {
|
|
994
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
995
|
-
if (!networkRequest) {
|
|
996
|
-
return;
|
|
997
|
-
}
|
|
998
|
-
|
|
999
|
-
networkRequest.addProtocolFrameError(errorMessage, time);
|
|
1000
|
-
networkRequest.responseReceivedTime = time;
|
|
1001
|
-
|
|
1002
|
-
this.updateNetworkRequest(networkRequest);
|
|
1003
|
-
}
|
|
1004
|
-
|
|
1005
|
-
webSocketClosed({requestId, timestamp: time}: Protocol.Network.WebSocketClosedEvent): void {
|
|
1006
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
1007
|
-
if (!networkRequest) {
|
|
1008
|
-
return;
|
|
1009
|
-
}
|
|
1010
|
-
this.finishNetworkRequest(networkRequest, time, -1);
|
|
1011
|
-
}
|
|
1012
|
-
|
|
1013
|
-
eventSourceMessageReceived({requestId, timestamp: time, eventName, eventId, data}:
|
|
1014
|
-
Protocol.Network.EventSourceMessageReceivedEvent): void {
|
|
1015
|
-
const networkRequest = this.#requestsById.get(requestId);
|
|
1016
|
-
if (!networkRequest) {
|
|
1017
|
-
return;
|
|
1018
|
-
}
|
|
1019
|
-
networkRequest.addEventSourceMessage(time, eventName, eventId, data);
|
|
1020
|
-
}
|
|
1021
|
-
|
|
1022
|
-
requestIntercepted({}: Protocol.Network.RequestInterceptedEvent): void {
|
|
1023
|
-
}
|
|
1024
|
-
|
|
1025
|
-
requestWillBeSentExtraInfo({
|
|
1026
|
-
requestId,
|
|
1027
|
-
associatedCookies,
|
|
1028
|
-
headers,
|
|
1029
|
-
clientSecurityState,
|
|
1030
|
-
connectTiming,
|
|
1031
|
-
siteHasCookieInOtherPartition,
|
|
1032
|
-
appliedNetworkConditionsId
|
|
1033
|
-
}: Protocol.Network.RequestWillBeSentExtraInfoEvent): void {
|
|
1034
|
-
const blockedRequestCookies: BlockedCookieWithReason[] = [];
|
|
1035
|
-
const includedRequestCookies: IncludedCookieWithReason[] = [];
|
|
1036
|
-
for (const {blockedReasons, exemptionReason, cookie} of associatedCookies) {
|
|
1037
|
-
if (blockedReasons.length === 0) {
|
|
1038
|
-
includedRequestCookies.push({exemptionReason, cookie: Cookie.fromProtocolCookie(cookie)});
|
|
1039
|
-
} else {
|
|
1040
|
-
blockedRequestCookies.push({blockedReasons, cookie: Cookie.fromProtocolCookie(cookie)});
|
|
1041
|
-
}
|
|
1042
|
-
}
|
|
1043
|
-
const extraRequestInfo = {
|
|
1044
|
-
blockedRequestCookies,
|
|
1045
|
-
includedRequestCookies,
|
|
1046
|
-
requestHeaders: this.headersMapToHeadersArray(headers),
|
|
1047
|
-
clientSecurityState,
|
|
1048
|
-
connectTiming,
|
|
1049
|
-
siteHasCookieInOtherPartition,
|
|
1050
|
-
appliedNetworkConditionsId,
|
|
1051
|
-
};
|
|
1052
|
-
this.getExtraInfoBuilder(requestId).addRequestExtraInfo(extraRequestInfo);
|
|
1053
|
-
}
|
|
1054
|
-
|
|
1055
|
-
responseReceivedEarlyHints({
|
|
1056
|
-
requestId,
|
|
1057
|
-
headers,
|
|
1058
|
-
}: Protocol.Network.ResponseReceivedEarlyHintsEvent): void {
|
|
1059
|
-
this.getExtraInfoBuilder(requestId).setEarlyHintsHeaders(this.headersMapToHeadersArray(headers));
|
|
1060
|
-
}
|
|
1061
|
-
|
|
1062
|
-
responseReceivedExtraInfo({
|
|
1063
|
-
requestId,
|
|
1064
|
-
blockedCookies,
|
|
1065
|
-
headers,
|
|
1066
|
-
headersText,
|
|
1067
|
-
resourceIPAddressSpace,
|
|
1068
|
-
statusCode,
|
|
1069
|
-
cookiePartitionKey,
|
|
1070
|
-
cookiePartitionKeyOpaque,
|
|
1071
|
-
exemptedCookies,
|
|
1072
|
-
}: Protocol.Network.ResponseReceivedExtraInfoEvent): void {
|
|
1073
|
-
const extraResponseInfo: ExtraResponseInfo = {
|
|
1074
|
-
blockedResponseCookies:
|
|
1075
|
-
blockedCookies.map(blockedCookie => ({
|
|
1076
|
-
blockedReasons: blockedCookie.blockedReasons,
|
|
1077
|
-
cookieLine: blockedCookie.cookieLine,
|
|
1078
|
-
cookie: blockedCookie.cookie ? Cookie.fromProtocolCookie(blockedCookie.cookie) : null,
|
|
1079
|
-
})),
|
|
1080
|
-
responseHeaders: this.headersMapToHeadersArray(headers),
|
|
1081
|
-
responseHeadersText: headersText,
|
|
1082
|
-
resourceIPAddressSpace,
|
|
1083
|
-
statusCode,
|
|
1084
|
-
cookiePartitionKey,
|
|
1085
|
-
cookiePartitionKeyOpaque,
|
|
1086
|
-
exemptedResponseCookies: exemptedCookies?.map(exemptedCookie => ({
|
|
1087
|
-
cookie: Cookie.fromProtocolCookie(exemptedCookie.cookie),
|
|
1088
|
-
cookieLine: exemptedCookie.cookieLine,
|
|
1089
|
-
exemptionReason: exemptedCookie.exemptionReason,
|
|
1090
|
-
})),
|
|
1091
|
-
};
|
|
1092
|
-
this.getExtraInfoBuilder(requestId).addResponseExtraInfo(extraResponseInfo);
|
|
1093
|
-
}
|
|
1094
|
-
|
|
1095
|
-
private getExtraInfoBuilder(requestId: string): ExtraInfoBuilder {
|
|
1096
|
-
let builder: ExtraInfoBuilder;
|
|
1097
|
-
if (!this.#requestIdToExtraInfoBuilder.has(requestId)) {
|
|
1098
|
-
builder = new ExtraInfoBuilder();
|
|
1099
|
-
this.#requestIdToExtraInfoBuilder.set(requestId, builder);
|
|
1100
|
-
} else {
|
|
1101
|
-
builder = (this.#requestIdToExtraInfoBuilder.get(requestId) as ExtraInfoBuilder);
|
|
1102
|
-
}
|
|
1103
|
-
return builder;
|
|
1104
|
-
}
|
|
1105
|
-
|
|
1106
|
-
private appendRedirect(
|
|
1107
|
-
requestId: Protocol.Network.RequestId, time: number,
|
|
1108
|
-
redirectURL: Platform.DevToolsPath.UrlString): NetworkRequest {
|
|
1109
|
-
const originalNetworkRequest = this.#requestsById.get(requestId);
|
|
1110
|
-
if (!originalNetworkRequest) {
|
|
1111
|
-
throw new Error(`Could not find original network request for ${requestId}`);
|
|
1112
|
-
}
|
|
1113
|
-
let redirectCount = 0;
|
|
1114
|
-
for (let redirect = originalNetworkRequest.redirectSource(); redirect; redirect = redirect.redirectSource()) {
|
|
1115
|
-
redirectCount++;
|
|
1116
|
-
}
|
|
1117
|
-
|
|
1118
|
-
originalNetworkRequest.markAsRedirect(redirectCount);
|
|
1119
|
-
this.finishNetworkRequest(originalNetworkRequest, time, -1);
|
|
1120
|
-
const newNetworkRequest = NetworkRequest.create(
|
|
1121
|
-
requestId, redirectURL, originalNetworkRequest.documentURL, originalNetworkRequest.frameId,
|
|
1122
|
-
originalNetworkRequest.loaderId, originalNetworkRequest.initiator(),
|
|
1123
|
-
originalNetworkRequest.hasUserGesture() ?? undefined);
|
|
1124
|
-
requestToManagerMap.set(newNetworkRequest, this.#manager);
|
|
1125
|
-
newNetworkRequest.setRedirectSource(originalNetworkRequest);
|
|
1126
|
-
originalNetworkRequest.setRedirectDestination(newNetworkRequest);
|
|
1127
|
-
return newNetworkRequest;
|
|
1128
|
-
}
|
|
1129
|
-
|
|
1130
|
-
private maybeAdoptMainResourceRequest(requestId: string): NetworkRequest|null {
|
|
1131
|
-
const request = MultitargetNetworkManager.instance().inflightMainResourceRequests.get(requestId);
|
|
1132
|
-
if (!request) {
|
|
1133
|
-
return null;
|
|
1134
|
-
}
|
|
1135
|
-
const oldDispatcher = (NetworkManager.forRequest(request) as NetworkManager).dispatcher;
|
|
1136
|
-
oldDispatcher.#requestsById.delete(requestId);
|
|
1137
|
-
oldDispatcher.#requestsByURL.delete(request.url());
|
|
1138
|
-
const loaderId = request.loaderId;
|
|
1139
|
-
if (loaderId) {
|
|
1140
|
-
oldDispatcher.#requestsByLoaderId.delete(loaderId);
|
|
1141
|
-
}
|
|
1142
|
-
const builder = oldDispatcher.#requestIdToExtraInfoBuilder.get(requestId);
|
|
1143
|
-
oldDispatcher.#requestIdToExtraInfoBuilder.delete(requestId);
|
|
1144
|
-
this.#requestsById.set(requestId, request);
|
|
1145
|
-
this.#requestsByURL.set(request.url(), request);
|
|
1146
|
-
if (loaderId) {
|
|
1147
|
-
this.#requestsByLoaderId.set(loaderId, request);
|
|
1148
|
-
}
|
|
1149
|
-
if (builder) {
|
|
1150
|
-
this.#requestIdToExtraInfoBuilder.set(requestId, builder);
|
|
1151
|
-
}
|
|
1152
|
-
requestToManagerMap.set(request, this.#manager);
|
|
1153
|
-
return request;
|
|
1154
|
-
}
|
|
1155
|
-
|
|
1156
|
-
private startNetworkRequest(networkRequest: NetworkRequest, originalRequest: Protocol.Network.Request|null): void {
|
|
1157
|
-
this.#requestsById.set(networkRequest.requestId(), networkRequest);
|
|
1158
|
-
this.#requestsByURL.set(networkRequest.url(), networkRequest);
|
|
1159
|
-
const loaderId = networkRequest.loaderId;
|
|
1160
|
-
if (loaderId) {
|
|
1161
|
-
this.#requestsByLoaderId.set(loaderId, networkRequest);
|
|
1162
|
-
}
|
|
1163
|
-
// The following relies on the fact that loaderIds and requestIds
|
|
1164
|
-
// are globally unique and that the main request has them equal. If
|
|
1165
|
-
// loaderId is an empty string, it indicates a worker request. For the
|
|
1166
|
-
// request to fetch the main worker script, the request ID is the future
|
|
1167
|
-
// worker target ID and, therefore, it is unique.
|
|
1168
|
-
if (networkRequest.loaderId === networkRequest.requestId() || networkRequest.loaderId === '') {
|
|
1169
|
-
MultitargetNetworkManager.instance().inflightMainResourceRequests.set(networkRequest.requestId(), networkRequest);
|
|
1170
|
-
}
|
|
1171
|
-
|
|
1172
|
-
this.#manager.dispatchEventToListeners(Events.RequestStarted, {request: networkRequest, originalRequest});
|
|
1173
|
-
}
|
|
1174
|
-
|
|
1175
|
-
private updateNetworkRequest(networkRequest: NetworkRequest): void {
|
|
1176
|
-
this.#manager.dispatchEventToListeners(Events.RequestUpdated, networkRequest);
|
|
1177
|
-
}
|
|
1178
|
-
|
|
1179
|
-
private finishNetworkRequest(
|
|
1180
|
-
networkRequest: NetworkRequest,
|
|
1181
|
-
finishTime: number,
|
|
1182
|
-
encodedDataLength: number,
|
|
1183
|
-
): void {
|
|
1184
|
-
networkRequest.endTime = finishTime;
|
|
1185
|
-
networkRequest.finished = true;
|
|
1186
|
-
if (encodedDataLength >= 0) {
|
|
1187
|
-
const redirectSource = networkRequest.redirectSource();
|
|
1188
|
-
if (redirectSource?.signedExchangeInfo()) {
|
|
1189
|
-
networkRequest.setTransferSize(0);
|
|
1190
|
-
redirectSource.setTransferSize(encodedDataLength);
|
|
1191
|
-
this.updateNetworkRequest(redirectSource);
|
|
1192
|
-
} else {
|
|
1193
|
-
networkRequest.setTransferSize(encodedDataLength);
|
|
1194
|
-
}
|
|
1195
|
-
}
|
|
1196
|
-
this.#manager.dispatchEventToListeners(Events.RequestFinished, networkRequest);
|
|
1197
|
-
MultitargetNetworkManager.instance().inflightMainResourceRequests.delete(networkRequest.requestId());
|
|
1198
|
-
|
|
1199
|
-
if (Common.Settings.Settings.instance().moduleSetting('monitoring-xhr-enabled').get() &&
|
|
1200
|
-
networkRequest.resourceType().category() === Common.ResourceType.resourceCategories.XHR) {
|
|
1201
|
-
let message;
|
|
1202
|
-
const failedToLoad = networkRequest.failed || networkRequest.hasErrorStatusCode();
|
|
1203
|
-
if (failedToLoad) {
|
|
1204
|
-
message = i18nString(
|
|
1205
|
-
UIStrings.sFailedLoadingSS,
|
|
1206
|
-
{PH1: networkRequest.resourceType().title(), PH2: networkRequest.requestMethod, PH3: networkRequest.url()});
|
|
1207
|
-
} else {
|
|
1208
|
-
message = i18nString(
|
|
1209
|
-
UIStrings.sFinishedLoadingSS,
|
|
1210
|
-
{PH1: networkRequest.resourceType().title(), PH2: networkRequest.requestMethod, PH3: networkRequest.url()});
|
|
1211
|
-
}
|
|
1212
|
-
|
|
1213
|
-
this.#manager.dispatchEventToListeners(
|
|
1214
|
-
Events.MessageGenerated, {message, requestId: networkRequest.requestId(), warning: false});
|
|
1215
|
-
}
|
|
1216
|
-
}
|
|
1217
|
-
|
|
1218
|
-
clearRequests(): void {
|
|
1219
|
-
for (const [requestId, request] of this.#requestsById) {
|
|
1220
|
-
if (request.finished) {
|
|
1221
|
-
this.#requestsById.delete(requestId);
|
|
1222
|
-
}
|
|
1223
|
-
}
|
|
1224
|
-
for (const [requestURL, request] of this.#requestsByURL) {
|
|
1225
|
-
if (request.finished) {
|
|
1226
|
-
this.#requestsByURL.delete(requestURL);
|
|
1227
|
-
}
|
|
1228
|
-
}
|
|
1229
|
-
for (const [requestLoaderId, request] of this.#requestsByLoaderId) {
|
|
1230
|
-
if (request.finished) {
|
|
1231
|
-
this.#requestsByLoaderId.delete(requestLoaderId);
|
|
1232
|
-
}
|
|
1233
|
-
}
|
|
1234
|
-
for (const [requestId, builder] of this.#requestIdToExtraInfoBuilder) {
|
|
1235
|
-
if (builder.isFinished()) {
|
|
1236
|
-
this.#requestIdToExtraInfoBuilder.delete(requestId);
|
|
1237
|
-
}
|
|
1238
|
-
}
|
|
1239
|
-
}
|
|
1240
|
-
|
|
1241
|
-
webTransportCreated({transportId, url: requestURL, timestamp: time, initiator}:
|
|
1242
|
-
Protocol.Network.WebTransportCreatedEvent): void {
|
|
1243
|
-
const networkRequest =
|
|
1244
|
-
NetworkRequest.createForSocket(transportId, requestURL as Platform.DevToolsPath.UrlString, initiator);
|
|
1245
|
-
networkRequest.hasNetworkData = true;
|
|
1246
|
-
requestToManagerMap.set(networkRequest, this.#manager);
|
|
1247
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes.WebTransport);
|
|
1248
|
-
networkRequest.setIssueTime(time, 0);
|
|
1249
|
-
// TODO(yoichio): Add appropreate events to address abort cases.
|
|
1250
|
-
this.startNetworkRequest(networkRequest, null);
|
|
1251
|
-
}
|
|
1252
|
-
|
|
1253
|
-
webTransportConnectionEstablished({transportId, timestamp: time}:
|
|
1254
|
-
Protocol.Network.WebTransportConnectionEstablishedEvent): void {
|
|
1255
|
-
const networkRequest = this.#requestsById.get(transportId);
|
|
1256
|
-
if (!networkRequest) {
|
|
1257
|
-
return;
|
|
1258
|
-
}
|
|
1259
|
-
|
|
1260
|
-
// This dummy deltas are needed to show this request as being
|
|
1261
|
-
// downloaded(blue) given typical WebTransport is kept for a while.
|
|
1262
|
-
// TODO(yoichio): Add appropreate events to fix these dummy datas.
|
|
1263
|
-
// DNS lookup?
|
|
1264
|
-
networkRequest.responseReceivedTime = time;
|
|
1265
|
-
networkRequest.endTime = time + 0.001;
|
|
1266
|
-
this.updateNetworkRequest(networkRequest);
|
|
1267
|
-
}
|
|
1268
|
-
|
|
1269
|
-
webTransportClosed({transportId, timestamp: time}: Protocol.Network.WebTransportClosedEvent): void {
|
|
1270
|
-
const networkRequest = this.#requestsById.get(transportId);
|
|
1271
|
-
if (!networkRequest) {
|
|
1272
|
-
return;
|
|
1273
|
-
}
|
|
1274
|
-
|
|
1275
|
-
networkRequest.endTime = time;
|
|
1276
|
-
this.finishNetworkRequest(networkRequest, time, 0);
|
|
1277
|
-
}
|
|
1278
|
-
|
|
1279
|
-
directTCPSocketCreated(event: Protocol.Network.DirectTCPSocketCreatedEvent): void {
|
|
1280
|
-
const requestURL = this.concatHostPort(event.remoteAddr, event.remotePort);
|
|
1281
|
-
const networkRequest = NetworkRequest.createForSocket(
|
|
1282
|
-
event.identifier, requestURL as Platform.DevToolsPath.UrlString, event.initiator);
|
|
1283
|
-
networkRequest.hasNetworkData = true;
|
|
1284
|
-
networkRequest.setRemoteAddress(event.remoteAddr, event.remotePort);
|
|
1285
|
-
networkRequest.protocol = i18n.i18n.lockedString('tcp');
|
|
1286
|
-
|
|
1287
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusOpening);
|
|
1288
|
-
networkRequest.directSocketInfo = {
|
|
1289
|
-
type: DirectSocketType.TCP,
|
|
1290
|
-
status: DirectSocketStatus.OPENING,
|
|
1291
|
-
createOptions: {
|
|
1292
|
-
remoteAddr: event.remoteAddr,
|
|
1293
|
-
remotePort: event.remotePort,
|
|
1294
|
-
noDelay: event.options.noDelay,
|
|
1295
|
-
keepAliveDelay: event.options.keepAliveDelay,
|
|
1296
|
-
sendBufferSize: event.options.sendBufferSize,
|
|
1297
|
-
receiveBufferSize: event.options.receiveBufferSize,
|
|
1298
|
-
dnsQueryType: event.options.dnsQueryType,
|
|
1299
|
-
}
|
|
1300
|
-
};
|
|
1301
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes.DirectSocket);
|
|
1302
|
-
networkRequest.setIssueTime(event.timestamp, event.timestamp);
|
|
1303
|
-
|
|
1304
|
-
requestToManagerMap.set(networkRequest, this.#manager);
|
|
1305
|
-
this.startNetworkRequest(networkRequest, null);
|
|
1306
|
-
}
|
|
1307
|
-
|
|
1308
|
-
directTCPSocketOpened(event: Protocol.Network.DirectTCPSocketOpenedEvent): void {
|
|
1309
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1310
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1311
|
-
return;
|
|
1312
|
-
}
|
|
1313
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1314
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.OPEN;
|
|
1315
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusOpen);
|
|
1316
|
-
networkRequest.directSocketInfo.openInfo = {
|
|
1317
|
-
remoteAddr: event.remoteAddr,
|
|
1318
|
-
remotePort: event.remotePort,
|
|
1319
|
-
localAddr: event.localAddr,
|
|
1320
|
-
localPort: event.localPort,
|
|
1321
|
-
};
|
|
1322
|
-
networkRequest.setRemoteAddress(event.remoteAddr, event.remotePort);
|
|
1323
|
-
const requestURL = this.concatHostPort(event.remoteAddr, event.remotePort);
|
|
1324
|
-
networkRequest.setUrl(requestURL as Platform.DevToolsPath.UrlString);
|
|
1325
|
-
this.updateNetworkRequest(networkRequest);
|
|
1326
|
-
}
|
|
1327
|
-
|
|
1328
|
-
directTCPSocketAborted(event: Protocol.Network.DirectTCPSocketAbortedEvent): void {
|
|
1329
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1330
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1331
|
-
return;
|
|
1332
|
-
}
|
|
1333
|
-
networkRequest.failed = true;
|
|
1334
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.ABORTED;
|
|
1335
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusAborted);
|
|
1336
|
-
networkRequest.directSocketInfo.errorMessage = event.errorMessage;
|
|
1337
|
-
this.finishNetworkRequest(networkRequest, event.timestamp, 0);
|
|
1338
|
-
}
|
|
1339
|
-
|
|
1340
|
-
directTCPSocketClosed(event: Protocol.Network.DirectTCPSocketClosedEvent): void {
|
|
1341
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1342
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1343
|
-
return;
|
|
1344
|
-
}
|
|
1345
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusClosed);
|
|
1346
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.CLOSED;
|
|
1347
|
-
this.finishNetworkRequest(networkRequest, event.timestamp, 0);
|
|
1348
|
-
}
|
|
1349
|
-
|
|
1350
|
-
directTCPSocketChunkSent(event: Protocol.Network.DirectTCPSocketChunkSentEvent): void {
|
|
1351
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1352
|
-
if (!networkRequest) {
|
|
1353
|
-
return;
|
|
1354
|
-
}
|
|
1355
|
-
|
|
1356
|
-
networkRequest.addDirectSocketChunk({
|
|
1357
|
-
data: event.data,
|
|
1358
|
-
type: DirectSocketChunkType.SEND,
|
|
1359
|
-
timestamp: event.timestamp,
|
|
1360
|
-
});
|
|
1361
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1362
|
-
|
|
1363
|
-
this.updateNetworkRequest(networkRequest);
|
|
1364
|
-
}
|
|
1365
|
-
|
|
1366
|
-
directTCPSocketChunkReceived(event: Protocol.Network.DirectTCPSocketChunkReceivedEvent): void {
|
|
1367
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1368
|
-
if (!networkRequest) {
|
|
1369
|
-
return;
|
|
1370
|
-
}
|
|
1371
|
-
|
|
1372
|
-
networkRequest.addDirectSocketChunk({
|
|
1373
|
-
data: event.data,
|
|
1374
|
-
type: DirectSocketChunkType.RECEIVE,
|
|
1375
|
-
timestamp: event.timestamp,
|
|
1376
|
-
});
|
|
1377
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1378
|
-
|
|
1379
|
-
this.updateNetworkRequest(networkRequest);
|
|
1380
|
-
}
|
|
1381
|
-
|
|
1382
|
-
directUDPSocketCreated(event: Protocol.Network.DirectUDPSocketCreatedEvent): void {
|
|
1383
|
-
let requestURL = '';
|
|
1384
|
-
let type: DirectSocketType;
|
|
1385
|
-
if (event.options.remoteAddr && event.options.remotePort) {
|
|
1386
|
-
requestURL = this.concatHostPort(event.options.remoteAddr, event.options.remotePort);
|
|
1387
|
-
type = DirectSocketType.UDP_CONNECTED;
|
|
1388
|
-
} else if (event.options.localAddr) {
|
|
1389
|
-
requestURL = this.concatHostPort(event.options.localAddr, event.options.localPort);
|
|
1390
|
-
type = DirectSocketType.UDP_BOUND;
|
|
1391
|
-
} else {
|
|
1392
|
-
// Must be present in a valid command if remoteAddr
|
|
1393
|
-
// is not specified.
|
|
1394
|
-
return;
|
|
1395
|
-
}
|
|
1396
|
-
const networkRequest = NetworkRequest.createForSocket(
|
|
1397
|
-
event.identifier, requestURL as Platform.DevToolsPath.UrlString, event.initiator);
|
|
1398
|
-
networkRequest.hasNetworkData = true;
|
|
1399
|
-
if (event.options.remoteAddr && event.options.remotePort) {
|
|
1400
|
-
networkRequest.setRemoteAddress(event.options.remoteAddr, event.options.remotePort);
|
|
1401
|
-
}
|
|
1402
|
-
networkRequest.protocol = i18n.i18n.lockedString('udp');
|
|
1403
|
-
|
|
1404
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusOpening);
|
|
1405
|
-
networkRequest.directSocketInfo = {
|
|
1406
|
-
type,
|
|
1407
|
-
status: DirectSocketStatus.OPENING,
|
|
1408
|
-
createOptions: {
|
|
1409
|
-
remoteAddr: event.options.remoteAddr,
|
|
1410
|
-
remotePort: event.options.remotePort,
|
|
1411
|
-
localAddr: event.options.localAddr,
|
|
1412
|
-
localPort: event.options.localPort,
|
|
1413
|
-
sendBufferSize: event.options.sendBufferSize,
|
|
1414
|
-
receiveBufferSize: event.options.receiveBufferSize,
|
|
1415
|
-
dnsQueryType: event.options.dnsQueryType,
|
|
1416
|
-
}
|
|
1417
|
-
};
|
|
1418
|
-
networkRequest.setResourceType(Common.ResourceType.resourceTypes.DirectSocket);
|
|
1419
|
-
networkRequest.setIssueTime(event.timestamp, event.timestamp);
|
|
1420
|
-
|
|
1421
|
-
requestToManagerMap.set(networkRequest, this.#manager);
|
|
1422
|
-
this.startNetworkRequest(networkRequest, null);
|
|
1423
|
-
}
|
|
1424
|
-
|
|
1425
|
-
directUDPSocketOpened(event: Protocol.Network.DirectUDPSocketOpenedEvent): void {
|
|
1426
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1427
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1428
|
-
return;
|
|
1429
|
-
}
|
|
1430
|
-
let requestURL: string;
|
|
1431
|
-
if (networkRequest.directSocketInfo.type === DirectSocketType.UDP_CONNECTED) {
|
|
1432
|
-
if (!event.remoteAddr || !event.remotePort) {
|
|
1433
|
-
// Connected socket must have remoteAdd and remotePort.
|
|
1434
|
-
return;
|
|
1435
|
-
}
|
|
1436
|
-
networkRequest.setRemoteAddress(event.remoteAddr, event.remotePort);
|
|
1437
|
-
requestURL = this.concatHostPort(event.remoteAddr, event.remotePort);
|
|
1438
|
-
} else {
|
|
1439
|
-
requestURL = this.concatHostPort(event.localAddr, event.localPort);
|
|
1440
|
-
}
|
|
1441
|
-
|
|
1442
|
-
networkRequest.setUrl(requestURL as Platform.DevToolsPath.UrlString);
|
|
1443
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1444
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.OPEN;
|
|
1445
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusOpen);
|
|
1446
|
-
networkRequest.directSocketInfo.openInfo = {
|
|
1447
|
-
remoteAddr: event.remoteAddr,
|
|
1448
|
-
remotePort: event.remotePort,
|
|
1449
|
-
localAddr: event.localAddr,
|
|
1450
|
-
localPort: event.localPort,
|
|
1451
|
-
};
|
|
1452
|
-
|
|
1453
|
-
this.updateNetworkRequest(networkRequest);
|
|
1454
|
-
}
|
|
1455
|
-
|
|
1456
|
-
directUDPSocketAborted(event: Protocol.Network.DirectUDPSocketAbortedEvent): void {
|
|
1457
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1458
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1459
|
-
return;
|
|
1460
|
-
}
|
|
1461
|
-
networkRequest.failed = true;
|
|
1462
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.ABORTED;
|
|
1463
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusAborted);
|
|
1464
|
-
networkRequest.directSocketInfo.errorMessage = event.errorMessage;
|
|
1465
|
-
this.finishNetworkRequest(networkRequest, event.timestamp, 0);
|
|
1466
|
-
}
|
|
1467
|
-
|
|
1468
|
-
directUDPSocketClosed(event: Protocol.Network.DirectUDPSocketClosedEvent): void {
|
|
1469
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1470
|
-
if (!networkRequest?.directSocketInfo) {
|
|
1471
|
-
return;
|
|
1472
|
-
}
|
|
1473
|
-
networkRequest.statusText = i18nString(UIStrings.directSocketStatusClosed);
|
|
1474
|
-
networkRequest.directSocketInfo.status = DirectSocketStatus.CLOSED;
|
|
1475
|
-
this.finishNetworkRequest(networkRequest, event.timestamp, 0);
|
|
1476
|
-
}
|
|
1477
|
-
|
|
1478
|
-
directUDPSocketChunkSent(event: Protocol.Network.DirectUDPSocketChunkSentEvent): void {
|
|
1479
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1480
|
-
if (!networkRequest) {
|
|
1481
|
-
return;
|
|
1482
|
-
}
|
|
1483
|
-
|
|
1484
|
-
networkRequest.addDirectSocketChunk({
|
|
1485
|
-
data: event.message.data,
|
|
1486
|
-
type: DirectSocketChunkType.SEND,
|
|
1487
|
-
timestamp: event.timestamp,
|
|
1488
|
-
remoteAddress: event.message.remoteAddr,
|
|
1489
|
-
remotePort: event.message.remotePort
|
|
1490
|
-
});
|
|
1491
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1492
|
-
|
|
1493
|
-
this.updateNetworkRequest(networkRequest);
|
|
1494
|
-
}
|
|
1495
|
-
|
|
1496
|
-
directUDPSocketChunkReceived(event: Protocol.Network.DirectUDPSocketChunkReceivedEvent): void {
|
|
1497
|
-
const networkRequest = this.#requestsById.get(event.identifier);
|
|
1498
|
-
if (!networkRequest) {
|
|
1499
|
-
return;
|
|
1500
|
-
}
|
|
1501
|
-
|
|
1502
|
-
networkRequest.addDirectSocketChunk({
|
|
1503
|
-
data: event.message.data,
|
|
1504
|
-
type: DirectSocketChunkType.RECEIVE,
|
|
1505
|
-
timestamp: event.timestamp,
|
|
1506
|
-
remoteAddress: event.message.remoteAddr,
|
|
1507
|
-
remotePort: event.message.remotePort
|
|
1508
|
-
});
|
|
1509
|
-
networkRequest.responseReceivedTime = event.timestamp;
|
|
1510
|
-
|
|
1511
|
-
this.updateNetworkRequest(networkRequest);
|
|
1512
|
-
}
|
|
1513
|
-
|
|
1514
|
-
trustTokenOperationDone(event: Protocol.Network.TrustTokenOperationDoneEvent): void {
|
|
1515
|
-
const request = this.#requestsById.get(event.requestId);
|
|
1516
|
-
if (!request) {
|
|
1517
|
-
this.#requestIdToTrustTokenEvent.set(event.requestId, event);
|
|
1518
|
-
return;
|
|
1519
|
-
}
|
|
1520
|
-
request.setTrustTokenOperationDoneEvent(event);
|
|
1521
|
-
}
|
|
1522
|
-
|
|
1523
|
-
subresourceWebBundleMetadataReceived(): void {
|
|
1524
|
-
// TODO: remove implementation after deleting this methods from definition in Network.pdl
|
|
1525
|
-
}
|
|
1526
|
-
|
|
1527
|
-
subresourceWebBundleMetadataError(): void {
|
|
1528
|
-
// TODO: remove implementation after deleting this methods from definition in Network.pdl
|
|
1529
|
-
}
|
|
1530
|
-
|
|
1531
|
-
subresourceWebBundleInnerResponseParsed(): void {
|
|
1532
|
-
// TODO: remove implementation after deleting this methods from definition in Network.pdl
|
|
1533
|
-
}
|
|
1534
|
-
|
|
1535
|
-
subresourceWebBundleInnerResponseError(): void {
|
|
1536
|
-
// TODO: remove implementation after deleting this methods from definition in Network.pdl
|
|
1537
|
-
}
|
|
1538
|
-
|
|
1539
|
-
reportingApiReportAdded(data: Protocol.Network.ReportingApiReportAddedEvent): void {
|
|
1540
|
-
this.#manager.dispatchEventToListeners(Events.ReportingApiReportAdded, data.report);
|
|
1541
|
-
}
|
|
1542
|
-
|
|
1543
|
-
reportingApiReportUpdated(data: Protocol.Network.ReportingApiReportUpdatedEvent): void {
|
|
1544
|
-
this.#manager.dispatchEventToListeners(Events.ReportingApiReportUpdated, data.report);
|
|
1545
|
-
}
|
|
1546
|
-
|
|
1547
|
-
reportingApiEndpointsChangedForOrigin(data: Protocol.Network.ReportingApiEndpointsChangedForOriginEvent): void {
|
|
1548
|
-
this.#manager.dispatchEventToListeners(Events.ReportingApiEndpointsChangedForOrigin, data);
|
|
1549
|
-
}
|
|
1550
|
-
|
|
1551
|
-
policyUpdated(): void {
|
|
1552
|
-
}
|
|
1553
|
-
|
|
1554
|
-
/**
|
|
1555
|
-
* @deprecated
|
|
1556
|
-
* This method is only kept for usage in a web test.
|
|
1557
|
-
*/
|
|
1558
|
-
protected createNetworkRequest(
|
|
1559
|
-
requestId: Protocol.Network.RequestId, frameId: Protocol.Page.FrameId, loaderId: Protocol.Network.LoaderId,
|
|
1560
|
-
url: string, documentURL: string, initiator: Protocol.Network.Initiator|null): NetworkRequest {
|
|
1561
|
-
const request = NetworkRequest.create(
|
|
1562
|
-
requestId, url as Platform.DevToolsPath.UrlString, documentURL as Platform.DevToolsPath.UrlString, frameId,
|
|
1563
|
-
loaderId, initiator);
|
|
1564
|
-
requestToManagerMap.set(request, this.#manager);
|
|
1565
|
-
return request;
|
|
1566
|
-
}
|
|
1567
|
-
|
|
1568
|
-
private concatHostPort(host: string, port?: number): string {
|
|
1569
|
-
if (!port || port === 0) {
|
|
1570
|
-
return host;
|
|
1571
|
-
}
|
|
1572
|
-
return `${host}:${port}`;
|
|
1573
|
-
}
|
|
1574
|
-
}
|
|
1575
|
-
|
|
1576
|
-
export type RequestConditionsSetting = {
|
|
1577
|
-
url: string,
|
|
1578
|
-
enabled: boolean,
|
|
1579
|
-
}|{
|
|
1580
|
-
urlPattern: URLPatternConstructorString,
|
|
1581
|
-
conditions: ThrottlingConditionKey,
|
|
1582
|
-
enabled: boolean,
|
|
1583
|
-
};
|
|
1584
|
-
|
|
1585
|
-
export type URLPatternConstructorString = Platform.Brand.Brand<string, 'URLPatternConstructorString'>;
|
|
1586
|
-
|
|
1587
|
-
export const enum RequestURLPatternValidity {
|
|
1588
|
-
VALID = 'valid',
|
|
1589
|
-
FAILED_TO_PARSE = 'failed-to-parse',
|
|
1590
|
-
HAS_REGEXP_GROUPS = 'has-regexp-groups',
|
|
1591
|
-
}
|
|
1592
|
-
|
|
1593
|
-
export class RequestURLPattern {
|
|
1594
|
-
private constructor(readonly constructorString: URLPatternConstructorString, readonly pattern: URLPattern) {
|
|
1595
|
-
if (pattern.hasRegExpGroups) {
|
|
1596
|
-
throw new Error('RegExp groups are not allowed');
|
|
1597
|
-
}
|
|
1598
|
-
}
|
|
1599
|
-
|
|
1600
|
-
static isValidPattern(pattern: string): RequestURLPatternValidity {
|
|
1601
|
-
try {
|
|
1602
|
-
const urlPattern = new URLPattern(pattern);
|
|
1603
|
-
return urlPattern.hasRegExpGroups ? RequestURLPatternValidity.HAS_REGEXP_GROUPS : RequestURLPatternValidity.VALID;
|
|
1604
|
-
} catch {
|
|
1605
|
-
return RequestURLPatternValidity.FAILED_TO_PARSE;
|
|
1606
|
-
}
|
|
1607
|
-
}
|
|
1608
|
-
|
|
1609
|
-
static create(constructorString: URLPatternConstructorString): RequestURLPattern|null {
|
|
1610
|
-
try {
|
|
1611
|
-
const urlPattern = new URLPattern(constructorString);
|
|
1612
|
-
return urlPattern.hasRegExpGroups ? null : new RequestURLPattern(constructorString, urlPattern);
|
|
1613
|
-
} catch {
|
|
1614
|
-
return null;
|
|
1615
|
-
}
|
|
1616
|
-
}
|
|
1617
|
-
|
|
1618
|
-
static upgradeFromWildcard(pattern: string): RequestURLPattern|null {
|
|
1619
|
-
const tryCreate = (constructorString: string): RequestURLPattern|null => {
|
|
1620
|
-
const result = this.create(constructorString as URLPatternConstructorString);
|
|
1621
|
-
if (result?.pattern.protocol === 'localhost' && result?.pattern.hostname === '') {
|
|
1622
|
-
// localhost:1234 parses as a valid pattern, do the right thing here instead
|
|
1623
|
-
return tryCreate(`*://${constructorString}`);
|
|
1624
|
-
}
|
|
1625
|
-
return result;
|
|
1626
|
-
};
|
|
1627
|
-
|
|
1628
|
-
return tryCreate(pattern) // try as is
|
|
1629
|
-
??
|
|
1630
|
-
// Try to upgrade patterns created from the network panel, which either blocks the full url (sans
|
|
1631
|
-
// protocol) or just the domain name. In both cases the wildcard patterns had implicit wildcards at the end.
|
|
1632
|
-
// We explicitly add that here, which will match both domain names without path (implicitly setting pathname
|
|
1633
|
-
// to '*') and urls with path (appending * to the pathname).
|
|
1634
|
-
tryCreate(`*://${pattern}*`);
|
|
1635
|
-
}
|
|
1636
|
-
}
|
|
1637
|
-
|
|
1638
|
-
export class RequestCondition extends Common.ObjectWrapper.ObjectWrapper<RequestCondition.EventTypes> {
|
|
1639
|
-
#pattern: RequestURLPattern|{wildcardURL: string, upgradedPattern?: RequestURLPattern};
|
|
1640
|
-
#enabled: boolean;
|
|
1641
|
-
#conditions: ThrottlingConditions;
|
|
1642
|
-
#ruleIds = new Set<string>();
|
|
1643
|
-
|
|
1644
|
-
static createFromSetting(setting: RequestConditionsSetting): RequestCondition {
|
|
1645
|
-
if ('urlPattern' in setting) {
|
|
1646
|
-
const pattern = RequestURLPattern.create(setting.urlPattern) ?? {
|
|
1647
|
-
wildcardURL: setting.urlPattern,
|
|
1648
|
-
upgradedPattern: RequestURLPattern.upgradeFromWildcard(setting.urlPattern) ?? undefined,
|
|
1649
|
-
};
|
|
1650
|
-
|
|
1651
|
-
const conditions = getPredefinedOrBlockingCondition(setting.conditions) ??
|
|
1652
|
-
customUserNetworkConditionsSetting().get().find(condition => condition.key === setting.conditions) ??
|
|
1653
|
-
NoThrottlingConditions;
|
|
1654
|
-
|
|
1655
|
-
return new this(pattern, setting.enabled, conditions);
|
|
1656
|
-
}
|
|
1657
|
-
|
|
1658
|
-
const pattern = {
|
|
1659
|
-
wildcardURL: setting.url,
|
|
1660
|
-
upgradedPattern: RequestURLPattern.upgradeFromWildcard(setting.url) ?? undefined
|
|
1661
|
-
};
|
|
1662
|
-
return new this(pattern, setting.enabled, BlockingConditions);
|
|
1663
|
-
}
|
|
1664
|
-
|
|
1665
|
-
static create(pattern: RequestURLPattern, conditions: ThrottlingConditions): RequestCondition {
|
|
1666
|
-
return new this(pattern, /* enabled=*/ true, conditions);
|
|
1667
|
-
}
|
|
1668
|
-
|
|
1669
|
-
private constructor(
|
|
1670
|
-
pattern: RequestURLPattern|{wildcardURL: string, upgradedPattern?: RequestURLPattern}, enabled: boolean,
|
|
1671
|
-
conditions: ThrottlingConditions) {
|
|
1672
|
-
super();
|
|
1673
|
-
this.#pattern = pattern;
|
|
1674
|
-
this.#enabled = enabled;
|
|
1675
|
-
this.#conditions = conditions;
|
|
1676
|
-
}
|
|
1677
|
-
|
|
1678
|
-
get isBlocking(): boolean {
|
|
1679
|
-
return this.conditions === BlockingConditions;
|
|
1680
|
-
}
|
|
1681
|
-
|
|
1682
|
-
get ruleIds(): Set<string> {
|
|
1683
|
-
return this.#ruleIds;
|
|
1684
|
-
}
|
|
1685
|
-
|
|
1686
|
-
get constructorString(): string|undefined {
|
|
1687
|
-
return this.#pattern instanceof RequestURLPattern ? this.#pattern.constructorString :
|
|
1688
|
-
this.#pattern.upgradedPattern?.constructorString;
|
|
1689
|
-
}
|
|
1690
|
-
|
|
1691
|
-
get wildcardURL(): string|undefined {
|
|
1692
|
-
return 'wildcardURL' in this.#pattern ? this.#pattern.wildcardURL : undefined;
|
|
1693
|
-
}
|
|
1694
|
-
|
|
1695
|
-
get constructorStringOrWildcardURL(): string {
|
|
1696
|
-
return this.#pattern instanceof RequestURLPattern ?
|
|
1697
|
-
this.#pattern.constructorString :
|
|
1698
|
-
(this.#pattern.upgradedPattern?.constructorString ?? this.#pattern.wildcardURL);
|
|
1699
|
-
}
|
|
1700
|
-
|
|
1701
|
-
set pattern(pattern: RequestURLPattern|string) {
|
|
1702
|
-
if (typeof pattern === 'string') {
|
|
1703
|
-
// TODO(pfaffe) Remove once the feature flag is no longer required
|
|
1704
|
-
if (Root.Runtime.hostConfig.devToolsIndividualRequestThrottling?.enabled) {
|
|
1705
|
-
throw new Error('Should not use wildcard urls');
|
|
1706
|
-
}
|
|
1707
|
-
this.#pattern = {
|
|
1708
|
-
wildcardURL: pattern,
|
|
1709
|
-
upgradedPattern: RequestURLPattern.upgradeFromWildcard(pattern) ?? undefined
|
|
1710
|
-
};
|
|
1711
|
-
} else {
|
|
1712
|
-
this.#pattern = pattern;
|
|
1713
|
-
}
|
|
1714
|
-
this.dispatchEventToListeners(RequestCondition.Events.REQUEST_CONDITION_CHANGED);
|
|
1715
|
-
}
|
|
1716
|
-
|
|
1717
|
-
get enabled(): boolean {
|
|
1718
|
-
return this.#enabled;
|
|
1719
|
-
}
|
|
1720
|
-
|
|
1721
|
-
set enabled(enabled: boolean) {
|
|
1722
|
-
this.#enabled = enabled;
|
|
1723
|
-
this.dispatchEventToListeners(RequestCondition.Events.REQUEST_CONDITION_CHANGED);
|
|
1724
|
-
}
|
|
1725
|
-
|
|
1726
|
-
get conditions(): ThrottlingConditions {
|
|
1727
|
-
return this.#conditions;
|
|
1728
|
-
}
|
|
1729
|
-
|
|
1730
|
-
set conditions(conditions: ThrottlingConditions) {
|
|
1731
|
-
this.#conditions = conditions;
|
|
1732
|
-
this.#ruleIds = new Set();
|
|
1733
|
-
this.dispatchEventToListeners(RequestCondition.Events.REQUEST_CONDITION_CHANGED);
|
|
1734
|
-
}
|
|
1735
|
-
|
|
1736
|
-
toSetting(): RequestConditionsSetting {
|
|
1737
|
-
const enabled = this.enabled;
|
|
1738
|
-
if (this.#pattern instanceof RequestURLPattern) {
|
|
1739
|
-
return {enabled, urlPattern: this.#pattern.constructorString, conditions: this.#conditions.key};
|
|
1740
|
-
}
|
|
1741
|
-
if (this.#conditions !== BlockingConditions && this.#pattern.upgradedPattern) {
|
|
1742
|
-
return {enabled, urlPattern: this.#pattern.upgradedPattern.constructorString, conditions: this.#conditions.key};
|
|
1743
|
-
}
|
|
1744
|
-
return {enabled, url: this.#pattern.wildcardURL};
|
|
1745
|
-
}
|
|
1746
|
-
|
|
1747
|
-
get originalOrUpgradedURLPattern(): URLPattern|undefined {
|
|
1748
|
-
return this.#pattern instanceof RequestURLPattern ? this.#pattern.pattern : this.#pattern.upgradedPattern?.pattern;
|
|
1749
|
-
}
|
|
1750
|
-
}
|
|
1751
|
-
|
|
1752
|
-
export namespace RequestCondition {
|
|
1753
|
-
export const enum Events {
|
|
1754
|
-
REQUEST_CONDITION_CHANGED = 'request-condition-changed',
|
|
1755
|
-
}
|
|
1756
|
-
|
|
1757
|
-
export interface EventTypes {
|
|
1758
|
-
[Events.REQUEST_CONDITION_CHANGED]: void;
|
|
1759
|
-
}
|
|
1760
|
-
}
|
|
1761
|
-
|
|
1762
|
-
export class RequestConditions extends Common.ObjectWrapper.ObjectWrapper<RequestConditions.EventTypes> {
|
|
1763
|
-
readonly #setting =
|
|
1764
|
-
Common.Settings.Settings.instance().createSetting<RequestConditionsSetting[]>('network-blocked-patterns', []);
|
|
1765
|
-
readonly #conditionsEnabledSetting =
|
|
1766
|
-
Common.Settings.Settings.instance().moduleSetting<boolean>('request-blocking-enabled');
|
|
1767
|
-
readonly #conditions: RequestCondition[] = [];
|
|
1768
|
-
readonly #requestConditionsById = new Map<string, {
|
|
1769
|
-
conditions: Conditions,
|
|
1770
|
-
urlPattern?: string,
|
|
1771
|
-
}>();
|
|
1772
|
-
#conditionsAppliedForTestPromise: Promise<unknown> = Promise.resolve();
|
|
1773
|
-
|
|
1774
|
-
constructor() {
|
|
1775
|
-
super();
|
|
1776
|
-
for (const condition of this.#setting.get()) {
|
|
1777
|
-
try {
|
|
1778
|
-
this.#conditions.push(RequestCondition.createFromSetting(condition));
|
|
1779
|
-
} catch (e) {
|
|
1780
|
-
console.error('Error loading throttling settings: ', e);
|
|
1781
|
-
}
|
|
1782
|
-
}
|
|
1783
|
-
for (const condition of this.#conditions) {
|
|
1784
|
-
condition.addEventListener(RequestCondition.Events.REQUEST_CONDITION_CHANGED, this.#conditionsChanged, this);
|
|
1785
|
-
}
|
|
1786
|
-
this.#conditionsEnabledSetting.addChangeListener(
|
|
1787
|
-
() => this.dispatchEventToListeners(RequestConditions.Events.REQUEST_CONDITIONS_CHANGED));
|
|
1788
|
-
}
|
|
1789
|
-
|
|
1790
|
-
get count(): number {
|
|
1791
|
-
return this.#conditions.length;
|
|
1792
|
-
}
|
|
1793
|
-
|
|
1794
|
-
get conditionsEnabled(): boolean {
|
|
1795
|
-
return this.#conditionsEnabledSetting.get();
|
|
1796
|
-
}
|
|
1797
|
-
|
|
1798
|
-
set conditionsEnabled(enabled: boolean) {
|
|
1799
|
-
if (this.#conditionsEnabledSetting.get() === enabled) {
|
|
1800
|
-
return;
|
|
1801
|
-
}
|
|
1802
|
-
this.#conditionsEnabledSetting.set(enabled);
|
|
1803
|
-
}
|
|
1804
|
-
|
|
1805
|
-
findCondition(pattern: string): RequestCondition|undefined {
|
|
1806
|
-
if (Root.Runtime.hostConfig.devToolsIndividualRequestThrottling?.enabled) {
|
|
1807
|
-
return this.#conditions.find(condition => condition.constructorString === pattern);
|
|
1808
|
-
}
|
|
1809
|
-
return this.#conditions.find(condition => condition.wildcardURL === pattern);
|
|
1810
|
-
}
|
|
1811
|
-
|
|
1812
|
-
has(url: string): boolean {
|
|
1813
|
-
return Boolean(this.findCondition(url));
|
|
1814
|
-
}
|
|
1815
|
-
|
|
1816
|
-
add(...conditions: RequestCondition[]): void {
|
|
1817
|
-
this.#conditions.push(...conditions);
|
|
1818
|
-
for (const condition of conditions) {
|
|
1819
|
-
condition.addEventListener(RequestCondition.Events.REQUEST_CONDITION_CHANGED, this.#conditionsChanged, this);
|
|
1820
|
-
}
|
|
1821
|
-
this.#conditionsChanged();
|
|
1822
|
-
}
|
|
1823
|
-
|
|
1824
|
-
decreasePriority(condition: RequestCondition): void {
|
|
1825
|
-
const index = this.#conditions.indexOf(condition);
|
|
1826
|
-
if (index < 0 || index >= this.#conditions.length - 1) {
|
|
1827
|
-
return;
|
|
1828
|
-
}
|
|
1829
|
-
|
|
1830
|
-
Platform.ArrayUtilities.swap(this.#conditions, index, index + 1);
|
|
1831
|
-
this.dispatchEventToListeners(RequestConditions.Events.REQUEST_CONDITIONS_CHANGED);
|
|
1832
|
-
}
|
|
1833
|
-
|
|
1834
|
-
increasePriority(condition: RequestCondition): void {
|
|
1835
|
-
const index = this.#conditions.indexOf(condition);
|
|
1836
|
-
if (index <= 0) {
|
|
1837
|
-
return;
|
|
1838
|
-
}
|
|
1839
|
-
|
|
1840
|
-
Platform.ArrayUtilities.swap(this.#conditions, index - 1, index);
|
|
1841
|
-
this.dispatchEventToListeners(RequestConditions.Events.REQUEST_CONDITIONS_CHANGED);
|
|
1842
|
-
}
|
|
1843
|
-
|
|
1844
|
-
delete(condition: RequestCondition): void {
|
|
1845
|
-
const index = this.#conditions.indexOf(condition);
|
|
1846
|
-
if (index < 0) {
|
|
1847
|
-
return;
|
|
1848
|
-
}
|
|
1849
|
-
condition.removeEventListener(RequestCondition.Events.REQUEST_CONDITION_CHANGED, this.#conditionsChanged, this);
|
|
1850
|
-
this.#conditions.splice(index, 1);
|
|
1851
|
-
this.#conditionsChanged();
|
|
1852
|
-
}
|
|
1853
|
-
|
|
1854
|
-
clear(): void {
|
|
1855
|
-
this.#conditions.splice(0);
|
|
1856
|
-
this.#conditionsChanged();
|
|
1857
|
-
for (const condition of this.#conditions) {
|
|
1858
|
-
condition.removeEventListener(RequestCondition.Events.REQUEST_CONDITION_CHANGED, this.#conditionsChanged, this);
|
|
1859
|
-
}
|
|
1860
|
-
}
|
|
1861
|
-
|
|
1862
|
-
#conditionsChanged(): void {
|
|
1863
|
-
this.#setting.set(this.#conditions.map(condition => condition.toSetting()));
|
|
1864
|
-
this.dispatchEventToListeners(RequestConditions.Events.REQUEST_CONDITIONS_CHANGED);
|
|
1865
|
-
}
|
|
1866
|
-
|
|
1867
|
-
get conditions(): IteratorObject<RequestCondition> {
|
|
1868
|
-
return this.#conditions.values();
|
|
1869
|
-
}
|
|
1870
|
-
|
|
1871
|
-
applyConditions(offline: boolean, globalConditions: Conditions|null, ...agents: ProtocolProxyApi.NetworkApi[]):
|
|
1872
|
-
boolean {
|
|
1873
|
-
function isNonBlockingCondition(condition: ThrottlingConditions): condition is Conditions {
|
|
1874
|
-
return !('block' in condition);
|
|
1875
|
-
}
|
|
1876
|
-
if (Root.Runtime.hostConfig.devToolsIndividualRequestThrottling?.enabled) {
|
|
1877
|
-
const urlPatterns: Protocol.Network.BlockPattern[] = [];
|
|
1878
|
-
// We store all this info out-of-band to prevent races with changing conditions while the promise is still pending
|
|
1879
|
-
const matchedNetworkConditions: Array<{conditions: Conditions, ruleIds?: Set<string>, urlPattern?: string}> = [];
|
|
1880
|
-
if (this.conditionsEnabled) {
|
|
1881
|
-
for (const condition of this.#conditions) {
|
|
1882
|
-
const urlPattern = condition.constructorString;
|
|
1883
|
-
const conditions = condition.conditions;
|
|
1884
|
-
if (!condition.enabled || !urlPattern || conditions === NoThrottlingConditions) {
|
|
1885
|
-
continue;
|
|
1886
|
-
}
|
|
1887
|
-
const block = !isNonBlockingCondition(conditions);
|
|
1888
|
-
urlPatterns.push({urlPattern, block});
|
|
1889
|
-
if (!block) {
|
|
1890
|
-
const {ruleIds} = condition;
|
|
1891
|
-
matchedNetworkConditions.push({ruleIds, urlPattern, conditions});
|
|
1892
|
-
}
|
|
1893
|
-
}
|
|
1894
|
-
|
|
1895
|
-
if (globalConditions) {
|
|
1896
|
-
matchedNetworkConditions.push({conditions: globalConditions});
|
|
1897
|
-
}
|
|
1898
|
-
}
|
|
1899
|
-
|
|
1900
|
-
const promises: Array<Promise<unknown>> = [];
|
|
1901
|
-
|
|
1902
|
-
for (const agent of agents) {
|
|
1903
|
-
promises.push(agent.invoke_setBlockedURLs({urlPatterns}));
|
|
1904
|
-
promises.push(agent
|
|
1905
|
-
.invoke_emulateNetworkConditionsByRule({
|
|
1906
|
-
offline,
|
|
1907
|
-
matchedNetworkConditions: matchedNetworkConditions.map(
|
|
1908
|
-
({urlPattern, conditions}) => ({
|
|
1909
|
-
urlPattern: urlPattern ?? '',
|
|
1910
|
-
latency: conditions.latency,
|
|
1911
|
-
downloadThroughput: conditions.download < 0 ? 0 : conditions.download,
|
|
1912
|
-
uploadThroughput: conditions.upload < 0 ? 0 : conditions.upload,
|
|
1913
|
-
packetLoss: (conditions.packetLoss ?? 0) < 0 ? 0 : conditions.packetLoss,
|
|
1914
|
-
packetQueueLength: conditions.packetQueueLength,
|
|
1915
|
-
packetReordering: conditions.packetReordering,
|
|
1916
|
-
connectionType: NetworkManager.connectionType(conditions),
|
|
1917
|
-
}))
|
|
1918
|
-
})
|
|
1919
|
-
.then(response => {
|
|
1920
|
-
if (!response.getError()) {
|
|
1921
|
-
for (let i = 0; i < response.ruleIds.length; ++i) {
|
|
1922
|
-
const ruleId = response.ruleIds[i];
|
|
1923
|
-
const {ruleIds, conditions, urlPattern} = matchedNetworkConditions[i];
|
|
1924
|
-
if (ruleIds) {
|
|
1925
|
-
this.#requestConditionsById.set(ruleId, {urlPattern, conditions});
|
|
1926
|
-
matchedNetworkConditions[i].ruleIds?.add(ruleId);
|
|
1927
|
-
}
|
|
1928
|
-
}
|
|
1929
|
-
}
|
|
1930
|
-
}));
|
|
1931
|
-
promises.push(agent.invoke_overrideNetworkState({
|
|
1932
|
-
offline,
|
|
1933
|
-
latency: globalConditions?.latency ?? 0,
|
|
1934
|
-
downloadThroughput: !globalConditions || globalConditions.download < 0 ? 0 : globalConditions.download,
|
|
1935
|
-
uploadThroughput: !globalConditions || globalConditions.upload < 0 ? 0 : globalConditions.upload,
|
|
1936
|
-
}));
|
|
1937
|
-
}
|
|
1938
|
-
|
|
1939
|
-
this.#conditionsAppliedForTestPromise = this.#conditionsAppliedForTestPromise.then(() => Promise.all(promises));
|
|
1940
|
-
return urlPatterns.length > 0;
|
|
1941
|
-
}
|
|
1942
|
-
|
|
1943
|
-
const urls = this.conditionsEnabled ?
|
|
1944
|
-
this.#conditions.filter(condition => condition.enabled && condition.wildcardURL)
|
|
1945
|
-
.map(condition => condition.wildcardURL as string) :
|
|
1946
|
-
[];
|
|
1947
|
-
|
|
1948
|
-
for (const agent of agents) {
|
|
1949
|
-
void agent.invoke_setBlockedURLs({urls});
|
|
1950
|
-
}
|
|
1951
|
-
return urls.length > 0;
|
|
1952
|
-
}
|
|
1953
|
-
|
|
1954
|
-
conditionsAppliedForTest(): Promise<unknown> {
|
|
1955
|
-
return this.#conditionsAppliedForTestPromise;
|
|
1956
|
-
}
|
|
1957
|
-
|
|
1958
|
-
conditionsForId(appliedNetworkConditionsId: string): {
|
|
1959
|
-
conditions: Conditions,
|
|
1960
|
-
urlPattern?: string,
|
|
1961
|
-
}|undefined {
|
|
1962
|
-
return this.#requestConditionsById.get(appliedNetworkConditionsId);
|
|
1963
|
-
}
|
|
1964
|
-
}
|
|
1965
|
-
|
|
1966
|
-
export namespace RequestConditions {
|
|
1967
|
-
export const enum Events {
|
|
1968
|
-
REQUEST_CONDITIONS_CHANGED = 'request-conditions-changed',
|
|
1969
|
-
}
|
|
1970
|
-
export interface EventTypes {
|
|
1971
|
-
[Events.REQUEST_CONDITIONS_CHANGED]: void;
|
|
1972
|
-
}
|
|
1973
|
-
}
|
|
1974
|
-
|
|
1975
|
-
let multiTargetNetworkManagerInstance: MultitargetNetworkManager|null;
|
|
1976
|
-
|
|
1977
|
-
export class MultitargetNetworkManager extends Common.ObjectWrapper.ObjectWrapper<MultitargetNetworkManager.EventTypes>
|
|
1978
|
-
implements SDKModelObserver<NetworkManager> {
|
|
1979
|
-
#userAgentOverride = '';
|
|
1980
|
-
#userAgentMetadataOverride: Protocol.Emulation.UserAgentMetadata|null = null;
|
|
1981
|
-
#customAcceptedEncodings: Protocol.Network.ContentEncoding[]|null = null;
|
|
1982
|
-
readonly #networkAgents = new Set<ProtocolProxyApi.NetworkApi>();
|
|
1983
|
-
readonly #fetchAgents = new Set<ProtocolProxyApi.FetchApi>();
|
|
1984
|
-
readonly inflightMainResourceRequests = new Map<string, NetworkRequest>();
|
|
1985
|
-
#networkConditions: Conditions = NoThrottlingConditions;
|
|
1986
|
-
#updatingInterceptionPatternsPromise: Promise<void>|null = null;
|
|
1987
|
-
readonly #requestConditions = new RequestConditions();
|
|
1988
|
-
readonly #urlsForRequestInterceptor:
|
|
1989
|
-
Platform.MapUtilities.Multimap<(arg0: InterceptedRequest) => Promise<void>, InterceptionPattern> =
|
|
1990
|
-
new Platform.MapUtilities.Multimap();
|
|
1991
|
-
#extraHeaders?: Protocol.Network.Headers;
|
|
1992
|
-
#customUserAgent?: string;
|
|
1993
|
-
#isBlocking = false;
|
|
1994
|
-
|
|
1995
|
-
constructor() {
|
|
1996
|
-
super();
|
|
1997
|
-
|
|
1998
|
-
// TODO(allada) Remove these and merge it with request interception.
|
|
1999
|
-
const blockedPatternChanged: () => void = () => {
|
|
2000
|
-
this.updateBlockedPatterns();
|
|
2001
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.BLOCKED_PATTERNS_CHANGED);
|
|
2002
|
-
};
|
|
2003
|
-
this.#requestConditions.addEventListener(
|
|
2004
|
-
RequestConditions.Events.REQUEST_CONDITIONS_CHANGED, blockedPatternChanged);
|
|
2005
|
-
this.updateBlockedPatterns();
|
|
2006
|
-
|
|
2007
|
-
TargetManager.instance().observeModels(NetworkManager, this);
|
|
2008
|
-
}
|
|
2009
|
-
|
|
2010
|
-
static instance(opts: {
|
|
2011
|
-
forceNew: boolean|null,
|
|
2012
|
-
} = {forceNew: null}): MultitargetNetworkManager {
|
|
2013
|
-
const {forceNew} = opts;
|
|
2014
|
-
if (!multiTargetNetworkManagerInstance || forceNew) {
|
|
2015
|
-
multiTargetNetworkManagerInstance = new MultitargetNetworkManager();
|
|
2016
|
-
}
|
|
2017
|
-
|
|
2018
|
-
return multiTargetNetworkManagerInstance;
|
|
2019
|
-
}
|
|
2020
|
-
|
|
2021
|
-
static dispose(): void {
|
|
2022
|
-
multiTargetNetworkManagerInstance = null;
|
|
2023
|
-
}
|
|
2024
|
-
|
|
2025
|
-
static patchUserAgentWithChromeVersion(uaString: string): string {
|
|
2026
|
-
// Patches Chrome/ChrOS version from user #agent ("1.2.3.4" when user #agent is: "Chrome/1.2.3.4").
|
|
2027
|
-
// Otherwise, ignore it. This assumes additional appVersions appear after the Chrome version.
|
|
2028
|
-
const chromeVersion = Root.Runtime.getChromeVersion();
|
|
2029
|
-
if (chromeVersion.length > 0) {
|
|
2030
|
-
// "1.2.3.4" becomes "1.0.100.0"
|
|
2031
|
-
const additionalAppVersion = chromeVersion.split('.', 1)[0] + '.0.100.0';
|
|
2032
|
-
return Platform.StringUtilities.sprintf(uaString, chromeVersion, additionalAppVersion);
|
|
2033
|
-
}
|
|
2034
|
-
return uaString;
|
|
2035
|
-
}
|
|
2036
|
-
|
|
2037
|
-
static patchUserAgentMetadataWithChromeVersion(userAgentMetadata: Protocol.Emulation.UserAgentMetadata): void {
|
|
2038
|
-
// Patches Chrome/ChrOS version from user #agent metadata ("1.2.3.4" when user #agent is: "Chrome/1.2.3.4").
|
|
2039
|
-
// Otherwise, ignore it. This assumes additional appVersions appear after the Chrome version.
|
|
2040
|
-
if (!userAgentMetadata.brands) {
|
|
2041
|
-
return;
|
|
2042
|
-
}
|
|
2043
|
-
const chromeVersion = Root.Runtime.getChromeVersion();
|
|
2044
|
-
if (chromeVersion.length === 0) {
|
|
2045
|
-
return;
|
|
2046
|
-
}
|
|
2047
|
-
|
|
2048
|
-
const majorVersion = chromeVersion.split('.', 1)[0];
|
|
2049
|
-
for (const brand of userAgentMetadata.brands) {
|
|
2050
|
-
if (brand.version.includes('%s')) {
|
|
2051
|
-
brand.version = Platform.StringUtilities.sprintf(brand.version, majorVersion);
|
|
2052
|
-
}
|
|
2053
|
-
}
|
|
2054
|
-
|
|
2055
|
-
if (userAgentMetadata.fullVersion) {
|
|
2056
|
-
if (userAgentMetadata.fullVersion.includes('%s')) {
|
|
2057
|
-
userAgentMetadata.fullVersion = Platform.StringUtilities.sprintf(userAgentMetadata.fullVersion, chromeVersion);
|
|
2058
|
-
}
|
|
2059
|
-
}
|
|
2060
|
-
}
|
|
2061
|
-
|
|
2062
|
-
modelAdded(networkManager: NetworkManager): void {
|
|
2063
|
-
const networkAgent = networkManager.target().networkAgent();
|
|
2064
|
-
const fetchAgent = networkManager.target().fetchAgent();
|
|
2065
|
-
if (this.#extraHeaders) {
|
|
2066
|
-
void networkAgent.invoke_setExtraHTTPHeaders({headers: this.#extraHeaders});
|
|
2067
|
-
}
|
|
2068
|
-
if (this.currentUserAgent()) {
|
|
2069
|
-
void networkAgent.invoke_setUserAgentOverride(
|
|
2070
|
-
{userAgent: this.currentUserAgent(), userAgentMetadata: this.#userAgentMetadataOverride || undefined});
|
|
2071
|
-
}
|
|
2072
|
-
this.#requestConditions.applyConditions(
|
|
2073
|
-
this.isOffline(), this.isThrottling() ? this.#networkConditions : null, networkAgent);
|
|
2074
|
-
if (this.isIntercepting()) {
|
|
2075
|
-
void fetchAgent.invoke_enable({patterns: this.#urlsForRequestInterceptor.valuesArray()});
|
|
2076
|
-
}
|
|
2077
|
-
if (this.#customAcceptedEncodings === null) {
|
|
2078
|
-
void networkAgent.invoke_clearAcceptedEncodingsOverride();
|
|
2079
|
-
} else {
|
|
2080
|
-
void networkAgent.invoke_setAcceptedEncodings({encodings: this.#customAcceptedEncodings});
|
|
2081
|
-
}
|
|
2082
|
-
this.#networkAgents.add(networkAgent);
|
|
2083
|
-
this.#fetchAgents.add(fetchAgent);
|
|
2084
|
-
if (this.isThrottling() && !Root.Runtime.hostConfig.devToolsIndividualRequestThrottling?.enabled) {
|
|
2085
|
-
this.updateNetworkConditions(networkAgent);
|
|
2086
|
-
}
|
|
2087
|
-
}
|
|
2088
|
-
|
|
2089
|
-
modelRemoved(networkManager: NetworkManager): void {
|
|
2090
|
-
for (const entry of this.inflightMainResourceRequests) {
|
|
2091
|
-
const manager = NetworkManager.forRequest((entry[1]));
|
|
2092
|
-
if (manager !== networkManager) {
|
|
2093
|
-
continue;
|
|
2094
|
-
}
|
|
2095
|
-
this.inflightMainResourceRequests.delete((entry[0]));
|
|
2096
|
-
}
|
|
2097
|
-
this.#networkAgents.delete(networkManager.target().networkAgent());
|
|
2098
|
-
this.#fetchAgents.delete(networkManager.target().fetchAgent());
|
|
2099
|
-
}
|
|
2100
|
-
|
|
2101
|
-
isThrottling(): boolean {
|
|
2102
|
-
return this.#networkConditions.download >= 0 || this.#networkConditions.upload >= 0 ||
|
|
2103
|
-
this.#networkConditions.latency > 0;
|
|
2104
|
-
}
|
|
2105
|
-
|
|
2106
|
-
isOffline(): boolean {
|
|
2107
|
-
return !this.#networkConditions.download && !this.#networkConditions.upload;
|
|
2108
|
-
}
|
|
2109
|
-
|
|
2110
|
-
setNetworkConditions(conditions: Conditions): void {
|
|
2111
|
-
this.#networkConditions = conditions;
|
|
2112
|
-
if (Root.Runtime.hostConfig.devToolsIndividualRequestThrottling?.enabled) {
|
|
2113
|
-
this.#requestConditions.applyConditions(
|
|
2114
|
-
this.isOffline(), this.isThrottling() ? this.#networkConditions : null, ...this.#networkAgents);
|
|
2115
|
-
} else {
|
|
2116
|
-
for (const agent of this.#networkAgents) {
|
|
2117
|
-
this.updateNetworkConditions(agent);
|
|
2118
|
-
}
|
|
2119
|
-
}
|
|
2120
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.CONDITIONS_CHANGED);
|
|
2121
|
-
}
|
|
2122
|
-
|
|
2123
|
-
networkConditions(): Conditions {
|
|
2124
|
-
return this.#networkConditions;
|
|
2125
|
-
}
|
|
2126
|
-
|
|
2127
|
-
private updateNetworkConditions(networkAgent: ProtocolProxyApi.NetworkApi): void {
|
|
2128
|
-
const conditions = this.#networkConditions;
|
|
2129
|
-
if (!this.isThrottling()) {
|
|
2130
|
-
void networkAgent.invoke_emulateNetworkConditions({
|
|
2131
|
-
offline: false,
|
|
2132
|
-
latency: 0,
|
|
2133
|
-
downloadThroughput: 0,
|
|
2134
|
-
uploadThroughput: 0,
|
|
2135
|
-
});
|
|
2136
|
-
} else {
|
|
2137
|
-
void networkAgent.invoke_emulateNetworkConditions({
|
|
2138
|
-
offline: this.isOffline(),
|
|
2139
|
-
latency: conditions.latency,
|
|
2140
|
-
downloadThroughput: conditions.download < 0 ? 0 : conditions.download,
|
|
2141
|
-
uploadThroughput: conditions.upload < 0 ? 0 : conditions.upload,
|
|
2142
|
-
packetLoss: (conditions.packetLoss ?? 0) < 0 ? 0 : conditions.packetLoss,
|
|
2143
|
-
packetQueueLength: conditions.packetQueueLength,
|
|
2144
|
-
packetReordering: conditions.packetReordering,
|
|
2145
|
-
connectionType: NetworkManager.connectionType(conditions),
|
|
2146
|
-
});
|
|
2147
|
-
}
|
|
2148
|
-
}
|
|
2149
|
-
|
|
2150
|
-
setExtraHTTPHeaders(headers: Protocol.Network.Headers): void {
|
|
2151
|
-
this.#extraHeaders = headers;
|
|
2152
|
-
for (const agent of this.#networkAgents) {
|
|
2153
|
-
void agent.invoke_setExtraHTTPHeaders({headers: this.#extraHeaders});
|
|
2154
|
-
}
|
|
2155
|
-
}
|
|
2156
|
-
|
|
2157
|
-
currentUserAgent(): string {
|
|
2158
|
-
return this.#customUserAgent ? this.#customUserAgent : this.#userAgentOverride;
|
|
2159
|
-
}
|
|
2160
|
-
|
|
2161
|
-
private updateUserAgentOverride(): void {
|
|
2162
|
-
const userAgent = this.currentUserAgent();
|
|
2163
|
-
for (const agent of this.#networkAgents) {
|
|
2164
|
-
void agent.invoke_setUserAgentOverride(
|
|
2165
|
-
{userAgent, userAgentMetadata: this.#userAgentMetadataOverride || undefined});
|
|
2166
|
-
}
|
|
2167
|
-
}
|
|
2168
|
-
|
|
2169
|
-
setUserAgentOverride(userAgent: string, userAgentMetadataOverride: Protocol.Emulation.UserAgentMetadata|null): void {
|
|
2170
|
-
const uaChanged = (this.#userAgentOverride !== userAgent);
|
|
2171
|
-
this.#userAgentOverride = userAgent;
|
|
2172
|
-
if (!this.#customUserAgent) {
|
|
2173
|
-
this.#userAgentMetadataOverride = userAgentMetadataOverride;
|
|
2174
|
-
this.updateUserAgentOverride();
|
|
2175
|
-
} else {
|
|
2176
|
-
this.#userAgentMetadataOverride = null;
|
|
2177
|
-
}
|
|
2178
|
-
|
|
2179
|
-
if (uaChanged) {
|
|
2180
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.USER_AGENT_CHANGED);
|
|
2181
|
-
}
|
|
2182
|
-
}
|
|
2183
|
-
|
|
2184
|
-
setCustomUserAgentOverride(
|
|
2185
|
-
userAgent: string, userAgentMetadataOverride: Protocol.Emulation.UserAgentMetadata|null = null): void {
|
|
2186
|
-
this.#customUserAgent = userAgent;
|
|
2187
|
-
this.#userAgentMetadataOverride = userAgentMetadataOverride;
|
|
2188
|
-
this.updateUserAgentOverride();
|
|
2189
|
-
}
|
|
2190
|
-
|
|
2191
|
-
setCustomAcceptedEncodingsOverride(acceptedEncodings: Protocol.Network.ContentEncoding[]): void {
|
|
2192
|
-
this.#customAcceptedEncodings = acceptedEncodings;
|
|
2193
|
-
this.updateAcceptedEncodingsOverride();
|
|
2194
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.ACCEPTED_ENCODINGS_CHANGED);
|
|
2195
|
-
}
|
|
2196
|
-
|
|
2197
|
-
clearCustomAcceptedEncodingsOverride(): void {
|
|
2198
|
-
this.#customAcceptedEncodings = null;
|
|
2199
|
-
this.updateAcceptedEncodingsOverride();
|
|
2200
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.ACCEPTED_ENCODINGS_CHANGED);
|
|
2201
|
-
}
|
|
2202
|
-
|
|
2203
|
-
isAcceptedEncodingOverrideSet(): boolean {
|
|
2204
|
-
return this.#customAcceptedEncodings !== null;
|
|
2205
|
-
}
|
|
2206
|
-
|
|
2207
|
-
private updateAcceptedEncodingsOverride(): void {
|
|
2208
|
-
const customAcceptedEncodings = this.#customAcceptedEncodings;
|
|
2209
|
-
for (const agent of this.#networkAgents) {
|
|
2210
|
-
if (customAcceptedEncodings === null) {
|
|
2211
|
-
void agent.invoke_clearAcceptedEncodingsOverride();
|
|
2212
|
-
} else {
|
|
2213
|
-
void agent.invoke_setAcceptedEncodings({encodings: customAcceptedEncodings});
|
|
2214
|
-
}
|
|
2215
|
-
}
|
|
2216
|
-
}
|
|
2217
|
-
|
|
2218
|
-
get requestConditions(): RequestConditions {
|
|
2219
|
-
return this.#requestConditions;
|
|
2220
|
-
}
|
|
2221
|
-
|
|
2222
|
-
isBlocking(): boolean {
|
|
2223
|
-
return this.#isBlocking && this.requestConditions.conditionsEnabled;
|
|
2224
|
-
}
|
|
2225
|
-
|
|
2226
|
-
/**
|
|
2227
|
-
* @deprecated Kept for layout tests
|
|
2228
|
-
* TODO(pfaffe) remove
|
|
2229
|
-
*/
|
|
2230
|
-
private setBlockingEnabled(enabled: boolean): void {
|
|
2231
|
-
this.requestConditions.conditionsEnabled = enabled;
|
|
2232
|
-
}
|
|
2233
|
-
|
|
2234
|
-
/**
|
|
2235
|
-
* @deprecated Kept for layout tests
|
|
2236
|
-
* TODO(pfaffe) remove
|
|
2237
|
-
*/
|
|
2238
|
-
private setBlockedPatterns(patterns: Array<{url: string, enabled: boolean}>): void {
|
|
2239
|
-
this.requestConditions.clear();
|
|
2240
|
-
this.requestConditions.add(...patterns.map(pattern => RequestCondition.createFromSetting(pattern)));
|
|
2241
|
-
}
|
|
2242
|
-
|
|
2243
|
-
private updateBlockedPatterns(): void {
|
|
2244
|
-
this.#isBlocking = this.#requestConditions.applyConditions(
|
|
2245
|
-
this.isOffline(), this.isThrottling() ? this.#networkConditions : null, ...this.#networkAgents);
|
|
2246
|
-
}
|
|
2247
|
-
|
|
2248
|
-
isIntercepting(): boolean {
|
|
2249
|
-
return Boolean(this.#urlsForRequestInterceptor.size);
|
|
2250
|
-
}
|
|
2251
|
-
|
|
2252
|
-
setInterceptionHandlerForPatterns(
|
|
2253
|
-
patterns: InterceptionPattern[], requestInterceptor: (arg0: InterceptedRequest) => Promise<void>): Promise<void> {
|
|
2254
|
-
// Note: requestInterceptors may receive interception #requests for patterns they did not subscribe to.
|
|
2255
|
-
this.#urlsForRequestInterceptor.deleteAll(requestInterceptor);
|
|
2256
|
-
for (const newPattern of patterns) {
|
|
2257
|
-
this.#urlsForRequestInterceptor.set(requestInterceptor, newPattern);
|
|
2258
|
-
}
|
|
2259
|
-
return this.updateInterceptionPatternsOnNextTick();
|
|
2260
|
-
}
|
|
2261
|
-
|
|
2262
|
-
private updateInterceptionPatternsOnNextTick(): Promise<void> {
|
|
2263
|
-
// This is used so we can register and unregister patterns in loops without sending lots of protocol messages.
|
|
2264
|
-
if (!this.#updatingInterceptionPatternsPromise) {
|
|
2265
|
-
this.#updatingInterceptionPatternsPromise = Promise.resolve().then(this.updateInterceptionPatterns.bind(this));
|
|
2266
|
-
}
|
|
2267
|
-
return this.#updatingInterceptionPatternsPromise;
|
|
2268
|
-
}
|
|
2269
|
-
|
|
2270
|
-
private async updateInterceptionPatterns(): Promise<void> {
|
|
2271
|
-
if (!Common.Settings.Settings.instance().moduleSetting('cache-disabled').get()) {
|
|
2272
|
-
Common.Settings.Settings.instance().moduleSetting('cache-disabled').set(true);
|
|
2273
|
-
}
|
|
2274
|
-
this.#updatingInterceptionPatternsPromise = null;
|
|
2275
|
-
const promises = ([] as Array<Promise<unknown>>);
|
|
2276
|
-
for (const agent of this.#fetchAgents) {
|
|
2277
|
-
promises.push(agent.invoke_enable({patterns: this.#urlsForRequestInterceptor.valuesArray()}));
|
|
2278
|
-
}
|
|
2279
|
-
this.dispatchEventToListeners(MultitargetNetworkManager.Events.INTERCEPTORS_CHANGED);
|
|
2280
|
-
await Promise.all(promises);
|
|
2281
|
-
}
|
|
2282
|
-
|
|
2283
|
-
async requestIntercepted(interceptedRequest: InterceptedRequest): Promise<void> {
|
|
2284
|
-
for (const requestInterceptor of this.#urlsForRequestInterceptor.keysArray()) {
|
|
2285
|
-
await requestInterceptor(interceptedRequest);
|
|
2286
|
-
if (interceptedRequest.hasResponded() && interceptedRequest.networkRequest) {
|
|
2287
|
-
this.dispatchEventToListeners(
|
|
2288
|
-
MultitargetNetworkManager.Events.REQUEST_INTERCEPTED, interceptedRequest.networkRequest.requestId());
|
|
2289
|
-
return;
|
|
2290
|
-
}
|
|
2291
|
-
}
|
|
2292
|
-
if (!interceptedRequest.hasResponded()) {
|
|
2293
|
-
interceptedRequest.continueRequestWithoutChange();
|
|
2294
|
-
}
|
|
2295
|
-
}
|
|
2296
|
-
|
|
2297
|
-
clearBrowserCache(): void {
|
|
2298
|
-
for (const agent of this.#networkAgents) {
|
|
2299
|
-
void agent.invoke_clearBrowserCache();
|
|
2300
|
-
}
|
|
2301
|
-
}
|
|
2302
|
-
|
|
2303
|
-
clearBrowserCookies(): void {
|
|
2304
|
-
for (const agent of this.#networkAgents) {
|
|
2305
|
-
void agent.invoke_clearBrowserCookies();
|
|
2306
|
-
}
|
|
2307
|
-
}
|
|
2308
|
-
|
|
2309
|
-
async getCertificate(origin: string): Promise<string[]> {
|
|
2310
|
-
const target = TargetManager.instance().primaryPageTarget();
|
|
2311
|
-
if (!target) {
|
|
2312
|
-
return [];
|
|
2313
|
-
}
|
|
2314
|
-
const certificate = await target.networkAgent().invoke_getCertificate({origin});
|
|
2315
|
-
if (!certificate) {
|
|
2316
|
-
return [];
|
|
2317
|
-
}
|
|
2318
|
-
return certificate.tableNames;
|
|
2319
|
-
}
|
|
2320
|
-
|
|
2321
|
-
async loadResource(url: Platform.DevToolsPath.UrlString): Promise<{
|
|
2322
|
-
success: boolean,
|
|
2323
|
-
content: string,
|
|
2324
|
-
errorDescription: Host.ResourceLoader.LoadErrorDescription,
|
|
2325
|
-
}> {
|
|
2326
|
-
const headers: Record<string, string> = {};
|
|
2327
|
-
|
|
2328
|
-
const currentUserAgent = this.currentUserAgent();
|
|
2329
|
-
if (currentUserAgent) {
|
|
2330
|
-
headers['User-Agent'] = currentUserAgent;
|
|
2331
|
-
}
|
|
2332
|
-
|
|
2333
|
-
if (Common.Settings.Settings.instance().moduleSetting('cache-disabled').get()) {
|
|
2334
|
-
headers['Cache-Control'] = 'no-cache';
|
|
2335
|
-
}
|
|
2336
|
-
|
|
2337
|
-
const allowRemoteFilePaths =
|
|
2338
|
-
Common.Settings.Settings.instance().moduleSetting('network.enable-remote-file-loading').get();
|
|
2339
|
-
|
|
2340
|
-
return await new Promise(
|
|
2341
|
-
resolve => Host.ResourceLoader.load(url, headers, (success, _responseHeaders, content, errorDescription) => {
|
|
2342
|
-
resolve({success, content, errorDescription});
|
|
2343
|
-
}, allowRemoteFilePaths));
|
|
2344
|
-
}
|
|
2345
|
-
|
|
2346
|
-
appliedRequestConditions(requestInternal: NetworkRequest): {
|
|
2347
|
-
conditions: Conditions,
|
|
2348
|
-
urlPattern?: string,
|
|
2349
|
-
}|undefined {
|
|
2350
|
-
if (!requestInternal.appliedNetworkConditionsId) {
|
|
2351
|
-
return undefined;
|
|
2352
|
-
}
|
|
2353
|
-
return this.requestConditions.conditionsForId(requestInternal.appliedNetworkConditionsId);
|
|
2354
|
-
}
|
|
2355
|
-
}
|
|
2356
|
-
|
|
2357
|
-
export namespace MultitargetNetworkManager {
|
|
2358
|
-
export const enum Events {
|
|
2359
|
-
BLOCKED_PATTERNS_CHANGED = 'BlockedPatternsChanged',
|
|
2360
|
-
CONDITIONS_CHANGED = 'ConditionsChanged',
|
|
2361
|
-
USER_AGENT_CHANGED = 'UserAgentChanged',
|
|
2362
|
-
INTERCEPTORS_CHANGED = 'InterceptorsChanged',
|
|
2363
|
-
ACCEPTED_ENCODINGS_CHANGED = 'AcceptedEncodingsChanged',
|
|
2364
|
-
REQUEST_INTERCEPTED = 'RequestIntercepted',
|
|
2365
|
-
REQUEST_FULFILLED = 'RequestFulfilled',
|
|
2366
|
-
}
|
|
2367
|
-
|
|
2368
|
-
export interface EventTypes {
|
|
2369
|
-
[Events.BLOCKED_PATTERNS_CHANGED]: void;
|
|
2370
|
-
[Events.CONDITIONS_CHANGED]: void;
|
|
2371
|
-
[Events.USER_AGENT_CHANGED]: void;
|
|
2372
|
-
[Events.INTERCEPTORS_CHANGED]: void;
|
|
2373
|
-
[Events.ACCEPTED_ENCODINGS_CHANGED]: void;
|
|
2374
|
-
[Events.REQUEST_INTERCEPTED]: string;
|
|
2375
|
-
[Events.REQUEST_FULFILLED]: Platform.DevToolsPath.UrlString;
|
|
2376
|
-
}
|
|
2377
|
-
}
|
|
2378
|
-
|
|
2379
|
-
export class InterceptedRequest {
|
|
2380
|
-
readonly #fetchAgent: ProtocolProxyApi.FetchApi;
|
|
2381
|
-
#hasResponded = false;
|
|
2382
|
-
request: Protocol.Network.Request;
|
|
2383
|
-
resourceType: Protocol.Network.ResourceType;
|
|
2384
|
-
responseStatusCode: number|undefined;
|
|
2385
|
-
responseHeaders: Protocol.Fetch.HeaderEntry[]|undefined;
|
|
2386
|
-
requestId: Protocol.Fetch.RequestId;
|
|
2387
|
-
networkRequest: NetworkRequest|null;
|
|
2388
|
-
|
|
2389
|
-
constructor(
|
|
2390
|
-
fetchAgent: ProtocolProxyApi.FetchApi,
|
|
2391
|
-
request: Protocol.Network.Request,
|
|
2392
|
-
resourceType: Protocol.Network.ResourceType,
|
|
2393
|
-
requestId: Protocol.Fetch.RequestId,
|
|
2394
|
-
networkRequest: NetworkRequest|null,
|
|
2395
|
-
responseStatusCode?: number,
|
|
2396
|
-
responseHeaders?: Protocol.Fetch.HeaderEntry[],
|
|
2397
|
-
) {
|
|
2398
|
-
this.#fetchAgent = fetchAgent;
|
|
2399
|
-
this.request = request;
|
|
2400
|
-
this.resourceType = resourceType;
|
|
2401
|
-
this.responseStatusCode = responseStatusCode;
|
|
2402
|
-
this.responseHeaders = responseHeaders;
|
|
2403
|
-
this.requestId = requestId;
|
|
2404
|
-
this.networkRequest = networkRequest;
|
|
2405
|
-
}
|
|
2406
|
-
|
|
2407
|
-
hasResponded(): boolean {
|
|
2408
|
-
return this.#hasResponded;
|
|
2409
|
-
}
|
|
2410
|
-
|
|
2411
|
-
static mergeSetCookieHeaders(
|
|
2412
|
-
originalSetCookieHeaders: Protocol.Fetch.HeaderEntry[],
|
|
2413
|
-
setCookieHeadersFromOverrides: Protocol.Fetch.HeaderEntry[]): Protocol.Fetch.HeaderEntry[] {
|
|
2414
|
-
// Generates a map containing the `set-cookie` headers. Valid `set-cookie`
|
|
2415
|
-
// headers are stored by the cookie name. Malformed `set-cookie` headers are
|
|
2416
|
-
// stored by the whole header value. Duplicates are allowed.
|
|
2417
|
-
const generateHeaderMap = (headers: Protocol.Fetch.HeaderEntry[]): Map<string, string[]> => {
|
|
2418
|
-
const result = new Map<string, string[]>();
|
|
2419
|
-
for (const header of headers) {
|
|
2420
|
-
// The regex matches cookie headers of the form '<header-name>=<header-value>'.
|
|
2421
|
-
// <header-name> is a token as defined in https://www.rfc-editor.org/rfc/rfc9110.html#name-tokens.
|
|
2422
|
-
// The shape of <header-value> is not being validated at all here.
|
|
2423
|
-
const match = header.value.match(/^([a-zA-Z0-9!#$%&'*+.^_`|~-]+=)(.*)$/);
|
|
2424
|
-
if (match) {
|
|
2425
|
-
if (result.has(match[1])) {
|
|
2426
|
-
result.get(match[1])?.push(header.value);
|
|
2427
|
-
} else {
|
|
2428
|
-
result.set(match[1], [header.value]);
|
|
2429
|
-
}
|
|
2430
|
-
} else if (result.has(header.value)) {
|
|
2431
|
-
result.get(header.value)?.push(header.value);
|
|
2432
|
-
} else {
|
|
2433
|
-
result.set(header.value, [header.value]);
|
|
2434
|
-
}
|
|
2435
|
-
}
|
|
2436
|
-
return result;
|
|
2437
|
-
};
|
|
2438
|
-
|
|
2439
|
-
const originalHeadersMap = generateHeaderMap(originalSetCookieHeaders);
|
|
2440
|
-
const overridesHeaderMap = generateHeaderMap(setCookieHeadersFromOverrides);
|
|
2441
|
-
|
|
2442
|
-
// Iterate over original headers. If the same key is found among the
|
|
2443
|
-
// overrides, use those instead.
|
|
2444
|
-
const mergedHeaders: Protocol.Fetch.HeaderEntry[] = [];
|
|
2445
|
-
for (const [key, headerValues] of originalHeadersMap) {
|
|
2446
|
-
if (overridesHeaderMap.has(key)) {
|
|
2447
|
-
for (const headerValue of overridesHeaderMap.get(key) || []) {
|
|
2448
|
-
mergedHeaders.push({name: 'set-cookie', value: headerValue});
|
|
2449
|
-
}
|
|
2450
|
-
} else {
|
|
2451
|
-
for (const headerValue of headerValues) {
|
|
2452
|
-
mergedHeaders.push({name: 'set-cookie', value: headerValue});
|
|
2453
|
-
}
|
|
2454
|
-
}
|
|
2455
|
-
}
|
|
2456
|
-
|
|
2457
|
-
// Finally add all overrides which have not been added yet.
|
|
2458
|
-
for (const [key, headerValues] of overridesHeaderMap) {
|
|
2459
|
-
if (originalHeadersMap.has(key)) {
|
|
2460
|
-
continue;
|
|
2461
|
-
}
|
|
2462
|
-
for (const headerValue of headerValues) {
|
|
2463
|
-
mergedHeaders.push({name: 'set-cookie', value: headerValue});
|
|
2464
|
-
}
|
|
2465
|
-
}
|
|
2466
|
-
return mergedHeaders;
|
|
2467
|
-
}
|
|
2468
|
-
|
|
2469
|
-
async continueRequestWithContent(
|
|
2470
|
-
contentBlob: Blob, encoded: boolean, responseHeaders: Protocol.Fetch.HeaderEntry[],
|
|
2471
|
-
isBodyOverridden: boolean): Promise<void> {
|
|
2472
|
-
this.#hasResponded = true;
|
|
2473
|
-
const body = encoded ? await contentBlob.text() : await Common.Base64.encode(contentBlob).catch(err => {
|
|
2474
|
-
console.error(err);
|
|
2475
|
-
return '';
|
|
2476
|
-
});
|
|
2477
|
-
const responseCode = isBodyOverridden ? 200 : (this.responseStatusCode || 200);
|
|
2478
|
-
|
|
2479
|
-
if (this.networkRequest) {
|
|
2480
|
-
const originalSetCookieHeaders =
|
|
2481
|
-
this.networkRequest?.originalResponseHeaders.filter(header => header.name === 'set-cookie') || [];
|
|
2482
|
-
const setCookieHeadersFromOverrides = responseHeaders.filter(header => header.name === 'set-cookie');
|
|
2483
|
-
this.networkRequest.setCookieHeaders =
|
|
2484
|
-
InterceptedRequest.mergeSetCookieHeaders(originalSetCookieHeaders, setCookieHeadersFromOverrides);
|
|
2485
|
-
this.networkRequest.hasOverriddenContent = isBodyOverridden;
|
|
2486
|
-
}
|
|
2487
|
-
|
|
2488
|
-
void this.#fetchAgent.invoke_fulfillRequest({requestId: this.requestId, responseCode, body, responseHeaders});
|
|
2489
|
-
MultitargetNetworkManager.instance().dispatchEventToListeners(
|
|
2490
|
-
MultitargetNetworkManager.Events.REQUEST_FULFILLED, this.request.url as Platform.DevToolsPath.UrlString);
|
|
2491
|
-
}
|
|
2492
|
-
|
|
2493
|
-
continueRequestWithoutChange(): void {
|
|
2494
|
-
console.assert(!this.#hasResponded);
|
|
2495
|
-
this.#hasResponded = true;
|
|
2496
|
-
void this.#fetchAgent.invoke_continueRequest({requestId: this.requestId});
|
|
2497
|
-
}
|
|
2498
|
-
|
|
2499
|
-
async responseBody(): Promise<TextUtils.ContentData.ContentDataOrError> {
|
|
2500
|
-
const response = await this.#fetchAgent.invoke_getResponseBody({requestId: this.requestId});
|
|
2501
|
-
const error = response.getError();
|
|
2502
|
-
if (error) {
|
|
2503
|
-
return {error};
|
|
2504
|
-
}
|
|
2505
|
-
|
|
2506
|
-
const {mimeType, charset} = this.getMimeTypeAndCharset();
|
|
2507
|
-
return new TextUtils.ContentData.ContentData(
|
|
2508
|
-
response.body, response.base64Encoded, mimeType ?? 'application/octet-stream', charset ?? undefined);
|
|
2509
|
-
}
|
|
2510
|
-
|
|
2511
|
-
isRedirect(): boolean {
|
|
2512
|
-
return this.responseStatusCode !== undefined && this.responseStatusCode >= 300 && this.responseStatusCode < 400;
|
|
2513
|
-
}
|
|
2514
|
-
|
|
2515
|
-
/**
|
|
2516
|
-
* Tries to determine the MIME type and charset for this intercepted request.
|
|
2517
|
-
* Looks at the intercepted response headers first (for Content-Type header), then
|
|
2518
|
-
* checks the `NetworkRequest` if we have one.
|
|
2519
|
-
*/
|
|
2520
|
-
getMimeTypeAndCharset(): {mimeType: string|null, charset: string|null} {
|
|
2521
|
-
for (const header of this.responseHeaders ?? []) {
|
|
2522
|
-
if (header.name.toLowerCase() === 'content-type') {
|
|
2523
|
-
return Platform.MimeType.parseContentType(header.value);
|
|
2524
|
-
}
|
|
2525
|
-
}
|
|
2526
|
-
|
|
2527
|
-
const mimeType = this.networkRequest?.mimeType ?? null;
|
|
2528
|
-
const charset = this.networkRequest?.charset() ?? null;
|
|
2529
|
-
return {mimeType, charset};
|
|
2530
|
-
}
|
|
2531
|
-
}
|
|
2532
|
-
|
|
2533
|
-
/**
|
|
2534
|
-
* Helper class to match #requests created from requestWillBeSent with
|
|
2535
|
-
* requestWillBeSentExtraInfo and responseReceivedExtraInfo when they have the
|
|
2536
|
-
* same requestId due to redirects.
|
|
2537
|
-
*/
|
|
2538
|
-
class ExtraInfoBuilder {
|
|
2539
|
-
readonly #requests: NetworkRequest[] = [];
|
|
2540
|
-
#responseExtraInfoFlag: Array<boolean|null> = [];
|
|
2541
|
-
#requestExtraInfos: Array<ExtraRequestInfo|null> = [];
|
|
2542
|
-
#responseExtraInfos: Array<ExtraResponseInfo|null> = [];
|
|
2543
|
-
#responseEarlyHintsHeaders: NameValue[] = [];
|
|
2544
|
-
#finished = false;
|
|
2545
|
-
|
|
2546
|
-
addRequest(req: NetworkRequest): void {
|
|
2547
|
-
this.#requests.push(req);
|
|
2548
|
-
this.sync(this.#requests.length - 1);
|
|
2549
|
-
}
|
|
2550
|
-
|
|
2551
|
-
addHasExtraInfo(hasExtraInfo: boolean): void {
|
|
2552
|
-
this.#responseExtraInfoFlag.push(hasExtraInfo);
|
|
2553
|
-
// This comes in response, so it can't come before request or after next
|
|
2554
|
-
// request in the redirect chain.
|
|
2555
|
-
console.assert(this.#requests.length === this.#responseExtraInfoFlag.length, 'request/response count mismatch');
|
|
2556
|
-
if (!hasExtraInfo) {
|
|
2557
|
-
// We may potentially have gotten extra infos from the next redirect
|
|
2558
|
-
// request already. Account for that by inserting null for missing
|
|
2559
|
-
// extra infos at current position.
|
|
2560
|
-
this.#requestExtraInfos.splice(this.#requests.length - 1, 0, null);
|
|
2561
|
-
this.#responseExtraInfos.splice(this.#requests.length - 1, 0, null);
|
|
2562
|
-
}
|
|
2563
|
-
this.sync(this.#requests.length - 1);
|
|
2564
|
-
}
|
|
2565
|
-
|
|
2566
|
-
addRequestExtraInfo(info: ExtraRequestInfo): void {
|
|
2567
|
-
this.#requestExtraInfos.push(info);
|
|
2568
|
-
this.sync(this.#requestExtraInfos.length - 1);
|
|
2569
|
-
}
|
|
2570
|
-
|
|
2571
|
-
addResponseExtraInfo(info: ExtraResponseInfo): void {
|
|
2572
|
-
this.#responseExtraInfos.push(info);
|
|
2573
|
-
this.sync(this.#responseExtraInfos.length - 1);
|
|
2574
|
-
}
|
|
2575
|
-
|
|
2576
|
-
setEarlyHintsHeaders(earlyHintsHeaders: NameValue[]): void {
|
|
2577
|
-
this.#responseEarlyHintsHeaders = earlyHintsHeaders;
|
|
2578
|
-
this.updateFinalRequest();
|
|
2579
|
-
}
|
|
2580
|
-
|
|
2581
|
-
finished(): void {
|
|
2582
|
-
this.#finished = true;
|
|
2583
|
-
// We may have missed responseReceived event in case of failure.
|
|
2584
|
-
// That said, the ExtraInfo events still may be here, so mark them
|
|
2585
|
-
// as present. Event if they are not, this is harmless.
|
|
2586
|
-
// TODO(caseq): consider if we need to report hasExtraInfo in the
|
|
2587
|
-
// loadingFailed event.
|
|
2588
|
-
if (this.#responseExtraInfoFlag.length < this.#requests.length) {
|
|
2589
|
-
this.#responseExtraInfoFlag.push(true);
|
|
2590
|
-
this.sync(this.#responseExtraInfoFlag.length - 1);
|
|
2591
|
-
}
|
|
2592
|
-
console.assert(
|
|
2593
|
-
this.#requests.length === this.#responseExtraInfoFlag.length,
|
|
2594
|
-
'request/response count mismatch when request finished');
|
|
2595
|
-
this.updateFinalRequest();
|
|
2596
|
-
}
|
|
2597
|
-
|
|
2598
|
-
isFinished(): boolean {
|
|
2599
|
-
return this.#finished;
|
|
2600
|
-
}
|
|
2601
|
-
|
|
2602
|
-
private sync(index: number): void {
|
|
2603
|
-
const req = this.#requests[index];
|
|
2604
|
-
if (!req) {
|
|
2605
|
-
return;
|
|
2606
|
-
}
|
|
2607
|
-
|
|
2608
|
-
// No response yet, so we don't know if extra info would
|
|
2609
|
-
// be there, bail out for now.
|
|
2610
|
-
if (index >= this.#responseExtraInfoFlag.length) {
|
|
2611
|
-
return;
|
|
2612
|
-
}
|
|
2613
|
-
if (!this.#responseExtraInfoFlag[index]) {
|
|
2614
|
-
return;
|
|
2615
|
-
}
|
|
2616
|
-
|
|
2617
|
-
const requestExtraInfo = this.#requestExtraInfos[index];
|
|
2618
|
-
if (requestExtraInfo) {
|
|
2619
|
-
req.addExtraRequestInfo(requestExtraInfo);
|
|
2620
|
-
this.#requestExtraInfos[index] = null;
|
|
2621
|
-
}
|
|
2622
|
-
|
|
2623
|
-
const responseExtraInfo = this.#responseExtraInfos[index];
|
|
2624
|
-
if (responseExtraInfo) {
|
|
2625
|
-
req.addExtraResponseInfo(responseExtraInfo);
|
|
2626
|
-
this.#responseExtraInfos[index] = null;
|
|
2627
|
-
}
|
|
2628
|
-
}
|
|
2629
|
-
|
|
2630
|
-
finalRequest(): NetworkRequest|null {
|
|
2631
|
-
if (!this.#finished) {
|
|
2632
|
-
return null;
|
|
2633
|
-
}
|
|
2634
|
-
return this.#requests[this.#requests.length - 1] || null;
|
|
2635
|
-
}
|
|
2636
|
-
|
|
2637
|
-
private updateFinalRequest(): void {
|
|
2638
|
-
if (!this.#finished) {
|
|
2639
|
-
return;
|
|
2640
|
-
}
|
|
2641
|
-
const finalRequest = this.finalRequest();
|
|
2642
|
-
finalRequest?.setEarlyHintsHeaders(this.#responseEarlyHintsHeaders);
|
|
2643
|
-
}
|
|
2644
|
-
}
|
|
2645
|
-
|
|
2646
|
-
SDKModel.register(NetworkManager, {capabilities: Capability.NETWORK, autostart: true});
|
|
2647
|
-
|
|
2648
|
-
export function networkConditionsEqual(first: ThrottlingConditions, second: ThrottlingConditions): boolean {
|
|
2649
|
-
if ('block' in first || 'block' in second) {
|
|
2650
|
-
if ('block' in first && 'block' in second) {
|
|
2651
|
-
const firstTitle = (typeof first.title === 'function' ? first.title() : first.title);
|
|
2652
|
-
const secondTitle = (typeof second.title === 'function' ? second.title() : second.title);
|
|
2653
|
-
return firstTitle === secondTitle && first.block === second.block;
|
|
2654
|
-
}
|
|
2655
|
-
return false;
|
|
2656
|
-
}
|
|
2657
|
-
// Caution: titles might be different function instances, which produce
|
|
2658
|
-
// the same value.
|
|
2659
|
-
// We prefer to use the i18nTitleKey to prevent against locale changes or
|
|
2660
|
-
// UIString changes that might change the value vs what the user has stored
|
|
2661
|
-
// locally.
|
|
2662
|
-
const firstTitle = first.i18nTitleKey || (typeof first.title === 'function' ? first.title() : first.title);
|
|
2663
|
-
const secondTitle = second.i18nTitleKey || (typeof second.title === 'function' ? second.title() : second.title);
|
|
2664
|
-
|
|
2665
|
-
return second.download === first.download && second.upload === first.upload && second.latency === first.latency &&
|
|
2666
|
-
first.packetLoss === second.packetLoss && first.packetQueueLength === second.packetQueueLength &&
|
|
2667
|
-
first.packetReordering === second.packetReordering && secondTitle === firstTitle;
|
|
2668
|
-
}
|
|
2669
|
-
|
|
2670
|
-
/**
|
|
2671
|
-
* IMPORTANT: this key is used as the value that is persisted so we remember
|
|
2672
|
-
* the user's throttling settings
|
|
2673
|
-
*
|
|
2674
|
-
* This means that it is very important that;
|
|
2675
|
-
* 1. Each Conditions that is defined must have a unique key.
|
|
2676
|
-
* 2. The keys & values DO NOT CHANGE for a particular condition, else we might break
|
|
2677
|
-
* DevTools when restoring a user's persisted setting.
|
|
2678
|
-
*
|
|
2679
|
-
* If you do want to change them, you need to handle that in a migration, but
|
|
2680
|
-
* please talk to jacktfranklin@ first.
|
|
2681
|
-
*/
|
|
2682
|
-
export const enum PredefinedThrottlingConditionKey {
|
|
2683
|
-
BLOCKING = 'BLOCKING',
|
|
2684
|
-
NO_THROTTLING = 'NO_THROTTLING',
|
|
2685
|
-
OFFLINE = 'OFFLINE',
|
|
2686
|
-
SPEED_3G = 'SPEED_3G',
|
|
2687
|
-
SPEED_SLOW_4G = 'SPEED_SLOW_4G',
|
|
2688
|
-
SPEED_FAST_4G = 'SPEED_FAST_4G',
|
|
2689
|
-
}
|
|
2690
|
-
|
|
2691
|
-
export type UserDefinedThrottlingConditionKey = `USER_CUSTOM_SETTING_${number}`;
|
|
2692
|
-
export type ThrottlingConditionKey = PredefinedThrottlingConditionKey|UserDefinedThrottlingConditionKey;
|
|
2693
|
-
|
|
2694
|
-
export const THROTTLING_CONDITIONS_LOOKUP: ReadonlyMap<PredefinedThrottlingConditionKey, Conditions> = new Map([
|
|
2695
|
-
[PredefinedThrottlingConditionKey.NO_THROTTLING, NoThrottlingConditions],
|
|
2696
|
-
[PredefinedThrottlingConditionKey.OFFLINE, OfflineConditions],
|
|
2697
|
-
[PredefinedThrottlingConditionKey.SPEED_3G, Slow3GConditions],
|
|
2698
|
-
[PredefinedThrottlingConditionKey.SPEED_SLOW_4G, Slow4GConditions],
|
|
2699
|
-
[PredefinedThrottlingConditionKey.SPEED_FAST_4G, Fast4GConditions]
|
|
2700
|
-
]);
|
|
2701
|
-
|
|
2702
|
-
function keyIsPredefined(key: ThrottlingConditionKey): key is PredefinedThrottlingConditionKey {
|
|
2703
|
-
return !key.startsWith('USER_CUSTOM_SETTING_');
|
|
2704
|
-
}
|
|
2705
|
-
export function keyIsCustomUser(key: ThrottlingConditionKey): key is UserDefinedThrottlingConditionKey {
|
|
2706
|
-
return key.startsWith('USER_CUSTOM_SETTING_');
|
|
2707
|
-
}
|
|
2708
|
-
|
|
2709
|
-
export function getPredefinedCondition(key: ThrottlingConditionKey): Conditions|null {
|
|
2710
|
-
if (!keyIsPredefined(key)) {
|
|
2711
|
-
return null;
|
|
2712
|
-
}
|
|
2713
|
-
return THROTTLING_CONDITIONS_LOOKUP.get(key) ?? null;
|
|
2714
|
-
}
|
|
2715
|
-
|
|
2716
|
-
export function getPredefinedOrBlockingCondition(key: ThrottlingConditionKey): ThrottlingConditions|null {
|
|
2717
|
-
return key === PredefinedThrottlingConditionKey.BLOCKING ? BlockingConditions : getPredefinedCondition(key);
|
|
2718
|
-
}
|
|
2719
|
-
|
|
2720
|
-
export type ThrottlingConditions = Conditions|{
|
|
2721
|
-
readonly key: ThrottlingConditionKey,
|
|
2722
|
-
block: true,
|
|
2723
|
-
title: string | (() => string),
|
|
2724
|
-
};
|
|
2725
|
-
export interface Conditions {
|
|
2726
|
-
readonly key: ThrottlingConditionKey;
|
|
2727
|
-
download: number;
|
|
2728
|
-
upload: number;
|
|
2729
|
-
latency: number;
|
|
2730
|
-
packetLoss?: number;
|
|
2731
|
-
packetQueueLength?: number;
|
|
2732
|
-
packetReordering?: boolean;
|
|
2733
|
-
// TODO(crbug.com/1219425): In the future, it might be worthwhile to
|
|
2734
|
-
// consider avoiding mixing up presentation state (e.g.: displayed
|
|
2735
|
-
// titles) with behavioral state (e.g.: the throttling amounts). In
|
|
2736
|
-
// this particular case, the title (along with other properties)
|
|
2737
|
-
// doubles as both part of group of fields which (loosely) uniquely
|
|
2738
|
-
// identify instances, as well as the literal string displayed in the
|
|
2739
|
-
// UI, which leads to complications around persistance.
|
|
2740
|
-
// TODO(crbug.com/422682525): make this just a function because we use lazy string everywhere.
|
|
2741
|
-
title: string|(() => string);
|
|
2742
|
-
// Instances may be serialized to local storage, so localized titles
|
|
2743
|
-
// should not be irrecoverably baked, just in case the string changes
|
|
2744
|
-
// (or the user switches locales).
|
|
2745
|
-
// TODO(crbug.com/422682525): get rid of this, there is no need to store on
|
|
2746
|
-
// the condition now we do not rely on it to reload a setting from disk.
|
|
2747
|
-
i18nTitleKey?: string;
|
|
2748
|
-
/**
|
|
2749
|
-
* RTT values are multiplied by adjustment factors to make DevTools' emulation more accurate.
|
|
2750
|
-
* This value represents the RTT value *before* the adjustment factor is applied.
|
|
2751
|
-
* @see https://docs.google.com/document/d/10lfVdS1iDWCRKQXPfbxEn4Or99D64mvNlugP1AQuFlE/edit for historical context.
|
|
2752
|
-
*/
|
|
2753
|
-
targetLatency?: number;
|
|
2754
|
-
}
|
|
2755
|
-
|
|
2756
|
-
export interface Message {
|
|
2757
|
-
message: string;
|
|
2758
|
-
requestId: string;
|
|
2759
|
-
warning: boolean;
|
|
2760
|
-
}
|
|
2761
|
-
|
|
2762
|
-
export interface InterceptionPattern {
|
|
2763
|
-
urlPattern: string;
|
|
2764
|
-
requestStage: Protocol.Fetch.RequestStage;
|
|
2765
|
-
}
|
|
2766
|
-
|
|
2767
|
-
export type RequestInterceptor = (request: InterceptedRequest) => Promise<void>;
|
|
2768
|
-
|
|
2769
|
-
export interface RequestUpdateDroppedEventData {
|
|
2770
|
-
url: Platform.DevToolsPath.UrlString;
|
|
2771
|
-
frameId: Protocol.Page.FrameId|null;
|
|
2772
|
-
loaderId: Protocol.Network.LoaderId;
|
|
2773
|
-
resourceType: Protocol.Network.ResourceType;
|
|
2774
|
-
mimeType: string;
|
|
2775
|
-
lastModified: Date|null;
|
|
2776
|
-
}
|
|
2777
|
-
|
|
2778
|
-
/**
|
|
2779
|
-
* For the given Round Trip Time (in MilliSeconds), return the best throttling conditions.
|
|
2780
|
-
*/
|
|
2781
|
-
export function getRecommendedNetworkPreset(rtt: number): Conditions|null {
|
|
2782
|
-
const RTT_COMPARISON_THRESHOLD = 200;
|
|
2783
|
-
const RTT_MINIMUM = 60;
|
|
2784
|
-
|
|
2785
|
-
if (!Number.isFinite(rtt)) {
|
|
2786
|
-
return null;
|
|
2787
|
-
}
|
|
2788
|
-
|
|
2789
|
-
if (rtt < RTT_MINIMUM) {
|
|
2790
|
-
return null;
|
|
2791
|
-
}
|
|
2792
|
-
|
|
2793
|
-
// We pick from the set of presets in the panel but do not want to allow
|
|
2794
|
-
// the "No Throttling" option to be picked.
|
|
2795
|
-
const presets = THROTTLING_CONDITIONS_LOOKUP.values()
|
|
2796
|
-
.filter(condition => {
|
|
2797
|
-
return condition !== NoThrottlingConditions;
|
|
2798
|
-
})
|
|
2799
|
-
.toArray();
|
|
2800
|
-
|
|
2801
|
-
let closestPreset: Conditions|null = null;
|
|
2802
|
-
let smallestDiff = Infinity;
|
|
2803
|
-
for (const preset of presets) {
|
|
2804
|
-
const {targetLatency} = preset;
|
|
2805
|
-
if (!targetLatency) {
|
|
2806
|
-
continue;
|
|
2807
|
-
}
|
|
2808
|
-
|
|
2809
|
-
const diff = Math.abs(targetLatency - rtt);
|
|
2810
|
-
if (diff > RTT_COMPARISON_THRESHOLD) {
|
|
2811
|
-
continue;
|
|
2812
|
-
}
|
|
2813
|
-
|
|
2814
|
-
if (smallestDiff < diff) {
|
|
2815
|
-
continue;
|
|
2816
|
-
}
|
|
2817
|
-
|
|
2818
|
-
closestPreset = preset;
|
|
2819
|
-
smallestDiff = diff;
|
|
2820
|
-
}
|
|
2821
|
-
|
|
2822
|
-
return closestPreset;
|
|
2823
|
-
}
|