Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2330)

Unified Diff: chrome/browser/net/profile_network_context_service.h

Issue 2976323002: Hook up ProfileIOData's URLRequestContext to a NetworkService. (Closed)
Patch Set: X11 is bonkers Created 3 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/net/profile_network_context_service.h
diff --git a/chrome/browser/net/profile_network_context_service.h b/chrome/browser/net/profile_network_context_service.h
new file mode 100644
index 0000000000000000000000000000000000000000..80055047dd01f5495b8a1a8450efbf42570d53b7
--- /dev/null
+++ b/chrome/browser/net/profile_network_context_service.h
@@ -0,0 +1,55 @@
+// Copyright 2017 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_NET_PROFILE_NETWORK_CONTEXT_SERVICE_H_
+#define CHROME_BROWSER_NET_PROFILE_NETWORK_CONTEXT_SERVICE_H_
+
+#include "base/macros.h"
+#include "components/keyed_service/core/keyed_service.h"
+#include "content/public/common/network_service.mojom.h"
+
+class Profile;
+
+// KeyedService that initializes and provides access to the NetworkContexts for
+// a Profile. This will eventually replace ProfileIOData.
+class ProfileNetworkContextService : public KeyedService {
+ public:
+ explicit ProfileNetworkContextService(Profile* profile);
+ ~ProfileNetworkContextService() override;
+
+ // Initializes |network_context_params| as needed to set up the
+ // ProfileIOData's main NetworkContext (Which the caller will need to send to
+ // the IOThread's in-process NetworkService). If the network service is
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 I think this description ("which the caller ...")
mmenke 2017/07/19 20:35:38 It applies to both cases. When the network servic
+ // disabled, this will be the NetworkContext returned by the MainContext()
+ // method, and use by all the requests associated with a profile. If the
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 nit: "and used" (I think).
mmenke 2017/07/19 20:35:38 Done.
+ // network service is enabled, this method is sitll used, but only legacy
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 nit: still
mmenke 2017/07/19 20:35:38 Done.
+ // requests going through the URLRequestContext interface instead of the
+ // NetworkContext interface will use the profile's NetworkContext, and the
+ // ProfileIOData's main network context will be configured not to use on-disk
+ // storage, as the network service will be using those files instead.
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 To confirm: This means that the legacy interface (
mmenke 2017/07/19 20:35:37 Other way around, so we can test the new interface
+ //
+ // Must be called before the system NetworkContext is first used.
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 Hmmm. I'm having a hard time wrapping my brain ar
mmenke 2017/07/19 20:35:38 That's what the above paragraph was attempting to
+ void SetUpProfileIODataMainContext(
+ content::mojom::NetworkContextRequest* network_context_request,
+ content::mojom::NetworkContextParamsPtr* network_context_params);
+
+ // Returns the main NetworkContext for the BrowserContext.
+ content::mojom::NetworkContext* MainContext();
+
+ // Creates the main NetworkContext for the BrowserContext. Only called when
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 nit, suggestion: "May only be called". I take hea
mmenke 2017/07/19 20:35:38 Done.
+ // the network service is enabled.
+ content::mojom::NetworkContextPtr CreateMainNetworkContext();
Randy Smith (Not in Mondays) 2017/07/19 19:31:10 As might be suggested by my confused questions ove
mmenke 2017/07/19 20:35:38 I don't think every use of a mojom::*Ptr should ha
+
+ private:
+ Profile* const profile_;
+
+ // This is a NetworkContext that wraps ProfileIOData's main URLRequestContext.
+ // Always initialized in SetUpProfileIODataMainContext, but it's only returned
+ // by Context() when the network service is disabled.
+ content::mojom::NetworkContextPtr profile_io_data_main_network_context_;
+
+ DISALLOW_COPY_AND_ASSIGN(ProfileNetworkContextService);
+};
+
+#endif // CHROME_BROWSER_NET_PROFILE_NETWORK_CONTEXT_SERVICE_H_

Powered by Google App Engine
This is Rietveld 408576698