blob: 0c2b6fa7185a17a61d92aadfa97c99f073a2928d [file] [log] [blame]
sdefresnef40c65a2014-11-13 12:25:021// Copyright 2013 The Chromium Authors. All rights reserved.
sdefresnea010b6d2014-11-12 09:32:202// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef IOS_WEB_PUBLIC_BROWSER_STATE_H_
6#define IOS_WEB_PUBLIC_BROWSER_STATE_H_
7
John Abd-El-Malek07a93f12018-02-08 19:28:258#include <memory>
9
sdefresnea010b6d2014-11-12 09:32:2010#include "base/supports_user_data.h"
Julie Jeongeun Kim17b2adf12019-10-29 10:24:4811#include "mojo/public/cpp/bindings/pending_receiver.h"
Julie Jeongeun Kimc0827552019-08-27 03:19:3712#include "mojo/public/cpp/bindings/remote.h"
Reilly Grantd055e32c2018-08-15 00:01:1813#include "services/network/public/mojom/cookie_manager.mojom.h"
Hans Wennborga61b3042021-06-15 12:06:3114#include "services/network/public/mojom/network_context.mojom.h"
Matt Menke1f2fb3732018-03-09 19:14:4715#include "services/network/public/mojom/network_service.mojom.h"
Helen Li5f3d96a2018-08-10 20:37:2416#include "services/network/public/mojom/proxy_resolving_socket.mojom.h"
Matt Menke1f2fb3732018-03-09 19:14:4717#include "services/network/public/mojom/url_loader_factory.mojom.h"
sdefresnea010b6d2014-11-12 09:32:2018
sdefresne6f95f8f2014-11-21 11:21:1019namespace base {
20class FilePath;
21}
22
sdefresnea010b6d2014-11-12 09:32:2023namespace net {
24class URLRequestContextGetter;
25}
26
John Abd-El-Malek07a93f12018-02-08 19:28:2527namespace network {
Maks Orlovichd6f27e52018-06-05 16:14:3528class SharedURLLoaderFactory;
29class WeakWrapperSharedURLLoaderFactory;
John Abd-El-Malek07a93f12018-02-08 19:28:2530} // namespace network
31
ssid9b9d6332019-08-08 17:48:2232namespace leveldb_proto {
33class ProtoDatabaseProvider;
34} // namespace leveldb_proto
35
sdefresnea010b6d2014-11-12 09:32:2036namespace web {
Robbie Gibson0abc1372020-05-15 11:29:2737enum class CookieBlockingMode;
stuartmorgand7f6a672015-03-31 22:01:1338class CertificatePolicyCache;
Maks Orlovichc71746a62018-04-27 21:52:1739class NetworkContextOwner;
stuartmorganf0e19f912015-04-29 06:01:0140class URLDataManagerIOS;
41class URLDataManagerIOSBackend;
42class URLRequestChromeJob;
sdefresnea010b6d2014-11-12 09:32:2043
44// This class holds the context needed for a browsing session.
45// It lives on the UI thread. All these methods must only be called on the UI
46// thread.
47class BrowserState : public base::SupportsUserData {
48 public:
sdefresnedb52bdf2014-11-13 09:20:3249 ~BrowserState() override;
sdefresnea010b6d2014-11-12 09:32:2050
stuartmorgand7f6a672015-03-31 22:01:1351 // static
52 static scoped_refptr<CertificatePolicyCache> GetCertificatePolicyCache(
53 BrowserState* browser_state);
54
sdefresne6f95f8f2014-11-21 11:21:1055 // Returns whether this BrowserState is incognito. Default is false.
sdefresnea010b6d2014-11-12 09:32:2056 virtual bool IsOffTheRecord() const = 0;
57
sdefresne6f95f8f2014-11-21 11:21:1058 // Returns the path where the BrowserState data is stored.
sdefresne2bbdeed2015-03-02 14:24:2659 // Unlike Profile::GetPath(), incognito BrowserState do not share their path
60 // with their original BrowserState.
61 virtual base::FilePath GetStatePath() const = 0;
sdefresne6f95f8f2014-11-21 11:21:1062
sdefresnea010b6d2014-11-12 09:32:2063 // Returns the request context information associated with this
64 // BrowserState.
65 virtual net::URLRequestContextGetter* GetRequestContext() = 0;
66
John Abd-El-Malek07a93f12018-02-08 19:28:2567 // Returns a URLLoaderFactory that is backed by GetRequestContext.
68 network::mojom::URLLoaderFactory* GetURLLoaderFactory();
69
Reilly Grantd055e32c2018-08-15 00:01:1870 // Returns a CookieManager that is backed by GetRequestContext.
71 network::mojom::CookieManager* GetCookieManager();
72
ssid9b9d6332019-08-08 17:48:2273 // Returns an provider to create ProtoDatabase tied to the profile directory.
74 leveldb_proto::ProtoDatabaseProvider* GetProtoDatabaseProvider();
75
Julie Jeongeun Kim17b2adf12019-10-29 10:24:4876 // Binds a ProxyResolvingSocketFactory receiver to NetworkContext.
Helen Li5f3d96a2018-08-10 20:37:2477 void GetProxyResolvingSocketFactory(
Julie Jeongeun Kim17b2adf12019-10-29 10:24:4878 mojo::PendingReceiver<network::mojom::ProxyResolvingSocketFactory>
79 receiver);
Helen Li5f3d96a2018-08-10 20:37:2480
Maks Orlovichd6f27e52018-06-05 16:14:3581 // Like URLLoaderFactory, but wrapped inside SharedURLLoaderFactory
Yi Su378627d2018-08-24 22:51:5782 virtual scoped_refptr<network::SharedURLLoaderFactory>
83 GetSharedURLLoaderFactory();
Maks Orlovichd6f27e52018-06-05 16:14:3584
sdefresneb30864ac2014-11-21 12:40:5285 // Safely cast a base::SupportsUserData to a BrowserState. Returns nullptr
86 // if |supports_user_data| is not a BrowserState.
87 static BrowserState* FromSupportsUserData(
88 base::SupportsUserData* supports_user_data);
89
Takashi Toyoshimacd413b42019-04-10 20:33:4690 // Updates |cors_exempt_header_list| field of the given |param| to register
91 // headers that are used in content for special purpose and should not be
92 // blocked by CORS checks.
93 virtual void UpdateCorsExemptHeader(
94 network::mojom::NetworkContextParams* params) {}
95
Robbie Gibson0abc1372020-05-15 11:29:2796 // Returns the current cookie blocking mode for this browser state.
97 CookieBlockingMode GetCookieBlockingMode() const;
98
99 // Sets the cookie blocking mode for this browser state. This will only affect
100 // WebStates that are loaded after this mode is set. WebStates with live web
101 // content will not have the mode correctly setup until they are reloaded.
Robbie Gibson283c9b82020-06-08 20:35:02102 // Some tasks here may be asynchronous, so |callback| will be called after
103 // the cookie blocking mode is set correctly. This may happen immediately.
104 void SetCookieBlockingMode(CookieBlockingMode cookie_blocking_mode,
105 base::OnceClosure callback);
Robbie Gibson0abc1372020-05-15 11:29:27106
sdefresnea010b6d2014-11-12 09:32:20107 protected:
108 BrowserState();
stuartmorganf0e19f912015-04-29 06:01:01109
110 private:
111 friend class URLDataManagerIOS;
112 friend class URLRequestChromeJob;
113
114 // Returns the URLDataManagerIOSBackend instance associated with this
115 // BrowserState, creating it if necessary. Should only be called on the IO
116 // thread.
117 // Not intended for usage outside of //web.
118 URLDataManagerIOSBackend* GetURLDataManagerIOSBackendOnIOThread();
119
Reilly Grantd055e32c2018-08-15 00:01:18120 void CreateNetworkContextIfNecessary();
Helen Li5f3d96a2018-08-10 20:37:24121
Julie Jeongeun Kim1b8bfaf2019-10-28 10:55:52122 mojo::Remote<network::mojom::URLLoaderFactory> url_loader_factory_;
Julie Jeongeun Kimc0827552019-08-27 03:19:37123 mojo::Remote<network::mojom::CookieManager> cookie_manager_;
ssid9b9d6332019-08-08 17:48:22124 std::unique_ptr<leveldb_proto::ProtoDatabaseProvider>
125 proto_database_provider_;
Maks Orlovichd6f27e52018-06-05 16:14:35126 scoped_refptr<network::WeakWrapperSharedURLLoaderFactory>
127 shared_url_loader_factory_;
Julie Jeongeun Kimbd33cf02019-09-12 04:56:23128 mojo::Remote<network::mojom::NetworkContext> network_context_;
Matt Menke1f2fb3732018-03-09 19:14:47129
130 // Owns the network::NetworkContext that backs |url_loader_factory_|. Created
131 // on the UI thread, destroyed on the IO thread.
132 std::unique_ptr<NetworkContextOwner> network_context_owner_;
John Abd-El-Malek07a93f12018-02-08 19:28:25133
stuartmorganf0e19f912015-04-29 06:01:01134 // The URLDataManagerIOSBackend instance associated with this BrowserState.
135 // Created and destroyed on the IO thread, and should be accessed only from
136 // the IO thread.
137 URLDataManagerIOSBackend* url_data_manager_ios_backend_;
Robbie Gibson0abc1372020-05-15 11:29:27138
139 CookieBlockingMode cookie_blocking_mode_;
sdefresnea010b6d2014-11-12 09:32:20140};
141
142} // namespace web
143
144#endif // IOS_WEB_PUBLIC_BROWSER_STATE_H_