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

Unified Diff: chromeos/network/network_handler.h

Issue 14729017: Add NetworkHandler to own network handlers in src/chromeos/network (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 7 years, 7 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: chromeos/network/network_handler.h
diff --git a/chromeos/network/network_handler.h b/chromeos/network/network_handler.h
new file mode 100644
index 0000000000000000000000000000000000000000..5abc01c3d88a9d8607bd4dfdf3af4c06ba4c26e5
--- /dev/null
+++ b/chromeos/network/network_handler.h
@@ -0,0 +1,92 @@
+// Copyright (c) 2013 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 CHROMEOS_NETWORK_NETWORK_HANDLER_H_
+#define CHROMEOS_NETWORK_NETWORK_HANDLER_H_
+
+#include "base/basictypes.h"
+#include "base/memory/scoped_ptr.h"
+#include "chromeos/chromeos_export.h"
+
+namespace chromeos {
+
+class CertLoader;
+class GeolocationHandler;
+class ManagedNetworkConfigurationHandler;
+class NetworkConfigurationHandler;
+class NetworkProfileHandler;
+class NetworkStateHandler;
+
+// Class for handling initialization and access to chromeos network handlers.
+
pneubeck (no reviews) 2013/05/13 09:17:06 nit: remove empty line.
stevenjb 2013/05/13 23:49:35 Done.
+class CHROMEOS_EXPORT NetworkHandler {
+ public:
+ // Sets the global instance. Must be called before any calls to Get().
+ static void Initialize();
+
+ // Destroys the global instance.
+ static void Shutdown();
+
+ // Gets the global instance. Initialize() must be called first.
+ static NetworkHandler* Get();
+
+ // Returns true if the global instance has been initialized.
+ static bool IsInitialized();
+
+ CertLoader* cert_loader();
+ NetworkStateHandler* network_state_handler();
pneubeck (no reviews) 2013/05/13 09:17:06 I thought you proposed state()? I'd at least drop
stevenjb 2013/05/13 23:49:35 I decided I prefer the name matching the class (cl
pneubeck (no reviews) 2013/05/22 14:02:53 I don't feel strong about that, so NIT: That migh
stevenjb 2013/05/22 17:09:27 I don't think we should need to rename the other c
+ NetworkProfileHandler* network_profile_handler();
+ NetworkConfigurationHandler* network_configuration_handler();
+ ManagedNetworkConfigurationHandler* managed_network_configuration_handler();
+ GeolocationHandler* geolocation_handler();
+
+ void SetCertLoaderForTest(CertLoader* cert_loader);
pneubeck (no reviews) 2013/05/13 09:17:06 Since none of these are called yet, we could leave
stevenjb 2013/05/13 23:49:35 I added them specifically to make setting future m
+ void SetNetworkStateHandlerForTest(
+ NetworkStateHandler* network_state_handler);
+ void SetNetworkProfileHandlerForTest(
+ NetworkProfileHandler* network_profile_handler);
+ void SetNetworkConfigurationHandlerForTest(
+ NetworkConfigurationHandler* network_configuration_handler);
+ void SetManagedNetworkConfigurationHandlerForTest(
+ ManagedNetworkConfigurationHandler*
+ managed_network_configuration_handler);
+ void SetGeolocationHandlerForTest(
+ GeolocationHandler* geolocation_handler);
+
+ private:
+ class LoginStateInitializer;
+
+ NetworkHandler();
+ virtual ~NetworkHandler();
+
+ void Init();
+
+ // Initialize LoginState for tests so they do not have to do so explicitly.
pneubeck (no reviews) 2013/05/13 09:17:06 I'm not convinced that this belongs into this clas
stevenjb 2013/05/13 23:49:35 Requiring any test that initializes NetworkHandler
pneubeck (no reviews) 2013/05/22 14:02:53 Tedious or not. It don't see an argument why it be
stevenjb 2013/05/22 17:09:27 I went ahead and eliminated this and made CertLoad
+ scoped_ptr<LoginStateInitializer> login_state_initializer_;
+
+ // The order of these determines the (inverse) destruction order.
+ scoped_ptr<CertLoader> cert_loader_;
+ scoped_ptr<NetworkStateHandler> network_state_handler_;
+ scoped_ptr<NetworkProfileHandler> network_profile_handler_;
+ scoped_ptr<NetworkConfigurationHandler> network_configuration_handler_;
+ scoped_ptr<ManagedNetworkConfigurationHandler>
+ managed_network_configuration_handler_;
+ scoped_ptr<GeolocationHandler> geolocation_handler_;
+
+ // Unowned test implementations. If non-NULL these will be used instead of
+ // the owned implementations. The test is responsible for destroying these.
+ CertLoader* test_cert_loader_;
+ NetworkStateHandler* test_network_state_handler_;
+ NetworkProfileHandler* test_network_profile_handler_;
+ NetworkConfigurationHandler* test_network_configuration_handler_;
+ ManagedNetworkConfigurationHandler*
+ test_managed_network_configuration_handler_;
+ GeolocationHandler* test_geolocation_handler_;
+
+ DISALLOW_COPY_AND_ASSIGN(NetworkHandler);
+};
+
+} // namespace chromeos
+
+#endif // CHROMEOS_NETWORK_NETWORK_HANDLER_H_

Powered by Google App Engine
This is Rietveld 408576698