chrome-ai-bridge 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/README.md +252 -0
- package/build/node_modules/chrome-devtools-frontend/LICENSE +27 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/App.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/AppProvider.js +17 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Base64.js +43 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/CharacterIdMap.js +27 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Color.js +2033 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ColorConverter.js +332 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ColorUtils.js +221 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Console.js +79 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Debouncer.js +14 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/EventTarget.js +14 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Gzip.js +66 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/JavaScriptMetaData.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Lazy.js +29 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/MapWithDefault.js +22 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Mutex.js +49 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Object.js +86 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ParsedURL.js +449 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Progress.js +144 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ResolverBase.js +69 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ResourceType.js +495 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/ReturnToPanel.js +15 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Revealer.js +164 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Runnable.js +24 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/SegmentedRange.js +78 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/SettingRegistration.js +164 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Settings.js +1263 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/SimpleHistoryManager.js +97 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/StringOutputStream.js +14 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/TextDictionary.js +40 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Throttler.js +71 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/Trie.js +127 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/common/common.js +41 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/AidaClient.js +434 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/DispatchHttpRequestClient.js +66 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/GdpClient.js +202 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/InspectorFrontendHost.js +92 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/InspectorFrontendHostAPI.js +69 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/InspectorFrontendHostStub.js +430 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/Platform.js +61 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/ResourceLoader.js +220 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/UserMetrics.js +968 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/host/host.js +13 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/i18n/i18n.js +60 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/ArrayUtilities.js +199 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/Brand.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/Constructor.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/DateUtilities.js +13 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/DevToolsPath.js +27 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/HostRuntime.js +19 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/KeyboardUtilities.js +21 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/MapUtilities.js +79 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/MimeType.js +143 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/NumberUtilities.js +72 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/StringUtilities.js +538 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/Timing.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/TypedArrayUtilities.js +157 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/TypescriptUtilities.js +24 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/UIString.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/UserVisibleError.js +22 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/api/HostRuntime.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/api/api.js +5 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/browser/HostRuntime.js +63 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/browser/browser.js +5 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/node/HostRuntime.js +72 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/node/node.js +5 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/platform/platform.js +26 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/protocol_client/CDPConnection.js +17 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/protocol_client/ConnectionTransport.js +12 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/protocol_client/DevToolsCDPConnection.js +138 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/protocol_client/InspectorBackend.js +539 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/protocol_client/protocol_client.js +8 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/root/DevToolsContext.js +54 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/root/Runtime.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/root/root.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/AccessibilityModel.js +281 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/AnimationModel.js +845 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/AutofillModel.js +155 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CPUProfilerModel.js +99 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CPUThrottlingManager.js +217 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSContainerQuery.js +98 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSFontFace.js +31 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSLayer.js +22 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSMatchedStyles.js +1318 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSMedia.js +100 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSMetadata.js +1532 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSModel.js +908 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSProperty.js +312 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSPropertyParser.js +574 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSPropertyParserMatchers.js +1346 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSQuery.js +53 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSRule.js +403 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSScope.js +22 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSStartingStyle.js +21 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSStyleDeclaration.js +275 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSStyleSheetHeader.js +166 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CSSSupports.js +24 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CategorizedBreakpoint.js +29 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ChildTargetManager.js +236 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CompilerSourceMappingContentProvider.js +47 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/Connections.js +205 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ConsoleModel.js +629 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ConsoleModelTypes.js +14 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/Cookie.js +241 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CookieModel.js +198 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/CookieParser.js +163 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/DOMDebuggerModel.js +597 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/DOMModel.js +1635 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/DebuggerModel.js +1216 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/EmulationModel.js +527 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/EnhancedTracesParser.js +364 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/EventBreakpointsModel.js +127 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/FrameAssociated.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/FrameManager.js +199 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/HeapProfilerModel.js +130 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/HttpReasonPhraseStrings.js +75 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/IOModel.js +80 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/IsolateManager.js +208 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/IssuesModel.js +41 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/LayerTreeBase.js +95 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/LogModel.js +34 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/NetworkManager.js +2223 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/NetworkRequest.js +1654 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/OverlayColorGenerator.js +48 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/OverlayModel.js +765 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/OverlayPersistentHighlighter.js +384 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/PageLoad.js +25 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/PageResourceLoader.js +310 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/PaintProfiler.js +67 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/PerformanceMetricsModel.js +62 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/PreloadingModel.js +608 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/RehydratingConnection.js +413 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/RehydratingObject.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/RemoteObject.js +908 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/Resource.js +163 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ResourceTreeModel.js +923 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/RuntimeModel.js +535 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SDKModel.js +45 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ScopeTreeCache.js +36 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ScreenCaptureModel.js +176 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/Script.js +420 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SecurityOriginManager.js +54 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ServerSentEvents.js +67 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ServerSentEventsProtocol.js +113 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ServerTiming.js +216 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ServiceWorkerCacheModel.js +271 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/ServiceWorkerManager.js +511 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMap.js +691 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMapCache.js +57 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMapFunctionRanges.js +132 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMapManager.js +201 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMapScopeChainEntry.js +156 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/SourceMapScopesInfo.js +508 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/StorageBucketsModel.js +143 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/StorageKeyManager.js +53 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/Target.js +257 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/TargetManager.js +395 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/TraceObject.js +55 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/WebAuthnModel.js +66 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/sdk-meta.js +1166 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/core/sdk/sdk.js +91 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/generated/ARIAProperties.js +2640 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/generated/Deprecation.js +384 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/generated/InspectorBackendCommands.js +1532 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/generated/SupportedCSSProperties.js +7602 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/generated/protocol.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/data_formatters/NetworkRequestFormatter.js +289 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/data_formatters/PerformanceInsightFormatter.js +995 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/data_formatters/PerformanceTraceFormatter.js +664 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/data_formatters/UnitFormatters.js +139 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/performance/AICallTree.js +377 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/performance/AIContext.js +131 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/ai_assistance/performance/AIQueries.js +149 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/CSSWorkspaceBinding.js +245 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/CompilerScriptMapping.js +486 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/ContentProviderBasedProject.js +130 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/DebuggerLanguagePlugins.js +992 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/DebuggerWorkspaceBinding.js +592 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/DefaultScriptMapping.js +112 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/FileUtils.js +186 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/LiveLocation.js +60 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/NetworkProject.js +107 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/PresentationConsoleMessageHelper.js +244 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/ResourceMapping.js +564 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/ResourceScriptMapping.js +437 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/ResourceUtils.js +87 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/SASSSourceMapping.js +182 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/StylesSourceMapping.js +268 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/TempFile.js +55 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/bindings/bindings.js +20 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/cpu_profile/CPUProfileDataModel.js +516 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/cpu_profile/ProfileTreeModel.js +89 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/cpu_profile/cpu_profile.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/crux-manager/CrUXManager.js +285 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/crux-manager/crux-manager.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/emulation/DeviceModeModel.js +775 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/emulation/EmulatedDevices.js +1706 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/emulation/emulation.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/formatter/FormatterWorkerPool.js +145 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/formatter/ScriptFormatter.js +77 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/formatter/formatter.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/geometry/GeometryImpl.js +347 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/geometry/geometry.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/logs/LogManager.js +67 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/logs/NetworkLog.js +494 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/logs/RequestResolver.js +49 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/logs/logs-meta.js +73 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/logs/logs.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/network_time_calculator/Calculator.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/network_time_calculator/NetworkTimeCalculator.js +256 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/network_time_calculator/RequestTimeRanges.js +122 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/network_time_calculator/network_time_calculator.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/source_map_scopes/FunctionCodeResolver.js +192 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/source_map_scopes/NamesResolver.js +622 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/source_map_scopes/ScopeChainModel.js +59 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/source_map_scopes/source_map_scopes.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/StackTrace.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/StackTraceImpl.js +67 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/StackTraceModel.js +97 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/Trie.js +121 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/stack_trace.js +5 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/stack_trace/stack_trace_impl.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/CodeMirrorUtils.js +32 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/ContentData.js +173 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/ContentProvider.js +30 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/StaticContentProvider.js +32 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/StreamingContentData.js +79 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/Text.js +69 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/TextCursor.js +35 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/TextRange.js +231 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/TextUtils.js +355 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/WasmDisassembly.js +68 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/text_utils/text_utils.js +14 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/EntityMapper.js +122 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/EventsSerializer.js +81 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/LanternComputationData.js +371 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/ModelImpl.js +169 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/Name.js +114 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/Processor.js +555 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/Styles.js +815 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/FilmStrip.js +44 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/MainThreadActivity.js +76 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/ScriptDuplication.js +162 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/StackTraceForEvent.js +191 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/ThirdParties.js +118 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/TraceFilter.js +50 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/TraceTree.js +599 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/extras/extras.js +10 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/AnimationFramesHandler.js +109 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/AnimationHandler.js +26 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/AsyncJSCallsHandler.js +187 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/AuctionWorkletsHandler.js +162 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/DOMStatsHandler.js +21 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/ExtensionTraceDataHandler.js +263 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/FlowsHandler.js +148 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/FramesHandler.js +485 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/GPUHandler.js +35 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/ImagePaintingHandler.js +147 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/InitiatorsHandler.js +180 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/InvalidationsHandler.js +126 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/LargestImagePaintHandler.js +85 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/LargestTextPaintHandler.js +27 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/LayerTreeHandler.js +103 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/LayoutShiftsHandler.js +449 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/MemoryHandler.js +21 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/MetaHandler.js +404 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/ModelHandlers.js +33 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/NetworkRequestsHandler.js +566 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/PageFramesHandler.js +42 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/PageLoadMetricsHandler.js +349 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/RendererHandler.js +346 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/SamplesHandler.js +260 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/ScreenshotsHandler.js +97 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/ScriptsHandler.js +276 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/SelectorStatsHandler.js +71 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/Threads.js +101 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/UserInteractionsHandler.js +317 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/UserTimingsHandler.js +183 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/WarningsHandler.js +134 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/WorkersHandler.js +33 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/handlers.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/helpers.js +163 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/handlers/types.js +1 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/Extensions.js +41 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/Network.js +102 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/SamplesIntegrator.js +495 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/SyntheticEvents.js +74 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/Timing.js +186 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/Trace.js +820 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/TreeHelpers.js +254 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/helpers/helpers.js +10 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/CLSCulprits.js +489 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/Cache.js +209 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/Common.js +340 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/DOMSize.js +181 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/DocumentLatency.js +258 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/DuplicatedJavaScript.js +90 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/FontDisplay.js +82 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/ForcedReflow.js +161 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/INPBreakdown.js +129 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/ImageDelivery.js +263 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/LCPBreakdown.js +199 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/LCPDiscovery.js +183 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/LegacyJavaScript.js +90 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/Models.js +21 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/ModernHTTP.js +200 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/NetworkDependencyTree.js +545 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/RenderBlocking.js +192 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/SlowCSSSelector.js +136 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/Statistics.js +92 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/ThirdParties.js +98 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/Viewport.js +102 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/insights.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/insights/types.js +18 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/core/LanternError.js +6 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/core/NetworkAnalyzer.js +488 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/core/core.js +5 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/graph/BaseNode.js +276 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/graph/CPUNode.js +63 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/graph/NetworkNode.js +82 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/graph/PageDependencyGraph.js +551 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/graph/graph.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/lantern.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/FirstContentfulPaint.js +136 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/Interactive.js +67 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/LargestContentfulPaint.js +68 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/MaxPotentialFID.js +48 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/Metric.js +68 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/SpeedIndex.js +101 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/TBTUtils.js +64 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/TotalBlockingTime.js +78 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/metrics/metrics.js +11 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/ConnectionPool.js +115 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/Constants.js +42 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/DNSCache.js +47 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/SimulationTimingMap.js +134 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/Simulator.js +450 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/TCPConnection.js +154 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/simulation/simulation.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/types/Lantern.js +24 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/lantern/types/types.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/trace.js +17 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/Configuration.js +18 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/Extensions.js +37 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/File.js +57 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/Overlays.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/Timing.js +15 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/TraceEvents.js +580 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace/types/types.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace_source_maps_resolver/SourceMapsResolver.js +224 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/FileManager.js +64 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/IgnoreListManager.js +504 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/SearchConfig.js +113 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/UISourceCode.js +601 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/WorkspaceImpl.js +201 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/workspace-meta.js +34 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/models/workspace/workspace.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/codemirror.next/codemirror.next.js +1 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/legacy-javascript/LICENSE +202 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/legacy-javascript/legacy-javascript.js +2 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +940 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/LICENSE +26 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +196 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +226 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/codec.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +394 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +24 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +283 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/mod.js +7 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/util.js +9 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +84 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/LICENSE +20 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/lib/nostats-subset.js +146 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +2 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/httparchive-subset.js +2 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +118 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +40 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/entities.test.js +26 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/index.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/index.test.js +215 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +4 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/package/nostats-subset.js +2 -0
- package/build/node_modules/chrome-devtools-frontend/front_end/third_party/third-party-web/third-party-web.js +2 -0
- package/build/src/McpContext.js +400 -0
- package/build/src/McpResponse.js +237 -0
- package/build/src/Mutex.js +40 -0
- package/build/src/PageCollector.js +68 -0
- package/build/src/WaitForHelper.js +134 -0
- package/build/src/browser-connection-manager.js +373 -0
- package/build/src/browser.js +719 -0
- package/build/src/cli.js +120 -0
- package/build/src/client-detector.js +93 -0
- package/build/src/config.js +38 -0
- package/build/src/formatters/consoleFormatter.js +73 -0
- package/build/src/formatters/extensionsPageFormatter.js +184 -0
- package/build/src/formatters/networkFormatter.js +34 -0
- package/build/src/formatters/snapshotFormatter.js +80 -0
- package/build/src/graceful.js +125 -0
- package/build/src/index.js +13 -0
- package/build/src/logger.js +27 -0
- package/build/src/login-helper.js +431 -0
- package/build/src/main.js +268 -0
- package/build/src/plugin-api.js +189 -0
- package/build/src/profile-migration.js +82 -0
- package/build/src/profile-resolver.js +555 -0
- package/build/src/project-detector.js +71 -0
- package/build/src/project-root-state.js +18 -0
- package/build/src/roots-manager.js +253 -0
- package/build/src/selectors/chatgpt.json +61 -0
- package/build/src/selectors/gemini.json +24 -0
- package/build/src/selectors/loader.js +128 -0
- package/build/src/stable-identity.js +193 -0
- package/build/src/startup-check.js +147 -0
- package/build/src/system-profile.js +181 -0
- package/build/src/tools/ToolDefinition.js +9 -0
- package/build/src/tools/bookmarks.js +170 -0
- package/build/src/tools/categories.js +15 -0
- package/build/src/tools/chatgpt-web.js +507 -0
- package/build/src/tools/console.js +19 -0
- package/build/src/tools/core-tools.js +65 -0
- package/build/src/tools/diagnose-ui.js +328 -0
- package/build/src/tools/emulation.js +67 -0
- package/build/src/tools/extensions.js +185 -0
- package/build/src/tools/gemini-web.js +491 -0
- package/build/src/tools/iframe-popup-tools.js +204 -0
- package/build/src/tools/input.js +185 -0
- package/build/src/tools/network.js +68 -0
- package/build/src/tools/optional-tools.js +69 -0
- package/build/src/tools/pages.js +172 -0
- package/build/src/tools/performance.js +127 -0
- package/build/src/tools/screenshot.js +48 -0
- package/build/src/tools/script.js +39 -0
- package/build/src/tools/snapshot.js +45 -0
- package/build/src/trace-processing/parse.js +93 -0
- package/build/src/utils/pagination.js +49 -0
- package/package.json +90 -0
- package/scripts/cli.mjs +49 -0
|
@@ -0,0 +1,566 @@
|
|
|
1
|
+
// Copyright 2022 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
|
+
import * as Platform from '../../../core/platform/platform.js';
|
|
5
|
+
import * as Helpers from '../helpers/helpers.js';
|
|
6
|
+
import * as Types from '../types/types.js';
|
|
7
|
+
import * as HandlerHelpers from './helpers.js';
|
|
8
|
+
import { data as metaHandlerData } from './MetaHandler.js';
|
|
9
|
+
const MILLISECONDS_TO_MICROSECONDS = 1000;
|
|
10
|
+
const SECONDS_TO_MICROSECONDS = 1000000;
|
|
11
|
+
let webSocketData = new Map();
|
|
12
|
+
let linkPreconnectEvents = [];
|
|
13
|
+
let requestMap = new Map();
|
|
14
|
+
let requestsById = new Map();
|
|
15
|
+
let requestsByTime = [];
|
|
16
|
+
let networkRequestEventByInitiatorUrl = new Map();
|
|
17
|
+
let eventToInitiatorMap = new Map();
|
|
18
|
+
/**
|
|
19
|
+
* These are to store ThirdParty data relationships between entities and events. To reduce iterating through data
|
|
20
|
+
* more than we have to, here we start building the caches. After this, the RendererHandler will update
|
|
21
|
+
* the relationships. When handling ThirdParty references, use the one in the RendererHandler instead.
|
|
22
|
+
*/
|
|
23
|
+
let entityMappings = {
|
|
24
|
+
eventsByEntity: new Map(),
|
|
25
|
+
entityByEvent: new Map(),
|
|
26
|
+
createdEntityCache: new Map(),
|
|
27
|
+
entityByUrlCache: new Map(),
|
|
28
|
+
};
|
|
29
|
+
function storeTraceEventWithRequestId(requestId, key, value) {
|
|
30
|
+
if (!requestMap.has(requestId)) {
|
|
31
|
+
requestMap.set(requestId, {});
|
|
32
|
+
}
|
|
33
|
+
const traceEvents = requestMap.get(requestId);
|
|
34
|
+
if (!traceEvents) {
|
|
35
|
+
throw new Error(`Unable to locate trace events for request ID ${requestId}`);
|
|
36
|
+
}
|
|
37
|
+
if (Array.isArray(traceEvents[key])) {
|
|
38
|
+
const target = traceEvents[key];
|
|
39
|
+
const values = value;
|
|
40
|
+
target.push(...values);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
traceEvents[key] = value;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
function firstPositiveValueInList(entries) {
|
|
47
|
+
for (const entry of entries) {
|
|
48
|
+
if (entry && entry > 0) {
|
|
49
|
+
return entry;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
// In the event we don't find a positive value, we return 0 so as to
|
|
53
|
+
// be a mathematical noop. It's typically not correct to return – say –
|
|
54
|
+
// a -1 here because it would affect the calculation of stats below.
|
|
55
|
+
return 0;
|
|
56
|
+
}
|
|
57
|
+
export function reset() {
|
|
58
|
+
requestsById = new Map();
|
|
59
|
+
requestMap = new Map();
|
|
60
|
+
requestsByTime = [];
|
|
61
|
+
networkRequestEventByInitiatorUrl = new Map();
|
|
62
|
+
eventToInitiatorMap = new Map();
|
|
63
|
+
webSocketData = new Map();
|
|
64
|
+
entityMappings = {
|
|
65
|
+
eventsByEntity: new Map(),
|
|
66
|
+
entityByEvent: new Map(),
|
|
67
|
+
createdEntityCache: new Map(),
|
|
68
|
+
entityByUrlCache: new Map(),
|
|
69
|
+
};
|
|
70
|
+
linkPreconnectEvents = [];
|
|
71
|
+
}
|
|
72
|
+
export function handleEvent(event) {
|
|
73
|
+
if (Types.Events.isResourceChangePriority(event)) {
|
|
74
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'changePriority', event);
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
if (Types.Events.isResourceWillSendRequest(event)) {
|
|
78
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'willSendRequests', [event]);
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
if (Types.Events.isResourceSendRequest(event)) {
|
|
82
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'sendRequests', [event]);
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (Types.Events.isResourceReceiveResponse(event)) {
|
|
86
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'receiveResponse', event);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
if (Types.Events.isResourceReceivedData(event)) {
|
|
90
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'receivedData', [event]);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (Types.Events.isResourceFinish(event)) {
|
|
94
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'resourceFinish', event);
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
if (Types.Events.isResourceMarkAsCached(event)) {
|
|
98
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'resourceMarkAsCached', event);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
if (Types.Events.isPreloadRenderBlockingStatusChangeEvent(event)) {
|
|
102
|
+
storeTraceEventWithRequestId(event.args.data.requestId, 'preloadRenderBlockingStatusChange', [event]);
|
|
103
|
+
}
|
|
104
|
+
if (Types.Events.isWebSocketCreate(event) || Types.Events.isWebSocketInfo(event) ||
|
|
105
|
+
Types.Events.isWebSocketTransfer(event)) {
|
|
106
|
+
const identifier = event.args.data.identifier;
|
|
107
|
+
if (!webSocketData.has(identifier)) {
|
|
108
|
+
if (event.args.data.frame) {
|
|
109
|
+
webSocketData.set(identifier, {
|
|
110
|
+
frame: event.args.data.frame,
|
|
111
|
+
webSocketIdentifier: identifier,
|
|
112
|
+
events: [],
|
|
113
|
+
syntheticConnection: null,
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
else if (event.args.data.workerId) {
|
|
117
|
+
webSocketData.set(identifier, {
|
|
118
|
+
workerId: event.args.data.workerId,
|
|
119
|
+
webSocketIdentifier: identifier,
|
|
120
|
+
events: [],
|
|
121
|
+
syntheticConnection: null,
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
webSocketData.get(identifier)?.events.push(event);
|
|
126
|
+
}
|
|
127
|
+
if (Types.Events.isLinkPreconnect(event)) {
|
|
128
|
+
linkPreconnectEvents.push(event);
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
export async function finalize() {
|
|
133
|
+
const { rendererProcessesByFrame } = metaHandlerData();
|
|
134
|
+
for (const [requestId, request] of requestMap.entries()) {
|
|
135
|
+
// If we have an incomplete set of events here, we choose to drop the network
|
|
136
|
+
// request rather than attempt to synthesize the missing data.
|
|
137
|
+
if (!request.sendRequests) {
|
|
138
|
+
continue;
|
|
139
|
+
}
|
|
140
|
+
// In the data we may get multiple willSendRequests and sendRequests, which
|
|
141
|
+
// will indicate that there are redirects for a given (sub)resource. In the
|
|
142
|
+
// case of a navigation, e.g., example.com/ we will get willSendRequests,
|
|
143
|
+
// and we should use these to calculate time spent in redirects.
|
|
144
|
+
// In the case of sub-resources, however, e.g., example.com/foo.js we will
|
|
145
|
+
// *only* get sendRequests, and we use these instead of willSendRequests
|
|
146
|
+
// to detect the time in redirects. We always use the sendRequest for the
|
|
147
|
+
// url, priority etc since it contains those values, but we use the
|
|
148
|
+
// willSendRequest (if it exists) to calculate the timestamp and durations
|
|
149
|
+
// of redirects.
|
|
150
|
+
const redirects = [];
|
|
151
|
+
for (let i = 0; i < request.sendRequests.length - 1; i++) {
|
|
152
|
+
const sendRequest = request.sendRequests[i];
|
|
153
|
+
const nextSendRequest = request.sendRequests[i + 1];
|
|
154
|
+
// Use the willSendRequests as the source for redirects if possible.
|
|
155
|
+
// We default to those of the sendRequests, however, since willSendRequest
|
|
156
|
+
// is not guaranteed to be present in the data for every request.
|
|
157
|
+
let ts = sendRequest.ts;
|
|
158
|
+
let dur = Types.Timing.Micro(nextSendRequest.ts - sendRequest.ts);
|
|
159
|
+
if (request.willSendRequests?.[i] && request.willSendRequests[i + 1]) {
|
|
160
|
+
const willSendRequest = request.willSendRequests[i];
|
|
161
|
+
const nextWillSendRequest = request.willSendRequests[i + 1];
|
|
162
|
+
ts = willSendRequest.ts;
|
|
163
|
+
dur = Types.Timing.Micro(nextWillSendRequest.ts - willSendRequest.ts);
|
|
164
|
+
}
|
|
165
|
+
redirects.push({
|
|
166
|
+
url: sendRequest.args.data.url,
|
|
167
|
+
priority: sendRequest.args.data.priority,
|
|
168
|
+
requestMethod: sendRequest.args.data.requestMethod,
|
|
169
|
+
ts,
|
|
170
|
+
dur,
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
const firstSendRequest = request.sendRequests[0];
|
|
174
|
+
const finalSendRequest = request.sendRequests[request.sendRequests.length - 1];
|
|
175
|
+
// We currently do not want to include data URI requests. We may revisit this in the future.
|
|
176
|
+
if (finalSendRequest.args.data.url.startsWith('data:')) {
|
|
177
|
+
continue;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* LR loses transfer size information, but passes it in the 'X-TotalFetchedSize' header.
|
|
181
|
+
* 'X-TotalFetchedSize' is the canonical transfer size in LR.
|
|
182
|
+
*
|
|
183
|
+
* In Lightrider, due to instrumentation limitations, our values for encodedDataLength are bogus
|
|
184
|
+
* and not valid. However the resource's true encodedDataLength/transferSize is shared via a
|
|
185
|
+
* special response header, X-TotalFetchedSize. In this situation, we read this value from
|
|
186
|
+
* responseReceived, use it for the transferSize and ignore the original encodedDataLength values.
|
|
187
|
+
*/
|
|
188
|
+
// @ts-expect-error
|
|
189
|
+
const isLightrider = globalThis.isLightrider;
|
|
190
|
+
if (isLightrider && request.resourceFinish && request.receiveResponse?.args.data.headers) {
|
|
191
|
+
const lrSizeHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-TotalFetchedSize');
|
|
192
|
+
if (lrSizeHeader) {
|
|
193
|
+
const size = parseFloat(lrSizeHeader.value);
|
|
194
|
+
if (!isNaN(size)) {
|
|
195
|
+
request.resourceFinish.args.data.encodedDataLength = size;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
// If a ResourceFinish event with an encoded data length is received,
|
|
200
|
+
// then the resource was not cached; it was fetched before it was
|
|
201
|
+
// requested, e.g. because it was pushed in this navigation.
|
|
202
|
+
const isPushedResource = request.resourceFinish?.args.data.encodedDataLength !== 0;
|
|
203
|
+
// This works around crbug.com/998397, which reports pushed resources, and resources served by a service worker as disk cached.
|
|
204
|
+
const isDiskCached = !!request.receiveResponse && request.receiveResponse.args.data.fromCache &&
|
|
205
|
+
!request.receiveResponse.args.data.fromServiceWorker && !isPushedResource;
|
|
206
|
+
// If the request contains a resourceMarkAsCached event, it was served from memory cache.
|
|
207
|
+
// The timing data returned is from the original (uncached) request, which
|
|
208
|
+
// means that if we leave the above network record data as-is when the
|
|
209
|
+
// request came from either the disk cache or memory cache, our calculations
|
|
210
|
+
// will be incorrect.
|
|
211
|
+
//
|
|
212
|
+
// So we use this flag so when we calculate the timestamps of the various
|
|
213
|
+
// events, we can overwrite them.
|
|
214
|
+
// These timestamps may not be perfect (indeed they don't always match
|
|
215
|
+
// the Network CDP domain exactly, which is likely an artifact of the way
|
|
216
|
+
// the data is routed on the backend), but they're the closest we have.
|
|
217
|
+
const isMemoryCached = request.resourceMarkAsCached !== undefined;
|
|
218
|
+
// If a request has `resourceMarkAsCached` field, the `timing` field is not correct.
|
|
219
|
+
// So let's discard it and override to 0 (which will be handled in later logic if timing field is undefined).
|
|
220
|
+
let timing = isMemoryCached ? undefined : request.receiveResponse?.args.data.timing;
|
|
221
|
+
/**
|
|
222
|
+
* LR gets additional, accurate timing information from its underlying fetch infrastructure. This
|
|
223
|
+
* is passed in via X-Headers similar to 'X-TotalFetchedSize'.
|
|
224
|
+
*
|
|
225
|
+
* See `_updateTimingsForLightrider` in Lighthouse for more detail.
|
|
226
|
+
*/
|
|
227
|
+
let lrServerResponseTime;
|
|
228
|
+
if (isLightrider && request.receiveResponse?.args.data.headers) {
|
|
229
|
+
timing = {
|
|
230
|
+
requestTime: Helpers.Timing.microToSeconds(request.sendRequests.at(0)?.ts ?? 0),
|
|
231
|
+
connectEnd: 0,
|
|
232
|
+
connectStart: 0,
|
|
233
|
+
dnsEnd: 0,
|
|
234
|
+
dnsStart: 0,
|
|
235
|
+
proxyEnd: 0,
|
|
236
|
+
proxyStart: 0,
|
|
237
|
+
pushEnd: 0,
|
|
238
|
+
pushStart: 0,
|
|
239
|
+
receiveHeadersEnd: 0,
|
|
240
|
+
receiveHeadersStart: 0,
|
|
241
|
+
sendEnd: 0,
|
|
242
|
+
sendStart: 0,
|
|
243
|
+
sslEnd: 0,
|
|
244
|
+
sslStart: 0,
|
|
245
|
+
workerReady: 0,
|
|
246
|
+
workerStart: 0,
|
|
247
|
+
...timing,
|
|
248
|
+
};
|
|
249
|
+
const TCPMsHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-TCPMs');
|
|
250
|
+
const TCPMs = TCPMsHeader ? Math.max(0, parseInt(TCPMsHeader.value, 10)) : 0;
|
|
251
|
+
if (request.receiveResponse.args.data.protocol.startsWith('h3')) {
|
|
252
|
+
timing.connectStart = 0;
|
|
253
|
+
timing.connectEnd = TCPMs;
|
|
254
|
+
}
|
|
255
|
+
else {
|
|
256
|
+
timing.connectStart = 0;
|
|
257
|
+
timing.sslStart = TCPMs / 2;
|
|
258
|
+
timing.connectEnd = TCPMs;
|
|
259
|
+
timing.sslEnd = TCPMs;
|
|
260
|
+
}
|
|
261
|
+
// Lightrider does not have any equivalent for `sendEnd` timing values. The
|
|
262
|
+
// closest we can get to the server response time is from a header that
|
|
263
|
+
// Lightrider sets.
|
|
264
|
+
const ResponseMsHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-ResponseMs');
|
|
265
|
+
if (ResponseMsHeader) {
|
|
266
|
+
lrServerResponseTime = Math.max(0, parseInt(ResponseMsHeader.value, 10));
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
// TODO: consider allowing chrome / about.
|
|
270
|
+
const allowedProtocols = [
|
|
271
|
+
'blob:',
|
|
272
|
+
'file:',
|
|
273
|
+
'filesystem:',
|
|
274
|
+
'http:',
|
|
275
|
+
'https:',
|
|
276
|
+
];
|
|
277
|
+
if (!allowedProtocols.some(p => firstSendRequest.args.data.url.startsWith(p))) {
|
|
278
|
+
continue;
|
|
279
|
+
}
|
|
280
|
+
const initialPriority = finalSendRequest.args.data.priority;
|
|
281
|
+
let finalPriority = initialPriority;
|
|
282
|
+
if (request.changePriority) {
|
|
283
|
+
finalPriority = request.changePriority.args.data.priority;
|
|
284
|
+
}
|
|
285
|
+
// Network timings are complicated.
|
|
286
|
+
// https://raw.githubusercontent.com/GoogleChrome/lighthouse/main/docs/Network-Timings.svg is generally correct, but.. less so for navigations/redirects/etc.
|
|
287
|
+
// Start time
|
|
288
|
+
// =======================
|
|
289
|
+
// The time where the request started, which is either the first willSendRequest
|
|
290
|
+
// event if there is one, or, if there is not, the sendRequest.
|
|
291
|
+
const startTime = (request.willSendRequests?.length) ? Types.Timing.Micro(request.willSendRequests[0].ts) :
|
|
292
|
+
Types.Timing.Micro(firstSendRequest.ts);
|
|
293
|
+
// End redirect time
|
|
294
|
+
// =======================
|
|
295
|
+
// It's possible that when we start requesting data we will receive redirections.
|
|
296
|
+
// Here we note the time of the *last* willSendRequest / sendRequest event,
|
|
297
|
+
// which is used later on in the calculations for time queueing etc.
|
|
298
|
+
const endRedirectTime = (request.willSendRequests?.length) ?
|
|
299
|
+
Types.Timing.Micro(request.willSendRequests[request.willSendRequests.length - 1].ts) :
|
|
300
|
+
Types.Timing.Micro(finalSendRequest.ts);
|
|
301
|
+
// Finish time and end time
|
|
302
|
+
// =======================
|
|
303
|
+
// The finish time and the end time are subtly different.
|
|
304
|
+
// - Finish time: records the point at which the network stack stopped receiving the data
|
|
305
|
+
// - End time: the timestamp of the finish event itself (if one exists)
|
|
306
|
+
//
|
|
307
|
+
// The end time, then, will be slightly after the finish time.
|
|
308
|
+
const endTime = request.resourceFinish ? request.resourceFinish.ts : endRedirectTime;
|
|
309
|
+
const finishTime = request.resourceFinish?.args.data.finishTime ?
|
|
310
|
+
Types.Timing.Micro(request.resourceFinish.args.data.finishTime * SECONDS_TO_MICROSECONDS) :
|
|
311
|
+
Types.Timing.Micro(endTime);
|
|
312
|
+
// Network duration
|
|
313
|
+
// =======================
|
|
314
|
+
// Time spent on the network.
|
|
315
|
+
const networkDuration = Types.Timing.Micro(timing ? (finishTime || endRedirectTime) - endRedirectTime : 0);
|
|
316
|
+
// Processing duration
|
|
317
|
+
// =======================
|
|
318
|
+
// Time spent from start to end.
|
|
319
|
+
const processingDuration = Types.Timing.Micro(endTime - (finishTime || endTime));
|
|
320
|
+
// Redirection duration
|
|
321
|
+
// =======================
|
|
322
|
+
// Time between the first willSendRequest / sendRequest and last. This we place in *front* of the
|
|
323
|
+
// queueing, since the queueing time that we know about from the trace data is only the last request,
|
|
324
|
+
// i.e., the one that occurs after all the redirects.
|
|
325
|
+
const redirectionDuration = Types.Timing.Micro(endRedirectTime - startTime);
|
|
326
|
+
// Queueing
|
|
327
|
+
// =======================
|
|
328
|
+
// The amount of time queueing is the time between the request's start time to the requestTime
|
|
329
|
+
// arg recorded in the receiveResponse event. In the cases where the recorded start time is larger
|
|
330
|
+
// that the requestTime we set queueing time to zero.
|
|
331
|
+
const queueingFromTraceData = timing ? timing.requestTime * SECONDS_TO_MICROSECONDS - endRedirectTime : 0;
|
|
332
|
+
const queueing = Types.Timing.Micro(Platform.NumberUtilities.clamp(queueingFromTraceData, 0, Number.MAX_VALUE));
|
|
333
|
+
// Stalled
|
|
334
|
+
// =======================
|
|
335
|
+
// If the request is cached, the amount of time stalled is the time between the start time and
|
|
336
|
+
// receiving a response.
|
|
337
|
+
// Otherwise it is whichever positive number comes first from the following timing info:
|
|
338
|
+
// DNS start, Connection start, Send Start, or the time duration between our start time and
|
|
339
|
+
// receiving a response.
|
|
340
|
+
const stalled = timing ?
|
|
341
|
+
Types.Timing.Micro(firstPositiveValueInList([
|
|
342
|
+
timing.dnsStart * MILLISECONDS_TO_MICROSECONDS,
|
|
343
|
+
timing.connectStart * MILLISECONDS_TO_MICROSECONDS,
|
|
344
|
+
timing.sendStart * MILLISECONDS_TO_MICROSECONDS,
|
|
345
|
+
request.receiveResponse ? (request.receiveResponse.ts - endRedirectTime) : null,
|
|
346
|
+
])) :
|
|
347
|
+
(request.receiveResponse ? Types.Timing.Micro(request.receiveResponse.ts - startTime) : Types.Timing.Micro(0));
|
|
348
|
+
// Sending HTTP request
|
|
349
|
+
// =======================
|
|
350
|
+
// Time when the HTTP request is sent.
|
|
351
|
+
const sendStartTime = timing ?
|
|
352
|
+
Types.Timing.Micro(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.sendStart * MILLISECONDS_TO_MICROSECONDS) :
|
|
353
|
+
startTime;
|
|
354
|
+
// Waiting
|
|
355
|
+
// =======================
|
|
356
|
+
// Time from when the send finished going to when the headers were received.
|
|
357
|
+
const waiting = timing ?
|
|
358
|
+
Types.Timing.Micro((timing.receiveHeadersEnd - timing.sendEnd) * MILLISECONDS_TO_MICROSECONDS) :
|
|
359
|
+
Types.Timing.Micro(0);
|
|
360
|
+
// Server Response Time
|
|
361
|
+
// =======================
|
|
362
|
+
// Time from when the send finished going to when the first byte of headers were received.
|
|
363
|
+
const serverResponseTime = timing ?
|
|
364
|
+
Types.Timing.Micro(((timing.receiveHeadersStart ?? timing.receiveHeadersEnd) - timing.sendEnd) *
|
|
365
|
+
MILLISECONDS_TO_MICROSECONDS) :
|
|
366
|
+
Types.Timing.Micro(0);
|
|
367
|
+
// Download
|
|
368
|
+
// =======================
|
|
369
|
+
// Time from receipt of headers to the finish time.
|
|
370
|
+
const downloadStart = timing ?
|
|
371
|
+
Types.Timing.Micro(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.receiveHeadersEnd * MILLISECONDS_TO_MICROSECONDS) :
|
|
372
|
+
startTime;
|
|
373
|
+
const download = timing ? Types.Timing.Micro(((finishTime || downloadStart) - downloadStart)) :
|
|
374
|
+
request.receiveResponse ? Types.Timing.Micro(endTime - request.receiveResponse.ts) :
|
|
375
|
+
Types.Timing.Micro(0);
|
|
376
|
+
const totalTime = Types.Timing.Micro(networkDuration + processingDuration);
|
|
377
|
+
// Collect a few values from the timing info.
|
|
378
|
+
// If the Network request is cached, these fields will be zero, so the minus will zero out them.
|
|
379
|
+
const dnsLookup = timing ? Types.Timing.Micro((timing.dnsEnd - timing.dnsStart) * MILLISECONDS_TO_MICROSECONDS) :
|
|
380
|
+
Types.Timing.Micro(0);
|
|
381
|
+
const ssl = timing ? Types.Timing.Micro((timing.sslEnd - timing.sslStart) * MILLISECONDS_TO_MICROSECONDS) :
|
|
382
|
+
Types.Timing.Micro(0);
|
|
383
|
+
const proxyNegotiation = timing ?
|
|
384
|
+
Types.Timing.Micro((timing.proxyEnd - timing.proxyStart) * MILLISECONDS_TO_MICROSECONDS) :
|
|
385
|
+
Types.Timing.Micro(0);
|
|
386
|
+
const requestSent = timing ?
|
|
387
|
+
Types.Timing.Micro((timing.sendEnd - timing.sendStart) * MILLISECONDS_TO_MICROSECONDS) :
|
|
388
|
+
Types.Timing.Micro(0);
|
|
389
|
+
const initialConnection = timing ?
|
|
390
|
+
Types.Timing.Micro((timing.connectEnd - timing.connectStart) * MILLISECONDS_TO_MICROSECONDS) :
|
|
391
|
+
Types.Timing.Micro(0);
|
|
392
|
+
// Finally get some of the general data from the trace events.
|
|
393
|
+
const { frame, url, renderBlocking: sendRequestIsRenderBlocking } = finalSendRequest.args.data;
|
|
394
|
+
const { encodedDataLength, decodedBodyLength } = request.resourceFinish ? request.resourceFinish.args.data : { encodedDataLength: 0, decodedBodyLength: 0 };
|
|
395
|
+
const parsedUrl = new URL(url);
|
|
396
|
+
const isHttps = parsedUrl.protocol === 'https:';
|
|
397
|
+
const requestingFrameUrl = Helpers.Trace.activeURLForFrameAtTime(frame, finalSendRequest.ts, rendererProcessesByFrame) || '';
|
|
398
|
+
// A resource that is preloaded (and not marked as render blocking) can
|
|
399
|
+
// become render blocked later via a PreloadRenderBlockingStatusChange. In
|
|
400
|
+
// this case, we take the render blocking value of the last
|
|
401
|
+
// PreloadRenderBlockingStatusChange for this request.
|
|
402
|
+
const preloadRenderBlockingStatusChange = request.preloadRenderBlockingStatusChange?.at(-1)?.args.data.renderBlocking;
|
|
403
|
+
// In the event the property isn't set, assume non-blocking.
|
|
404
|
+
const isRenderBlocking = preloadRenderBlockingStatusChange ?? sendRequestIsRenderBlocking ?? 'non_blocking';
|
|
405
|
+
// Construct a synthetic trace event for this network request.
|
|
406
|
+
const networkEvent = Helpers.SyntheticEvents.SyntheticEventsManager.registerSyntheticEvent({
|
|
407
|
+
rawSourceEvent: finalSendRequest,
|
|
408
|
+
args: {
|
|
409
|
+
data: {
|
|
410
|
+
// All data we create from trace events should be added to |syntheticData|.
|
|
411
|
+
syntheticData: {
|
|
412
|
+
dnsLookup,
|
|
413
|
+
download,
|
|
414
|
+
downloadStart,
|
|
415
|
+
finishTime,
|
|
416
|
+
initialConnection,
|
|
417
|
+
isDiskCached,
|
|
418
|
+
isHttps,
|
|
419
|
+
isMemoryCached,
|
|
420
|
+
isPushedResource,
|
|
421
|
+
networkDuration,
|
|
422
|
+
processingDuration,
|
|
423
|
+
proxyNegotiation,
|
|
424
|
+
queueing,
|
|
425
|
+
redirectionDuration,
|
|
426
|
+
requestSent,
|
|
427
|
+
sendStartTime,
|
|
428
|
+
ssl,
|
|
429
|
+
stalled,
|
|
430
|
+
totalTime,
|
|
431
|
+
waiting,
|
|
432
|
+
serverResponseTime,
|
|
433
|
+
},
|
|
434
|
+
// All fields below are from TraceEventsForNetworkRequest.
|
|
435
|
+
decodedBodyLength,
|
|
436
|
+
encodedDataLength,
|
|
437
|
+
frame,
|
|
438
|
+
fromServiceWorker: request.receiveResponse?.args.data.fromServiceWorker,
|
|
439
|
+
isLinkPreload: finalSendRequest.args.data.isLinkPreload || false,
|
|
440
|
+
mimeType: request.receiveResponse?.args.data.mimeType ?? '',
|
|
441
|
+
priority: finalPriority,
|
|
442
|
+
initialPriority,
|
|
443
|
+
protocol: request.receiveResponse?.args.data.protocol ?? 'unknown',
|
|
444
|
+
redirects,
|
|
445
|
+
renderBlocking: isRenderBlocking,
|
|
446
|
+
requestId,
|
|
447
|
+
requestingFrameUrl,
|
|
448
|
+
requestMethod: finalSendRequest.args.data.requestMethod,
|
|
449
|
+
resourceType: finalSendRequest.args.data.resourceType ?? "Other" /* Protocol.Network.ResourceType.Other */,
|
|
450
|
+
statusCode: request.receiveResponse?.args.data.statusCode ?? 0,
|
|
451
|
+
responseHeaders: request.receiveResponse?.args.data.headers ?? null,
|
|
452
|
+
fetchPriorityHint: finalSendRequest.args.data.fetchPriorityHint ?? 'auto',
|
|
453
|
+
initiator: finalSendRequest.args.data.initiator,
|
|
454
|
+
stackTrace: finalSendRequest.args.data.stackTrace,
|
|
455
|
+
timing,
|
|
456
|
+
lrServerResponseTime,
|
|
457
|
+
url,
|
|
458
|
+
failed: request.resourceFinish?.args.data.didFail ?? false,
|
|
459
|
+
finished: Boolean(request.resourceFinish),
|
|
460
|
+
hasResponse: Boolean(request.receiveResponse),
|
|
461
|
+
connectionId: request.receiveResponse?.args.data.connectionId,
|
|
462
|
+
connectionReused: request.receiveResponse?.args.data.connectionReused,
|
|
463
|
+
},
|
|
464
|
+
},
|
|
465
|
+
cat: 'loading',
|
|
466
|
+
name: "SyntheticNetworkRequest" /* Types.Events.Name.SYNTHETIC_NETWORK_REQUEST */,
|
|
467
|
+
ph: "X" /* Types.Events.Phase.COMPLETE */,
|
|
468
|
+
dur: Types.Timing.Micro(endTime - startTime),
|
|
469
|
+
tdur: Types.Timing.Micro(endTime - startTime),
|
|
470
|
+
ts: Types.Timing.Micro(startTime),
|
|
471
|
+
tts: Types.Timing.Micro(startTime),
|
|
472
|
+
pid: finalSendRequest.pid,
|
|
473
|
+
tid: finalSendRequest.tid,
|
|
474
|
+
});
|
|
475
|
+
// However, there are also times where we just want to loop through all
|
|
476
|
+
// the captured requests, so here we store all of them together.
|
|
477
|
+
requestsByTime.push(networkEvent);
|
|
478
|
+
requestsById.set(networkEvent.args.data.requestId, networkEvent);
|
|
479
|
+
// Update entity relationships for network events
|
|
480
|
+
HandlerHelpers.addNetworkRequestToEntityMapping(networkEvent, entityMappings, request);
|
|
481
|
+
// Establish initiator relationships
|
|
482
|
+
const initiatorUrl = networkEvent.args.data.initiator?.url ||
|
|
483
|
+
Helpers.Trace.getStackTraceTopCallFrameInEventPayload(networkEvent)?.url;
|
|
484
|
+
if (initiatorUrl) {
|
|
485
|
+
const events = networkRequestEventByInitiatorUrl.get(initiatorUrl) ?? [];
|
|
486
|
+
events.push(networkEvent);
|
|
487
|
+
networkRequestEventByInitiatorUrl.set(initiatorUrl, events);
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
for (const request of requestsByTime) {
|
|
491
|
+
const initiatedEvents = networkRequestEventByInitiatorUrl.get(request.args.data.url);
|
|
492
|
+
if (initiatedEvents) {
|
|
493
|
+
for (const initiatedEvent of initiatedEvents) {
|
|
494
|
+
eventToInitiatorMap.set(initiatedEvent, request);
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
finalizeWebSocketData();
|
|
499
|
+
}
|
|
500
|
+
export function data() {
|
|
501
|
+
return {
|
|
502
|
+
byId: requestsById,
|
|
503
|
+
byTime: requestsByTime,
|
|
504
|
+
eventToInitiator: eventToInitiatorMap,
|
|
505
|
+
webSocket: [...webSocketData.values()],
|
|
506
|
+
entityMappings: {
|
|
507
|
+
entityByEvent: entityMappings.entityByEvent,
|
|
508
|
+
eventsByEntity: entityMappings.eventsByEntity,
|
|
509
|
+
createdEntityCache: entityMappings.createdEntityCache,
|
|
510
|
+
entityByUrlCache: entityMappings.entityByUrlCache,
|
|
511
|
+
},
|
|
512
|
+
linkPreconnectEvents,
|
|
513
|
+
};
|
|
514
|
+
}
|
|
515
|
+
export function deps() {
|
|
516
|
+
return ['Meta'];
|
|
517
|
+
}
|
|
518
|
+
function finalizeWebSocketData() {
|
|
519
|
+
// for each WebSocketTraceData in webSocketData map, we create a synthetic event
|
|
520
|
+
// to represent the entire WebSocket connection. This is done by finding the start and end event
|
|
521
|
+
// if they exist, and if they don't, we use the first event in the list for start, and the traceBounds.max
|
|
522
|
+
// for the end. So each WebSocketTraceData will have
|
|
523
|
+
// {
|
|
524
|
+
// events: the list of WebSocket events
|
|
525
|
+
// syntheticConnection: the synthetic event representing the entire WebSocket connection
|
|
526
|
+
// }
|
|
527
|
+
webSocketData.forEach(data => {
|
|
528
|
+
let startEvent = null;
|
|
529
|
+
let endEvent = null;
|
|
530
|
+
for (const event of data.events) {
|
|
531
|
+
if (Types.Events.isWebSocketCreate(event)) {
|
|
532
|
+
startEvent = event;
|
|
533
|
+
}
|
|
534
|
+
if (Types.Events.isWebSocketDestroy(event)) {
|
|
535
|
+
endEvent = event;
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
data.syntheticConnection = createSyntheticWebSocketConnection(startEvent, endEvent, data.events[0]);
|
|
539
|
+
});
|
|
540
|
+
}
|
|
541
|
+
function createSyntheticWebSocketConnection(startEvent, endEvent, firstRecordedEvent) {
|
|
542
|
+
const { traceBounds } = metaHandlerData();
|
|
543
|
+
const startTs = startEvent ? startEvent.ts : traceBounds.min;
|
|
544
|
+
const endTs = endEvent ? endEvent.ts : traceBounds.max;
|
|
545
|
+
const duration = endTs - startTs;
|
|
546
|
+
const mainEvent = startEvent || endEvent || firstRecordedEvent;
|
|
547
|
+
return {
|
|
548
|
+
name: 'SyntheticWebSocketConnection',
|
|
549
|
+
cat: mainEvent.cat,
|
|
550
|
+
ph: "X" /* Types.Events.Phase.COMPLETE */,
|
|
551
|
+
ts: startTs,
|
|
552
|
+
dur: duration,
|
|
553
|
+
pid: mainEvent.pid,
|
|
554
|
+
tid: mainEvent.tid,
|
|
555
|
+
s: mainEvent.s,
|
|
556
|
+
rawSourceEvent: mainEvent,
|
|
557
|
+
_tag: 'SyntheticEntryTag',
|
|
558
|
+
args: {
|
|
559
|
+
data: {
|
|
560
|
+
identifier: mainEvent.args.data.identifier,
|
|
561
|
+
priority: "Low" /* Protocol.Network.ResourcePriority.Low */,
|
|
562
|
+
url: mainEvent.args.data.url || '',
|
|
563
|
+
},
|
|
564
|
+
},
|
|
565
|
+
};
|
|
566
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// Copyright 2024 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
|
+
import * as Types from '../types/types.js';
|
|
5
|
+
let frames = new Map();
|
|
6
|
+
export function reset() {
|
|
7
|
+
frames = new Map();
|
|
8
|
+
}
|
|
9
|
+
export function handleEvent(event) {
|
|
10
|
+
if (Types.Events.isTracingStartedInBrowser(event)) {
|
|
11
|
+
for (const frame of event.args.data?.frames ?? []) {
|
|
12
|
+
// The ID of a frame is stored under the `frame` key.
|
|
13
|
+
frames.set(frame.frame, frame);
|
|
14
|
+
}
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
// CommitLoad events can contain an updated URL or Name for a frame.
|
|
18
|
+
if (Types.Events.isCommitLoad(event)) {
|
|
19
|
+
const frameData = event.args.data;
|
|
20
|
+
if (!frameData) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
// We don't want to mutate the original object, hence why
|
|
24
|
+
// we set a new object from the new and existing values.
|
|
25
|
+
const frame = frames.get(frameData.frame);
|
|
26
|
+
if (!frame) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
frames.set(frameData.frame, {
|
|
30
|
+
...frame,
|
|
31
|
+
url: frameData.url || frame.url,
|
|
32
|
+
name: frameData.name || frameData.name,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
export async function finalize() {
|
|
37
|
+
}
|
|
38
|
+
export function data() {
|
|
39
|
+
return {
|
|
40
|
+
frames,
|
|
41
|
+
};
|
|
42
|
+
}
|