blob: 65d8250cbb04b272a14616d70df4d725adfee749 [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_PERFORMANCE_MANAGER_EMBEDDER_PERFORMANCE_MANAGER_REGISTRY_H_
#define COMPONENTS_PERFORMANCE_MANAGER_EMBEDDER_PERFORMANCE_MANAGER_REGISTRY_H_
#include <memory>
#include <vector>
#include "mojo/public/cpp/bindings/binder_map.h"
#include "services/service_manager/public/cpp/binder_registry.h"
namespace content {
class BrowserContext;
class RenderFrameHost;
class RenderProcessHost;
class NavigationHandle;
class NavigationThrottle;
class WebContents;
} // namespace content
namespace performance_manager {
// Allows tracking of WebContents, RenderProcessHosts and SharedWorkerInstances
// in the PerformanceManager.
//
// A process that embeds the PerformanceManager should create a single instance
// of this and notify it when WebContents, RenderProcessHosts or BrowserContexts
// are created.
//
// TearDown() must be called prior to destroying this object. This will schedule
// deletion of PageNodes, ProcessNodes and WorkerNodes retained by this
// registry, even if the associated WebContents, RenderProcessHosts and
// SharedWorkerInstances still exist.
//
// This class can only be accessed on the main thread.
class PerformanceManagerRegistry {
public:
using Throttles = std::vector<std::unique_ptr<content::NavigationThrottle>>;
virtual ~PerformanceManagerRegistry() = default;
PerformanceManagerRegistry(const PerformanceManagerRegistry&) = delete;
void operator=(const PerformanceManagerRegistry&) = delete;
// Creates a PerformanceManagerRegistry instance.
static std::unique_ptr<PerformanceManagerRegistry> Create();
// Returns the only instance of PerformanceManagerRegistry living in this
// process, or nullptr if there is none.
static PerformanceManagerRegistry* GetInstance();
// Helper function that invokes CreatePageNodeForWebContents only if it hasn't
// already been called for the provided WebContents.
void MaybeCreatePageNodeForWebContents(content::WebContents* web_contents);
// Must be invoked when a WebContents is created. Creates an associated
// PageNode in the PerformanceManager, if it doesn't already exist. This
// should only be called once for a given |web_contents|.
virtual void CreatePageNodeForWebContents(
content::WebContents* web_contents) = 0;
// Must be invoked for a NavigationHandle when it is committed, allowing the
// PM the opportunity to apply NavigationThrottles. Typically wired up to
// ContentBrowserClient::CreateThrottlesForNavigation.
virtual Throttles CreateThrottlesForNavigation(
content::NavigationHandle* handle) = 0;
// Must be invoked when a BrowserContext is added/removed.
// Registers/unregisters an observer that creates WorkerNodes when
// SharedWorkerInstances are added in the BrowserContext.
virtual void NotifyBrowserContextAdded(
content::BrowserContext* browser_context) = 0;
virtual void NotifyBrowserContextRemoved(
content::BrowserContext* browser_context) = 0;
// Must be invoked when a renderer process is starting up and interfaces are
// being exposed to it. This ensures that a process node is created for the
// RPH, and exposes the interface that allows the remote renderer process to
// bind to the corresponding ProcessNode in the graph. Typically wired up via
// ContentBrowserClient::ExposeInterfacesToRenderer.
// NOTE: Ideally we'd have a separate CreateProcessNode notification, but the
// current content architecture makes it very difficult to get this
// notification.
virtual void CreateProcessNodeAndExposeInterfacesToRendererProcess(
service_manager::BinderRegistry* registry,
content::RenderProcessHost* render_process_host) = 0;
// Must be invoked when interfaces are being exposed to a renderer frame.
// This allows the remote renderer frame to bind to its corresponding
// FrameNode in the graph. Typically wired up via
// ContentBrowserClient::RegisterBrowserInterfaceBindersForFrame.
virtual void ExposeInterfacesToRenderFrame(
mojo::BinderMapWithContext<content::RenderFrameHost*>* map) = 0;
// Must be invoked prior to destroying the object. Schedules deletion of
// PageNodes and ProcessNodes retained by this registry, even if the
// associated WebContents and RenderProcessHosts still exist.
virtual void TearDown() = 0;
protected:
PerformanceManagerRegistry() = default;
};
} // namespace performance_manager
#endif // COMPONENTS_PERFORMANCE_MANAGER_EMBEDDER_PERFORMANCE_MANAGER_REGISTRY_H_