| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | // Copyright (c) 2018 GitHub, Inc.
 | 
					
						
							|  |  |  | // Use of this source code is governed by the MIT license that can be
 | 
					
						
							|  |  |  | // found in the LICENSE file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 13:56:58 -07:00
										 |  |  | #ifndef SHELL_BROWSER_NET_SYSTEM_NETWORK_CONTEXT_MANAGER_H_
 | 
					
						
							|  |  |  | #define SHELL_BROWSER_NET_SYSTEM_NETWORK_CONTEXT_MANAGER_H_
 | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | #include "base/macros.h"
 | 
					
						
							|  |  |  | #include "base/memory/ref_counted.h"
 | 
					
						
							|  |  |  | #include "chrome/browser/net/proxy_config_monitor.h"
 | 
					
						
							| 
									
										
										
										
											2019-09-18 15:58:00 -04:00
										 |  |  | #include "mojo/public/cpp/bindings/remote.h"
 | 
					
						
							| 
									
										
										
										
											2021-06-03 01:05:04 -07:00
										 |  |  | #include "services/network/public/cpp/shared_url_loader_factory.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | #include "services/network/public/mojom/network_context.mojom.h"
 | 
					
						
							|  |  |  | #include "services/network/public/mojom/network_service.mojom.h"
 | 
					
						
							| 
									
										
										
										
											2021-06-03 01:05:04 -07:00
										 |  |  | #include "services/network/public/mojom/url_loader.mojom.h"
 | 
					
						
							|  |  |  | #include "services/network/public/mojom/url_loader_factory.mojom.h"
 | 
					
						
							|  |  |  | #include "third_party/abseil-cpp/absl/types/optional.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 14:23:04 -07:00
										 |  |  | namespace electron { | 
					
						
							| 
									
										
										
										
											2019-05-29 16:43:06 -07:00
										 |  |  | network::mojom::HttpAuthDynamicParamsPtr CreateHttpAuthDynamicParams(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | // Responsible for creating and managing access to the system NetworkContext.
 | 
					
						
							|  |  |  | // Lives on the UI thread. The NetworkContext this owns is intended for requests
 | 
					
						
							|  |  |  | // not associated with a session. It stores no data on disk, and has no HTTP
 | 
					
						
							|  |  |  | // cache, but it does have ephemeral cookie and channel ID stores.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This class is also responsible for configuring global NetworkService state.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // The "system" NetworkContext will either share a URLRequestContext with
 | 
					
						
							|  |  |  | // IOThread's SystemURLRequestContext and be part of IOThread's NetworkService
 | 
					
						
							|  |  |  | // (If the network service is disabled) or be an independent NetworkContext
 | 
					
						
							|  |  |  | // using the actual network service.
 | 
					
						
							|  |  |  | class SystemNetworkContextManager { | 
					
						
							|  |  |  |  public: | 
					
						
							|  |  |  |   ~SystemNetworkContextManager(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-26 06:40:48 +05:30
										 |  |  |   // Creates the global instance of SystemNetworkContextManager. If an
 | 
					
						
							|  |  |  |   // instance already exists, this will cause a DCHECK failure.
 | 
					
						
							|  |  |  |   static SystemNetworkContextManager* CreateInstance(PrefService* pref_service); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Gets the global SystemNetworkContextManager instance.
 | 
					
						
							|  |  |  |   static SystemNetworkContextManager* GetInstance(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Destroys the global SystemNetworkContextManager instance.
 | 
					
						
							|  |  |  |   static void DeleteInstance(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-26 13:06:26 -07:00
										 |  |  |   // Configures default set of parameters for configuring the network context.
 | 
					
						
							|  |  |  |   void ConfigureDefaultNetworkContextParams( | 
					
						
							|  |  |  |       network::mojom::NetworkContextParams* network_context_params); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Same as ConfigureDefaultNetworkContextParams() but returns a newly
 | 
					
						
							|  |  |  |   // allocated network::mojom::NetworkContextParams with the
 | 
					
						
							|  |  |  |   // CertVerifierCreationParams already placed into the NetworkContextParams.
 | 
					
						
							| 
									
										
										
										
											2019-03-26 06:40:48 +05:30
										 |  |  |   network::mojom::NetworkContextParamsPtr CreateDefaultNetworkContextParams(); | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |   // Returns the System NetworkContext. May only be called after SetUp(). Does
 | 
					
						
							|  |  |  |   // any initialization of the NetworkService that may be needed when first
 | 
					
						
							|  |  |  |   // called.
 | 
					
						
							|  |  |  |   network::mojom::NetworkContext* GetContext(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Returns a URLLoaderFactory owned by the SystemNetworkContextManager that is
 | 
					
						
							|  |  |  |   // backed by the SystemNetworkContext. Allows sharing of the URLLoaderFactory.
 | 
					
						
							|  |  |  |   // Prefer this to creating a new one.  Call Clone() on the value returned by
 | 
					
						
							|  |  |  |   // this method to get a URLLoaderFactory that can be used on other threads.
 | 
					
						
							|  |  |  |   network::mojom::URLLoaderFactory* GetURLLoaderFactory(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Returns a SharedURLLoaderFactory owned by the SystemNetworkContextManager
 | 
					
						
							|  |  |  |   // that is backed by the SystemNetworkContext.
 | 
					
						
							|  |  |  |   scoped_refptr<network::SharedURLLoaderFactory> GetSharedURLLoaderFactory(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Called when content creates a NetworkService. Creates the
 | 
					
						
							|  |  |  |   // SystemNetworkContext, if the network service is enabled.
 | 
					
						
							|  |  |  |   void OnNetworkServiceCreated(network::mojom::NetworkService* network_service); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  private: | 
					
						
							|  |  |  |   class URLLoaderFactoryForSystem; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-26 06:40:48 +05:30
										 |  |  |   explicit SystemNetworkContextManager(PrefService* pref_service); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  |   // Creates parameters for the NetworkContext. May only be called once, since
 | 
					
						
							|  |  |  |   // it initializes some class members.
 | 
					
						
							|  |  |  |   network::mojom::NetworkContextParamsPtr CreateNetworkContextParams(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ProxyConfigMonitor proxy_config_monitor_; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // NetworkContext using the network service, if the network service is
 | 
					
						
							|  |  |  |   // enabled. nullptr, otherwise.
 | 
					
						
							| 
									
										
										
										
											2019-09-18 15:58:00 -04:00
										 |  |  |   mojo::Remote<network::mojom::NetworkContext> network_context_; | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |   // URLLoaderFactory backed by the NetworkContext returned by GetContext(), so
 | 
					
						
							|  |  |  |   // consumers don't all need to create their own factory.
 | 
					
						
							|  |  |  |   scoped_refptr<URLLoaderFactoryForSystem> shared_url_loader_factory_; | 
					
						
							| 
									
										
										
										
											2019-10-28 18:12:35 -04:00
										 |  |  |   mojo::Remote<network::mojom::URLLoaderFactory> url_loader_factory_; | 
					
						
							| 
									
										
										
										
											2018-11-06 11:40:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |   DISALLOW_COPY_AND_ASSIGN(SystemNetworkContextManager); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 13:56:58 -07:00
										 |  |  | #endif  // SHELL_BROWSER_NET_SYSTEM_NETWORK_CONTEXT_MANAGER_H_
 |