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

Side by Side Diff: chrome/browser/ui/webui/chromeos/network_ui.cc

Issue 260083007: Replace chrome://network implementation with networkConfig API (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 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/ui/webui/chromeos/network_ui.h" 5 #include "chrome/browser/ui/webui/chromeos/network_ui.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/bind_helpers.h" 10 #include "base/bind_helpers.h"
11 #include "base/json/json_string_value_serializer.h" 11 #include "base/json/json_string_value_serializer.h"
michaelpg 2014/04/29 19:51:00 where is this used?
stevenjb 2014/05/01 01:45:14 Done.
12 #include "base/values.h" 12 #include "base/values.h"
13 #include "chrome/browser/profiles/profile.h" 13 #include "chrome/browser/ui/webui/chromeos/network_config_message_handler.h"
14 #include "chrome/common/url_constants.h" 14 #include "chrome/common/url_constants.h"
15 #include "chromeos/network/favorite_state.h"
16 #include "chromeos/network/network_event_log.h" 15 #include "chromeos/network/network_event_log.h"
17 #include "chromeos/network/network_state.h" 16 #include "content/public/browser/web_contents.h"
18 #include "chromeos/network/network_state_handler.h"
19 #include "content/public/browser/web_ui.h" 17 #include "content/public/browser/web_ui.h"
20 #include "content/public/browser/web_ui_data_source.h" 18 #include "content/public/browser/web_ui_data_source.h"
21 #include "content/public/browser/web_ui_message_handler.h" 19 #include "content/public/browser/web_ui_message_handler.h"
22 #include "grit/browser_resources.h" 20 #include "grit/browser_resources.h"
23 #include "grit/generated_resources.h" 21 #include "grit/generated_resources.h"
24 22
25 namespace chromeos { 23 namespace chromeos {
26 24
27 namespace { 25 namespace {
28 26
29 const char kStringsJsFile[] = "strings.js"; 27 class NetworkUIMessageHandler : public content::WebUIMessageHandler {
30 const char kRequestNetworkInfoCallback[] = "requestNetworkInfo";
31 const char kNetworkEventLogTag[] = "networkEventLog";
32 const char kNetworkStateTag[] = "networkStates";
33 const char kFavoriteStateTag[] = "favoriteStates";
34 const char kOnNetworkInfoReceivedFunction[] = "NetworkUI.onNetworkInfoReceived";
35
36 class NetworkMessageHandler : public content::WebUIMessageHandler {
37 public: 28 public:
38 NetworkMessageHandler(); 29 NetworkUIMessageHandler() {}
39 virtual ~NetworkMessageHandler(); 30 virtual ~NetworkUIMessageHandler() {}
40 31
41 // WebUIMessageHandler implementation. 32 // WebUIMessageHandler implementation.
42 virtual void RegisterMessages() OVERRIDE; 33 virtual void RegisterMessages() OVERRIDE {
34 web_ui()->RegisterMessageCallback(
35 "NetworkUI.getNetworkLog",
36 base::Bind(&NetworkUIMessageHandler::GetNetworkLog,
37 base::Unretained(this)));
38 }
43 39
44 private: 40 private:
45 void CollectNetworkInfo(const base::ListValue* value) const; 41 void GetNetworkLog(const base::ListValue* value) const {
46 std::string GetNetworkEventLog() const; 42 base::StringValue data(chromeos::network_event_log::GetAsString(
47 void GetNetworkState(base::DictionaryValue* output) const; 43 chromeos::network_event_log::NEWEST_FIRST,
48 void GetFavoriteState(base::DictionaryValue* output) const; 44 "json",
49 void RespondToPage(const base::DictionaryValue& value) const; 45 chromeos::network_event_log::LOG_LEVEL_DEBUG,
46 0));
47 web_ui()->CallJavascriptFunction("NetworkUI.getNetworkLogCallback", data);
48 }
50 49
51 DISALLOW_COPY_AND_ASSIGN(NetworkMessageHandler); 50 DISALLOW_COPY_AND_ASSIGN(NetworkUIMessageHandler);
52 }; 51 };
53 52
54 NetworkMessageHandler::NetworkMessageHandler() {
55 }
56
57 NetworkMessageHandler::~NetworkMessageHandler() {
58 }
59
60 void NetworkMessageHandler::RegisterMessages() {
61 web_ui()->RegisterMessageCallback(
62 kRequestNetworkInfoCallback,
63 base::Bind(&NetworkMessageHandler::CollectNetworkInfo,
64 base::Unretained(this)));
65 }
66
67 void NetworkMessageHandler::CollectNetworkInfo(
68 const base::ListValue* value) const {
69 base::DictionaryValue data;
70 data.SetString(kNetworkEventLogTag, GetNetworkEventLog());
71
72 base::DictionaryValue* networkState = new base::DictionaryValue;
73 GetNetworkState(networkState);
74 data.Set(kNetworkStateTag, networkState);
75
76 base::DictionaryValue* favoriteState = new base::DictionaryValue;
77 GetFavoriteState(favoriteState);
78 data.Set(kFavoriteStateTag, favoriteState);
79
80 RespondToPage(data);
81 }
82
83 void NetworkMessageHandler::RespondToPage(
84 const base::DictionaryValue& value) const {
85 web_ui()->CallJavascriptFunction(kOnNetworkInfoReceivedFunction, value);
86 }
87
88 std::string NetworkMessageHandler::GetNetworkEventLog() const {
89 std::string format = "json";
90 return chromeos::network_event_log::GetAsString(
91 chromeos::network_event_log::NEWEST_FIRST,
92 format,
93 chromeos::network_event_log::LOG_LEVEL_DEBUG,
94 0);
95 }
96
97 void NetworkMessageHandler::GetNetworkState(
98 base::DictionaryValue* output) const {
99 chromeos::NetworkStateHandler* handler =
100 chromeos::NetworkHandler::Get()->network_state_handler();
101 chromeos::NetworkStateHandler::NetworkStateList network_list;
102 handler->GetNetworkList(&network_list);
103 for (chromeos::NetworkStateHandler::NetworkStateList::const_iterator it =
104 network_list.begin();
105 it != network_list.end();
106 ++it) {
107 base::DictionaryValue* properties = new base::DictionaryValue;
108 (*it)->GetStateProperties(properties);
109 output->Set((*it)->path(), properties);
110 }
111 }
112
113 void NetworkMessageHandler::GetFavoriteState(
114 base::DictionaryValue* output) const {
115 chromeos::NetworkStateHandler* handler =
116 chromeos::NetworkHandler::Get()->network_state_handler();
117 chromeos::NetworkStateHandler::FavoriteStateList favorite_list;
118 handler->GetFavoriteList(&favorite_list);
119 for (chromeos::NetworkStateHandler::FavoriteStateList::const_iterator it =
120 favorite_list.begin();
121 it != favorite_list.end();
122 ++it) {
123 base::DictionaryValue* properties = new base::DictionaryValue;
124 (*it)->GetStateProperties(properties);
125 output->Set((*it)->path(), properties);
126 }
127 }
128
129 } // namespace 53 } // namespace
130 54
131 NetworkUI::NetworkUI(content::WebUI* web_ui) 55 NetworkUI::NetworkUI(content::WebUI* web_ui)
132 : content::WebUIController(web_ui) { 56 : content::WebUIController(web_ui) {
133 web_ui->AddMessageHandler(new NetworkMessageHandler()); 57 web_ui->AddMessageHandler(new NetworkConfigMessageHandler());
58 web_ui->AddMessageHandler(new NetworkUIMessageHandler());
134 59
135 content::WebUIDataSource* html = 60 content::WebUIDataSource* html =
136 content::WebUIDataSource::Create(chrome::kChromeUINetworkHost); 61 content::WebUIDataSource::Create(chrome::kChromeUINetworkHost);
137 html->SetUseJsonJSFormatV2(); 62 html->SetUseJsonJSFormatV2();
138 63
139 html->AddLocalizedString("titleText", IDS_NETWORK_TITLE); 64 html->AddLocalizedString("titleText", IDS_NETWORK_TITLE);
140 html->AddLocalizedString("autoRefreshText", IDS_NETWORK_AUTO_REFRESH); 65 html->AddLocalizedString("autoRefreshText", IDS_NETWORK_AUTO_REFRESH);
141 html->AddLocalizedString("logRefreshText", IDS_NETWORK_LOG_REFRESH); 66 html->AddLocalizedString("logRefreshText", IDS_NETWORK_LOG_REFRESH);
142 html->AddLocalizedString("logLevelShowText", IDS_NETWORK_LOG_LEVEL_SHOW); 67 html->AddLocalizedString("logLevelShowText", IDS_NETWORK_LOG_LEVEL_SHOW);
143 html->AddLocalizedString("logLevelErrorText", IDS_NETWORK_LOG_LEVEL_ERROR); 68 html->AddLocalizedString("logLevelErrorText", IDS_NETWORK_LOG_LEVEL_ERROR);
144 html->AddLocalizedString("logLevelUserText", IDS_NETWORK_LOG_LEVEL_USER); 69 html->AddLocalizedString("logLevelUserText", IDS_NETWORK_LOG_LEVEL_USER);
145 html->AddLocalizedString("logLevelEventText", IDS_NETWORK_LOG_LEVEL_EVENT); 70 html->AddLocalizedString("logLevelEventText", IDS_NETWORK_LOG_LEVEL_EVENT);
146 html->AddLocalizedString("logLevelDebugText", IDS_NETWORK_LOG_LEVEL_DEBUG); 71 html->AddLocalizedString("logLevelDebugText", IDS_NETWORK_LOG_LEVEL_DEBUG);
147 html->AddLocalizedString("logLevelFileinfoText", 72 html->AddLocalizedString("logLevelFileinfoText",
148 IDS_NETWORK_LOG_LEVEL_FILEINFO); 73 IDS_NETWORK_LOG_LEVEL_FILEINFO);
149 html->AddLocalizedString("logLevelTimeDetailText", 74 html->AddLocalizedString("logLevelTimeDetailText",
150 IDS_NETWORK_LOG_LEVEL_TIME_DETAIL); 75 IDS_NETWORK_LOG_LEVEL_TIME_DETAIL);
151 html->AddLocalizedString("logEntryFormat", IDS_NETWORK_LOG_ENTRY); 76 html->AddLocalizedString("logEntryFormat", IDS_NETWORK_LOG_ENTRY);
152 html->SetJsonPath(kStringsJsFile); 77 html->SetJsonPath("strings.js");
78 html->AddResourcePath("network_config.js", IDR_NETWORK_CONFIG_JS);
79 html->AddResourcePath("network_ui.css", IDR_NETWORK_UI_CSS);
80 html->AddResourcePath("network_ui.js", IDR_NETWORK_UI_JS);
81 html->SetDefaultResource(IDR_NETWORK_UI_HTML);
153 82
154 html->AddResourcePath("network.css", IDR_NETWORK_CSS); 83 content::WebUIDataSource::Add(
155 html->AddResourcePath("network.js", IDR_NETWORK_JS); 84 web_ui->GetWebContents()->GetBrowserContext(), html);
156 html->SetDefaultResource(IDR_NETWORK_HTML);
157
158 Profile* profile = Profile::FromWebUI(web_ui);
159 content::WebUIDataSource::Add(profile, html);
160 } 85 }
161 86
162 NetworkUI::~NetworkUI() { 87 NetworkUI::~NetworkUI() {
163 } 88 }
164 89
165 } // namespace chromeos 90 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698