| // Copyright 2020 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 CHROME_BROWSER_PERFORMANCE_HINTS_PERFORMANCE_HINTS_OBSERVER_H_ |
| #define CHROME_BROWSER_PERFORMANCE_HINTS_PERFORMANCE_HINTS_OBSERVER_H_ |
| |
| #include <tuple> |
| #include <utility> |
| #include <vector> |
| |
| #include "base/feature_list.h" |
| #include "base/macros.h" |
| #include "base/memory/weak_ptr.h" |
| #include "base/optional.h" |
| #include "base/sequence_checker.h" |
| #include "components/optimization_guide/optimization_guide_decider.h" |
| #include "components/optimization_guide/proto/hints.pb.h" |
| #include "components/optimization_guide/proto/performance_hints_metadata.pb.h" |
| #include "content/public/browser/web_contents_observer.h" |
| #include "content/public/browser/web_contents_user_data.h" |
| |
| namespace content { |
| class NavigationHandle; |
| class WebContents; |
| } // namespace content |
| |
| namespace optimization_guide { |
| class URLPatternWithWildcards; |
| namespace proto { |
| class PerformanceHint; |
| } // namespace proto |
| } // namespace optimization_guide |
| |
| class GURL; |
| |
| // If enabled, PerformanceHintsObserver will be added as a tab helper and will |
| // fetch performance hints. |
| extern const base::Feature kPerformanceHintsObserver; |
| // If enabled, hints of PERFORMANCE_UNKNOWN will be overridden to |
| // PERFORMANCE_FAST. This does not affect the value that is recorded via UMA. |
| extern const base::Feature kPerformanceHintsTreatUnknownAsFast; |
| |
| // Provides an interface to access PerformanceHints for the associated |
| // WebContents and links within it. |
| class PerformanceHintsObserver |
| : public content::WebContentsObserver, |
| public content::WebContentsUserData<PerformanceHintsObserver> { |
| public: |
| ~PerformanceHintsObserver() override; |
| PerformanceHintsObserver(const PerformanceHintsObserver&) = delete; |
| PerformanceHintsObserver& operator=(const PerformanceHintsObserver&) = delete; |
| |
| // Returns the PerformanceClass for |url|, or PERFORMANCE_UNKNOWN if could not |
| // be determined. |
| static optimization_guide::proto::PerformanceClass PerformanceClassForURL( |
| content::WebContents* web_contents, |
| const GURL& url); |
| |
| // Used only on Android since the java API can be called repeatedly and is |
| // not appropriate to record metrics. |
| static void RecordPerformanceUMAForURL(content::WebContents* web_contents, |
| const GURL& url); |
| |
| // Public so is accessible by Android JNI. |
| static optimization_guide::proto::PerformanceClass |
| PerformanceClassForURLInternal(content::WebContents* web_contents, |
| const GURL& url, |
| bool record_metrics); |
| |
| private: |
| explicit PerformanceHintsObserver(content::WebContents* web_contents); |
| friend class content::WebContentsUserData<PerformanceHintsObserver>; |
| friend class PerformanceHintsObserverTest; |
| |
| // content::WebContentsObserver. |
| void DidFinishNavigation( |
| content::NavigationHandle* navigation_handle) override; |
| |
| // This callback populates |hints_| with performance information for links on |
| // the current page and is called by |optimization_guide_decider_| when a |
| // definite decision has been reached. |
| void ProcessPerformanceHint( |
| optimization_guide::OptimizationGuideDecision decision, |
| const optimization_guide::OptimizationMetadata& optimization_metadata); |
| |
| // These values are logged to UMA. Entries should not be renumbered and |
| // numeric values should never be reused. Please keep in sync with |
| // "PerformanceHintsObserverHintForURLResult" in |
| // src/tools/metrics/histograms/enums.xml. |
| enum class HintForURLResult { |
| // Hints for the current page have been processed and no hint for the URL |
| // was found. |
| kHintNotFound = 0, |
| // Hints have not yet been processed. The call may be attempted again. |
| kHintNotReady = 1, |
| // An invalid URL was passed. |
| kInvalidURL = 2, |
| // A matching hint was found and has been returned. |
| kHintFound = 3, |
| kMaxValue = kHintFound, |
| }; |
| |
| // Fetches a PerformanceHint for the given |url|. |
| // |
| // Returns an enum describing the fetch outcome and, if that outcome is |
| // kHintFound, the matching PerformanceHint. See HintForURLResult, above. |
| std::tuple<HintForURLResult, |
| base::Optional<optimization_guide::proto::PerformanceHint>> |
| HintForURL(const GURL& url) const; |
| |
| // Initialized in constructor. It may be null if !IsOptimizationHintsEnabled. |
| optimization_guide::OptimizationGuideDecider* optimization_guide_decider_ = |
| nullptr; |
| |
| // URLs that match |first| should use the Performance hint in |second|. |
| std::vector<std::pair<optimization_guide::URLPatternWithWildcards, |
| optimization_guide::proto::PerformanceHint>> |
| hints_; |
| |
| // True if the ProcessPerformanceHint callback has been run. |
| bool hint_processed_ = false; |
| |
| SEQUENCE_CHECKER(sequence_checker_); |
| |
| base::WeakPtrFactory<PerformanceHintsObserver> weak_factory_{this}; |
| |
| WEB_CONTENTS_USER_DATA_KEY_DECL(); |
| }; |
| |
| #endif // CHROME_BROWSER_PERFORMANCE_HINTS_PERFORMANCE_HINTS_OBSERVER_H_ |