Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/chromeos/extensions/networking_private_event_router.h" | 5 #include "chrome/browser/chromeos/extensions/networking_private_event_router.h" |
| 6 | 6 |
| 7 #include "base/json/json_writer.h" | 7 #include "base/json/json_writer.h" |
| 8 #include "chrome/browser/browser_process.h" | 8 #include "chrome/browser/browser_process.h" |
| 9 #include "chrome/browser/chromeos/extensions/networking_private_api.h" | 9 #include "chrome/browser/chromeos/extensions/networking_private_api.h" |
| 10 #include "chrome/browser/extensions/event_names.h" | 10 #include "chrome/browser/extensions/event_names.h" |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 59 NetworkingPrivateEventRouter::NetworkingPrivateEventRouter(Profile* profile) | 59 NetworkingPrivateEventRouter::NetworkingPrivateEventRouter(Profile* profile) |
| 60 : profile_(profile), listening_(false) { | 60 : profile_(profile), listening_(false) { |
| 61 // Register with the event router so we know when renderers are listening to | 61 // Register with the event router so we know when renderers are listening to |
| 62 // our events. We first check and see if there *is* an event router, because | 62 // our events. We first check and see if there *is* an event router, because |
| 63 // some unit tests try to create all profile services, but don't initialize | 63 // some unit tests try to create all profile services, but don't initialize |
| 64 // the event router first. | 64 // the event router first. |
| 65 extensions::EventRouter* event_router = | 65 extensions::EventRouter* event_router = |
| 66 ExtensionSystem::Get(profile_)->event_router(); | 66 ExtensionSystem::Get(profile_)->event_router(); |
| 67 if (event_router) { | 67 if (event_router) { |
| 68 event_router->RegisterObserver( | 68 event_router->RegisterObserver( |
| 69 this, extensions::event_names::kOnNetworkChanged); | 69 this, extensions::event_names::kOnNetworksChanged); |
| 70 event_router->RegisterObserver( | |
| 71 this, extensions::event_names::kOnNetworkListChanged); | |
| 70 StartOrStopListeningForNetworkChanges(); | 72 StartOrStopListeningForNetworkChanges(); |
| 71 } | 73 } |
| 72 } | 74 } |
| 73 | 75 |
| 74 NetworkingPrivateEventRouter::~NetworkingPrivateEventRouter() { | 76 NetworkingPrivateEventRouter::~NetworkingPrivateEventRouter() { |
| 75 } | 77 } |
| 76 | 78 |
| 77 void NetworkingPrivateEventRouter::Shutdown() { | 79 void NetworkingPrivateEventRouter::Shutdown() { |
| 78 // Unregister with the event router. We first check and see if there *is* an | 80 // Unregister with the event router. We first check and see if there *is* an |
| 79 // event router, because some unit tests try to shutdown all profile services, | 81 // event router, because some unit tests try to shutdown all profile services, |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 95 } | 97 } |
| 96 | 98 |
| 97 void NetworkingPrivateEventRouter::OnListenerRemoved( | 99 void NetworkingPrivateEventRouter::OnListenerRemoved( |
| 98 const extensions::EventListenerInfo& details) { | 100 const extensions::EventListenerInfo& details) { |
| 99 // Stop listening to events from the network state handler if there are no | 101 // Stop listening to events from the network state handler if there are no |
| 100 // more listeners. | 102 // more listeners. |
| 101 StartOrStopListeningForNetworkChanges(); | 103 StartOrStopListeningForNetworkChanges(); |
| 102 } | 104 } |
| 103 | 105 |
| 104 void NetworkingPrivateEventRouter::StartOrStopListeningForNetworkChanges() { | 106 void NetworkingPrivateEventRouter::StartOrStopListeningForNetworkChanges() { |
| 105 bool should_listen = ExtensionSystem::Get(profile_)->event_router()-> | 107 bool should_listen = (ExtensionSystem::Get(profile_)->event_router()-> |
| 106 HasEventListener(extensions::event_names::kOnNetworkChanged); | 108 HasEventListener(extensions::event_names::kOnNetworksChanged) || |
| 109 ExtensionSystem::Get(profile_)->event_router()-> | |
|
not at google - send to devlin
2013/02/12 22:07:25
save reference to the event router rather than gra
Greg Spencer (Chromium)
2013/02/12 23:11:02
Done.
| |
| 110 HasEventListener(extensions::event_names::kOnNetworkListChanged)); | |
| 107 | 111 |
| 108 if (should_listen) { | 112 if (should_listen) { |
| 109 if (!listening_) | 113 if (!listening_) |
| 110 NetworkStateHandler::Get()->AddObserver(this); | 114 NetworkStateHandler::Get()->AddObserver(this); |
| 111 } else { | 115 } else { |
| 112 if (listening_) | 116 if (listening_) |
| 113 NetworkStateHandler::Get()->RemoveObserver(this); | 117 NetworkStateHandler::Get()->RemoveObserver(this); |
| 114 } | 118 } |
| 115 listening_ = should_listen; | 119 listening_ = should_listen; |
| 116 } | 120 } |
| 117 | 121 |
| 118 void NetworkingPrivateEventRouter::NetworkListChanged() { | 122 void NetworkingPrivateEventRouter::NetworkListChanged() { |
| 119 NetworkStateList networks; | 123 NetworkStateList networks; |
| 120 NetworkStateHandler::Get()->GetNetworkList(&networks); | 124 NetworkStateHandler::Get()->GetNetworkList(&networks); |
| 121 std::vector<linked_ptr<api::NetworkProperties> > changes; | 125 if (!ExtensionSystem::Get(profile_)->event_router()-> |
| 126 HasEventListener(extensions::event_names::kOnNetworkListChanged)) { | |
| 127 return; | |
| 128 } | |
| 129 | |
| 130 std::vector<std::string> changes; | |
| 131 std::string change_str; | |
| 122 for (NetworkStateList::const_iterator iter = networks.begin(); | 132 for (NetworkStateList::const_iterator iter = networks.begin(); |
| 123 iter != networks.end(); ++iter) { | 133 iter != networks.end(); ++iter) { |
| 124 api::NetworkProperties* network_properties = new api::NetworkProperties; | 134 // TODO(gspencer): Currently the "GUID" is actually the service path. Fix |
| 125 network_properties->additional_properties.SetString( | 135 // this to be the real GUID once we're using |
| 126 onc::network_config::kName, (*iter)->name()); | 136 // ManagedNetworkConfigurationManager. |
| 127 network_properties->additional_properties.SetString( | 137 changes.push_back((*iter)->path()); |
| 128 onc::network_config::kGUID, (*iter)->path()); | 138 change_str += (*iter)->path() + " "; |
|
not at google - send to devlin
2013/02/12 22:07:25
change_str doesn't appear to be used?
Greg Spencer (Chromium)
2013/02/12 23:11:02
Removed. That was for some debugging output that'
| |
| 129 network_properties->additional_properties.SetString( | |
| 130 onc::network_config::kType, | |
| 131 GetConnectionType((*iter)->type())); | |
| 132 network_properties->additional_properties.SetString( | |
| 133 onc::network_config::kConnectionState, | |
| 134 GetConnectionState(*iter)); | |
| 135 changes.push_back(make_linked_ptr(network_properties)); | |
| 136 } | 139 } |
| 137 | 140 |
| 138 scoped_ptr<base::ListValue> args(api::OnNetworkChanged::Create(changes)); | 141 scoped_ptr<base::ListValue> args(api::OnNetworksChanged::Create(changes)); |
| 139 scoped_ptr<extensions::Event> extension_event(new extensions::Event( | 142 scoped_ptr<extensions::Event> extension_event(new extensions::Event( |
| 140 extensions::event_names::kOnNetworkChanged, args.Pass())); | 143 extensions::event_names::kOnNetworkListChanged, args.Pass())); |
|
not at google - send to devlin
2013/02/12 22:07:25
why does OnNetworkListChanged take OnNetworksChang
Greg Spencer (Chromium)
2013/02/12 23:11:02
Whoa. I guess this worked because in the end they
| |
| 141 ExtensionSystem::Get(profile_)->event_router()->BroadcastEvent( | 144 ExtensionSystem::Get(profile_)->event_router()->BroadcastEvent( |
| 142 extension_event.Pass()); | 145 extension_event.Pass()); |
| 143 } | 146 } |
| 147 | |
| 148 void NetworkingPrivateEventRouter::NetworkPropertiesUpdated( | |
| 149 const NetworkState* network) { | |
| 150 if (!ExtensionSystem::Get(profile_)->event_router()-> | |
| 151 HasEventListener(extensions::event_names::kOnNetworksChanged)) { | |
| 152 return; | |
| 153 } | |
| 154 | |
| 155 std::vector<std::string> changes; | |
| 156 changes.push_back(network->path()); | |
| 157 scoped_ptr<base::ListValue> args(api::OnNetworkListChanged::Create(changes)); | |
|
not at google - send to devlin
2013/02/12 22:07:25
just
scoped_ptr<base::ListValue> args(
api::O
Greg Spencer (Chromium)
2013/02/12 23:11:02
Done.
| |
| 158 scoped_ptr<extensions::Event> extension_event(new extensions::Event( | |
| 159 extensions::event_names::kOnNetworksChanged, args.Pass())); | |
|
not at google - send to devlin
2013/02/12 22:07:25
see above comment
Greg Spencer (Chromium)
2013/02/12 23:11:02
Done.
| |
| 160 ExtensionSystem::Get(profile_)->event_router()->BroadcastEvent( | |
| 161 extension_event.Pass()); | |
| 162 } | |
| 144 | 163 |
| 145 } // namespace chromeos | 164 } // namespace chromeos |
| OLD | NEW |