File: web_app_url_loader.h

package info (click to toggle)
chromium 135.0.7049.95-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,959,392 kB
  • sloc: cpp: 34,198,526; ansic: 7,100,035; javascript: 3,985,800; python: 1,395,489; asm: 896,754; xml: 722,891; pascal: 180,504; sh: 94,909; perl: 88,388; objc: 79,739; sql: 53,020; cs: 41,358; fortran: 24,137; makefile: 22,501; php: 13,699; tcl: 10,142; yacc: 8,822; ruby: 7,350; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; awk: 197; sed: 36
file content (99 lines) | stat: -rw-r--r-- 3,521 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef COMPONENTS_WEBAPPS_BROWSER_WEB_CONTENTS_WEB_APP_URL_LOADER_H_
#define COMPONENTS_WEBAPPS_BROWSER_WEB_CONTENTS_WEB_APP_URL_LOADER_H_

#include "base/functional/callback_forward.h"
#include "base/memory/weak_ptr.h"
#include "base/time/time.h"
#include "content/public/browser/navigation_controller.h"

class GURL;

namespace content {
class WebContents;
}  // namespace content

namespace webapps {

// Result enum values are persisted to logs. Entries should not be renumbered
// and numeric values should never be reused. Update corresponding enums.xml
// entry when making changes here.
enum class WebAppUrlLoaderResult {
  // The provided URL (matched using |UrlComparison|) was loaded.
  kUrlLoaded = 0,
  // The provided URL redirected to another URL (that did not match using
  // |UrlComparison|) and the final URL was loaded.
  kRedirectedUrlLoaded = 1,
  kFailedUnknownReason = 2,
  kFailedPageTookTooLong = 3,
  kFailedWebContentsDestroyed = 4,
  kFailedErrorPageLoaded = 5,

  kMaxValue = kFailedErrorPageLoaded,
};

// Callback-based wrapper around NavigationController::LoadUrl.
class WebAppUrlLoader {
 public:
  // How to compare resolved URL against the given URL for the purpose of
  // determining a successful load.
  enum class UrlComparison {
    kExact,
    kIgnoreQueryParamsAndRef,
    kSameOrigin,
  };

  // Exposed for testing.
  static constexpr base::TimeDelta kSecondsToWaitForWebContentsLoad =
      base::Seconds(30);

  using Result = WebAppUrlLoaderResult;

  using ResultCallback = base::OnceCallback<void(Result)>;

  WebAppUrlLoader();
  virtual ~WebAppUrlLoader();

  // Navigates `web_contents` to about:blank, followed by navigating to `url`.
  // This prevents races with events from old contents loaded in the
  // `web_contents`. After navigating to `url`, the `url` is compared with the
  // resolved URL with `url_comparison`, and runs callback with the result code.
  virtual void LoadUrl(const GURL& url,
                       content::WebContents* web_contents,
                       UrlComparison url_comparison,
                       ResultCallback callback);

  // Navigates `web_contents` to about:blank, followed by navigating based on
  // `load_url_params`. This prevents races with events from old contents loaded
  // in the `web_contents`. Compares the resolved URL with `url_comparison`, and
  // runs callback with the result code.
  virtual void LoadUrl(
      content::NavigationController::LoadURLParams load_url_params,
      content::WebContents* web_contents,
      UrlComparison url_comparison,
      ResultCallback callback);

  // Used by LoadUrl() to put `web_contents` into a clean state, will noop if
  // called redundantly. Useful for other uses of `web_contents` e.g.
  // downloading icons.
  virtual void PrepareForLoad(content::WebContents* web_contents,
                              base::OnceClosure complete);

 private:
  void LoadUrlInternal(
      const content::NavigationController::LoadURLParams& load_url_params,
      base::WeakPtr<content::WebContents> web_contents,
      UrlComparison url_comparison,
      ResultCallback callback);

  base::WeakPtrFactory<WebAppUrlLoader> weak_factory_{this};
};

const char* ConvertUrlLoaderResultToString(WebAppUrlLoader::Result result);

}  // namespace web_app

#endif  // COMPONENTS_WEBAPPS_BROWSER_WEB_CONTENTS_WEB_APP_URL_LOADER_H_