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

Side by Side Diff: components/error_page/common/localized_error.cc

Issue 1639953002: Network error interstitial update - add suggestions list (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 10 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
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "components/error_page/common/localized_error.h" 5 #include "components/error_page/common/localized_error.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/i18n/rtl.h" 10 #include "base/i18n/rtl.h"
(...skipping 27 matching lines...) Expand all
38 #endif 38 #endif
39 39
40 namespace error_page { 40 namespace error_page {
41 41
42 namespace { 42 namespace {
43 43
44 // Some error pages have no details. 44 // Some error pages have no details.
45 const unsigned int kErrorPagesNoDetails = 0; 45 const unsigned int kErrorPagesNoDetails = 0;
46 46
47 static const char kRedirectLoopLearnMoreUrl[] = 47 static const char kRedirectLoopLearnMoreUrl[] =
48 "https://support.google.com/chrome/answer/95626"; 48 "https://support.google.com/chrome?p=rl_error";
49 static const char kWeakDHKeyLearnMoreUrl[] = 49 static const char kWeakDHKeyLearnMoreUrl[] =
50 "https://support.google.com/chrome?p=dh_error"; 50 "https://support.google.com/chrome?p=dh_error";
51 static const int kGoogleCachedCopySuggestionType = 0; 51 static const int kGoogleCachedCopySuggestionType = 0;
52 52
53 enum NAV_SUGGESTIONS { 53 enum NAV_SUGGESTIONS {
54 SUGGEST_NONE = 0, 54 SUGGEST_NONE = 0,
55 SUGGEST_RELOAD = 1 << 0, 55 SUGGEST_RELOAD = 1 << 0,
56 SUGGEST_CHECK_CONNECTION = 1 << 1, 56 SUGGEST_CHECK_CONNECTION = 1 << 1,
57 SUGGEST_DNS_CONFIG = 1 << 2, 57 SUGGEST_DNS_CONFIG = 1 << 2,
58 SUGGEST_FIREWALL_CONFIG = 1 << 3, 58 SUGGEST_FIREWALL_CONFIG = 1 << 3,
59 SUGGEST_PROXY_CONFIG = 1 << 4, 59 SUGGEST_PROXY_CONFIG = 1 << 4,
60 SUGGEST_DISABLE_EXTENSION = 1 << 5, 60 SUGGEST_DISABLE_EXTENSION = 1 << 5,
61 SUGGEST_LEARNMORE = 1 << 6, 61 SUGGEST_LEARNMORE = 1 << 6,
62 SUGGEST_VIEW_POLICIES = 1 << 7, 62 SUGGEST_VIEW_POLICIES = 1 << 7,
63 SUGGEST_CONTACT_ADMINISTRATOR = 1 << 8, 63 SUGGEST_CONTACT_ADMINISTRATOR = 1 << 8,
64 SUGGEST_UNSUPPORTED_CIPHER = 1 << 9, 64 SUGGEST_UNSUPPORTED_CIPHER = 1 << 9,
65 SUGGEST_AV_CONFIG = 1 << 10,
66 SUGGEST_OFFLINE_CHECKS = 1 << 11,
67 SUGGEST_COMPLETE_SETUP = 1 << 12,
65 }; 68 };
66 69
67 struct LocalizedErrorMap { 70 struct LocalizedErrorMap {
68 int error_code; 71 int error_code;
69 unsigned int title_resource_id; 72 unsigned int title_resource_id;
70 unsigned int heading_resource_id; 73 unsigned int heading_resource_id;
71 // Detailed summary used when the error is in the main frame. 74 // Detailed summary used when the error is in the main frame.
72 unsigned int summary_resource_id; 75 unsigned int summary_resource_id;
73 // Short one sentence description shown on mouse over when the error is in 76 // Short one sentence description shown on mouse over when the error is in
74 // a frame. 77 // a frame.
(...skipping 17 matching lines...) Expand all
92 IDS_ERRORPAGES_SUMMARY_TIMED_OUT, 95 IDS_ERRORPAGES_SUMMARY_TIMED_OUT,
93 IDS_ERRORPAGES_DETAILS_TIMED_OUT, 96 IDS_ERRORPAGES_DETAILS_TIMED_OUT,
94 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | 97 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
95 SUGGEST_PROXY_CONFIG, 98 SUGGEST_PROXY_CONFIG,
96 }, 99 },
97 {net::ERR_CONNECTION_CLOSED, 100 {net::ERR_CONNECTION_CLOSED,
98 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 101 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
99 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 102 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
100 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED, 103 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED,
101 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED, 104 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED,
102 SUGGEST_RELOAD, 105 SUGGEST_RELOAD, SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
mmenke 2016/02/18 19:51:18 BUG: That comma should be an |. Suggest removing
edwardjung 2016/02/19 18:18:22 Done.
106 SUGGEST_PROXY_CONFIG,
103 }, 107 },
104 {net::ERR_CONNECTION_RESET, 108 {net::ERR_CONNECTION_RESET,
105 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 109 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
106 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 110 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
107 IDS_ERRORPAGES_SUMMARY_CONNECTION_RESET, 111 IDS_ERRORPAGES_SUMMARY_CONNECTION_RESET,
108 IDS_ERRORPAGES_DETAILS_CONNECTION_RESET, 112 IDS_ERRORPAGES_DETAILS_CONNECTION_RESET,
109 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | 113 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
110 SUGGEST_PROXY_CONFIG, 114 SUGGEST_PROXY_CONFIG,
111 }, 115 },
112 {net::ERR_CONNECTION_REFUSED, 116 {net::ERR_CONNECTION_REFUSED,
(...skipping 24 matching lines...) Expand all
137 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 141 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
138 IDS_ERRORPAGES_SUMMARY_ICANN_NAME_COLLISION, 142 IDS_ERRORPAGES_SUMMARY_ICANN_NAME_COLLISION,
139 IDS_ERRORPAGES_DETAILS_ICANN_NAME_COLLISION, 143 IDS_ERRORPAGES_DETAILS_ICANN_NAME_COLLISION,
140 SUGGEST_NONE, 144 SUGGEST_NONE,
141 }, 145 },
142 {net::ERR_ADDRESS_UNREACHABLE, 146 {net::ERR_ADDRESS_UNREACHABLE,
143 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 147 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
144 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 148 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
145 IDS_ERRORPAGES_SUMMARY_ADDRESS_UNREACHABLE, 149 IDS_ERRORPAGES_SUMMARY_ADDRESS_UNREACHABLE,
146 IDS_ERRORPAGES_DETAILS_ADDRESS_UNREACHABLE, 150 IDS_ERRORPAGES_DETAILS_ADDRESS_UNREACHABLE,
147 SUGGEST_RELOAD | SUGGEST_FIREWALL_CONFIG | SUGGEST_PROXY_CONFIG, 151 SUGGEST_RELOAD,
148 }, 152 },
149 {net::ERR_NETWORK_ACCESS_DENIED, 153 {net::ERR_NETWORK_ACCESS_DENIED,
150 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 154 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
151 IDS_ERRORPAGES_HEADING_NETWORK_ACCESS_DENIED, 155 IDS_ERRORPAGES_HEADING_NETWORK_ACCESS_DENIED,
152 IDS_ERRORPAGES_SUMMARY_NETWORK_ACCESS_DENIED, 156 IDS_ERRORPAGES_SUMMARY_NETWORK_ACCESS_DENIED,
153 IDS_ERRORPAGES_DETAILS_NETWORK_ACCESS_DENIED, 157 IDS_ERRORPAGES_DETAILS_NETWORK_ACCESS_DENIED,
154 SUGGEST_FIREWALL_CONFIG, 158 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | SUGGEST_AV_CONFIG,
155 }, 159 },
156 {net::ERR_PROXY_CONNECTION_FAILED, 160 {net::ERR_PROXY_CONNECTION_FAILED,
157 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 161 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
158 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 162 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
159 IDS_ERRORPAGES_SUMMARY_PROXY_CONNECTION_FAILED, 163 IDS_ERRORPAGES_SUMMARY_PROXY_CONNECTION_FAILED,
160 IDS_ERRORPAGES_DETAILS_PROXY_CONNECTION_FAILED, 164 IDS_ERRORPAGES_DETAILS_PROXY_CONNECTION_FAILED,
161 SUGGEST_PROXY_CONFIG, 165 SUGGEST_PROXY_CONFIG | SUGGEST_CONTACT_ADMINISTRATOR,
162 }, 166 },
163 {net::ERR_INTERNET_DISCONNECTED, 167 {net::ERR_INTERNET_DISCONNECTED,
164 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 168 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
165 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 169 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
166 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED, 170 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED,
167 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED, 171 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED,
168 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG, 172 SUGGEST_OFFLINE_CHECKS,
169 }, 173 },
170 {net::ERR_FILE_NOT_FOUND, 174 {net::ERR_FILE_NOT_FOUND,
171 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 175 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
172 IDS_ERRORPAGES_HEADING_FILE_NOT_FOUND, 176 IDS_ERRORPAGES_HEADING_FILE_NOT_FOUND,
173 IDS_ERRORPAGES_SUMMARY_FILE_NOT_FOUND, 177 IDS_ERRORPAGES_SUMMARY_FILE_NOT_FOUND,
174 IDS_ERRORPAGES_DETAILS_FILE_NOT_FOUND, 178 IDS_ERRORPAGES_DETAILS_FILE_NOT_FOUND,
175 SUGGEST_RELOAD, 179 SUGGEST_RELOAD,
176 }, 180 },
177 {net::ERR_CACHE_MISS, 181 {net::ERR_CACHE_MISS,
178 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 182 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
242 IDS_ERRORPAGES_HEADING_PAGE_NOT_WORKING, 246 IDS_ERRORPAGES_HEADING_PAGE_NOT_WORKING,
243 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED, 247 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED,
244 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED, 248 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED,
245 SUGGEST_RELOAD, 249 SUGGEST_RELOAD,
246 }, 250 },
247 {net::ERR_SSL_PROTOCOL_ERROR, 251 {net::ERR_SSL_PROTOCOL_ERROR,
248 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 252 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
249 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 253 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
250 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE, 254 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE,
251 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR, 255 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR,
252 SUGGEST_NONE, 256 SUGGEST_RELOAD,
253 }, 257 },
254 {net::ERR_BAD_SSL_CLIENT_AUTH_CERT, 258 {net::ERR_BAD_SSL_CLIENT_AUTH_CERT,
255 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 259 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
256 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 260 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
257 IDS_ERRORPAGES_SUMMARY_BAD_SSL_CLIENT_AUTH_CERT, 261 IDS_ERRORPAGES_SUMMARY_BAD_SSL_CLIENT_AUTH_CERT,
258 IDS_ERRORPAGES_DETAILS_BAD_SSL_CLIENT_AUTH_CERT, 262 IDS_ERRORPAGES_DETAILS_BAD_SSL_CLIENT_AUTH_CERT,
259 SUGGEST_NONE, 263 SUGGEST_CONTACT_ADMINISTRATOR,
260 }, 264 },
261 {net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY, 265 {net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY,
262 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 266 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
263 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 267 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
264 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR, 268 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR,
265 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR, 269 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR,
266 SUGGEST_LEARNMORE, 270 SUGGEST_LEARNMORE,
267 }, 271 },
268 {net::ERR_SSL_PINNED_KEY_NOT_IN_CERT_CHAIN, 272 {net::ERR_SSL_PINNED_KEY_NOT_IN_CERT_CHAIN,
269 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 273 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
270 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 274 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
271 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DETAILS, 275 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DETAILS,
272 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DESCRIPTION, 276 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DESCRIPTION,
273 SUGGEST_NONE, 277 SUGGEST_NONE,
274 }, 278 },
275 {net::ERR_TEMPORARILY_THROTTLED, 279 {net::ERR_TEMPORARILY_THROTTLED,
276 IDS_ERRORPAGES_TITLE_ACCESS_DENIED, 280 IDS_ERRORPAGES_TITLE_ACCESS_DENIED,
277 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 281 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
278 IDS_ERRORPAGES_SUMMARY_NOT_AVAILABLE, 282 IDS_ERRORPAGES_SUMMARY_NOT_AVAILABLE,
279 IDS_ERRORPAGES_DETAILS_TEMPORARILY_THROTTLED, 283 IDS_ERRORPAGES_DETAILS_TEMPORARILY_THROTTLED,
280 SUGGEST_NONE, 284 SUGGEST_DISABLE_EXTENSION,
281 }, 285 },
282 {net::ERR_BLOCKED_BY_CLIENT, 286 {net::ERR_BLOCKED_BY_CLIENT,
283 IDS_ERRORPAGES_TITLE_BLOCKED, 287 IDS_ERRORPAGES_TITLE_BLOCKED,
284 IDS_ERRORPAGES_HEADING_BLOCKED, 288 IDS_ERRORPAGES_HEADING_BLOCKED,
285 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_EXTENSION, 289 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_EXTENSION,
286 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_EXTENSION, 290 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_EXTENSION,
287 SUGGEST_RELOAD | SUGGEST_DISABLE_EXTENSION, 291 SUGGEST_RELOAD | SUGGEST_DISABLE_EXTENSION,
288 }, 292 },
289 {net::ERR_NETWORK_CHANGED, 293 {net::ERR_NETWORK_CHANGED,
290 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 294 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
291 IDS_ERRORPAGES_HEADING_CONNECTION_INTERRUPTED, 295 IDS_ERRORPAGES_HEADING_CONNECTION_INTERRUPTED,
292 IDS_ERRORPAGES_SUMMARY_NETWORK_CHANGED, 296 IDS_ERRORPAGES_SUMMARY_NETWORK_CHANGED,
293 IDS_ERRORPAGES_DETAILS_NETWORK_CHANGED, 297 IDS_ERRORPAGES_DETAILS_NETWORK_CHANGED,
294 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION, 298 SUGGEST_RELOAD,
295 }, 299 },
296 {net::ERR_BLOCKED_BY_ADMINISTRATOR, 300 {net::ERR_BLOCKED_BY_ADMINISTRATOR,
297 IDS_ERRORPAGES_TITLE_BLOCKED, 301 IDS_ERRORPAGES_TITLE_BLOCKED,
298 IDS_ERRORPAGES_HEADING_BLOCKED, 302 IDS_ERRORPAGES_HEADING_BLOCKED,
299 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_ADMINISTRATOR, 303 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_ADMINISTRATOR,
300 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_ADMINISTRATOR, 304 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_ADMINISTRATOR,
301 SUGGEST_VIEW_POLICIES | SUGGEST_CONTACT_ADMINISTRATOR, 305 SUGGEST_VIEW_POLICIES | SUGGEST_CONTACT_ADMINISTRATOR,
302 }, 306 },
303 {net::ERR_BLOCKED_ENROLLMENT_CHECK_PENDING, 307 {net::ERR_BLOCKED_ENROLLMENT_CHECK_PENDING,
304 IDS_ERRORPAGES_TITLE_BLOCKED, 308 IDS_ERRORPAGES_TITLE_BLOCKED,
305 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 309 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
306 IDS_ERRORPAGES_SUMMARY_BLOCKED_ENROLLMENT_CHECK_PENDING, 310 IDS_ERRORPAGES_SUMMARY_BLOCKED_ENROLLMENT_CHECK_PENDING,
307 IDS_ERRORPAGES_DETAILS_BLOCKED_ENROLLMENT_CHECK_PENDING, 311 IDS_ERRORPAGES_DETAILS_BLOCKED_ENROLLMENT_CHECK_PENDING,
308 SUGGEST_CHECK_CONNECTION, 312 SUGGEST_COMPLETE_SETUP,
309 }, 313 },
310 {net::ERR_SSL_FALLBACK_BEYOND_MINIMUM_VERSION, 314 {net::ERR_SSL_FALLBACK_BEYOND_MINIMUM_VERSION,
311 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 315 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
312 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 316 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
313 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR, 317 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE,
314 IDS_ERRORPAGES_DETAILS_SSL_FALLBACK_BEYOND_MINIMUM_VERSION, 318 IDS_ERRORPAGES_DETAILS_SSL_FALLBACK_BEYOND_MINIMUM_VERSION,
315 SUGGEST_NONE, 319 SUGGEST_NONE,
316 }, 320 },
317 {net::ERR_SSL_VERSION_OR_CIPHER_MISMATCH, 321 {net::ERR_SSL_VERSION_OR_CIPHER_MISMATCH,
318 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 322 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
319 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 323 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
320 IDS_ERRORPAGES_SUMMARY_SSL_VERSION_OR_CIPHER_MISMATCH, 324 IDS_ERRORPAGES_SUMMARY_SSL_VERSION_OR_CIPHER_MISMATCH,
321 IDS_ERRORPAGES_DETAILS_SSL_VERSION_OR_CIPHER_MISMATCH, 325 IDS_ERRORPAGES_DETAILS_SSL_VERSION_OR_CIPHER_MISMATCH,
322 SUGGEST_UNSUPPORTED_CIPHER, 326 SUGGEST_UNSUPPORTED_CIPHER,
323 }, 327 },
(...skipping 24 matching lines...) Expand all
348 IDS_ERRORPAGES_DETAILS_CACHE_READ_FAILURE, 352 IDS_ERRORPAGES_DETAILS_CACHE_READ_FAILURE,
349 SUGGEST_RELOAD, 353 SUGGEST_RELOAD,
350 }; 354 };
351 355
352 const LocalizedErrorMap http_error_options[] = { 356 const LocalizedErrorMap http_error_options[] = {
353 {403, 357 {403,
354 IDS_ERRORPAGES_TITLE_ACCESS_DENIED, 358 IDS_ERRORPAGES_TITLE_ACCESS_DENIED,
355 IDS_ERRORPAGES_HEADING_ACCESS_DENIED, 359 IDS_ERRORPAGES_HEADING_ACCESS_DENIED,
356 IDS_ERRORPAGES_SUMMARY_FORBIDDEN, 360 IDS_ERRORPAGES_SUMMARY_FORBIDDEN,
357 IDS_ERRORPAGES_DETAILS_FORBIDDEN, 361 IDS_ERRORPAGES_DETAILS_FORBIDDEN,
358 SUGGEST_NONE, 362 SUGGEST_RELOAD,
359 }, 363 },
360 {410, 364 {410,
361 IDS_ERRORPAGES_TITLE_NOT_FOUND, 365 IDS_ERRORPAGES_TITLE_NOT_FOUND,
362 IDS_ERRORPAGES_HEADING_NOT_FOUND, 366 IDS_ERRORPAGES_HEADING_NOT_FOUND,
363 IDS_ERRORPAGES_SUMMARY_GONE, 367 IDS_ERRORPAGES_SUMMARY_GONE,
364 IDS_ERRORPAGES_DETAILS_GONE, 368 IDS_ERRORPAGES_DETAILS_GONE,
365 SUGGEST_NONE, 369 SUGGEST_NONE,
366 }, 370 },
367 371
368 {500, 372 {500,
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after
424 }, 428 },
425 429
426 // DNS_PROBE_FINISHED_UNKNOWN is not here; NetErrorHelper will restore the 430 // DNS_PROBE_FINISHED_UNKNOWN is not here; NetErrorHelper will restore the
427 // original error, which might be one of several DNS-related errors. 431 // original error, which might be one of several DNS-related errors.
428 432
429 {error_page::DNS_PROBE_FINISHED_NO_INTERNET, 433 {error_page::DNS_PROBE_FINISHED_NO_INTERNET,
430 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 434 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
431 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 435 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
432 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED, 436 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED,
433 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED, 437 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED,
434 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG, 438 SUGGEST_OFFLINE_CHECKS,
435 }, 439 },
436 {error_page::DNS_PROBE_FINISHED_BAD_CONFIG, 440 {error_page::DNS_PROBE_FINISHED_BAD_CONFIG,
437 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 441 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
438 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 442 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
439 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED, 443 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED,
440 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED, 444 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED,
441 SUGGEST_RELOAD | SUGGEST_DNS_CONFIG | SUGGEST_FIREWALL_CONFIG, 445 SUGGEST_RELOAD | SUGGEST_DNS_CONFIG | SUGGEST_FIREWALL_CONFIG,
442 }, 446 },
443 {error_page::DNS_PROBE_FINISHED_NXDOMAIN, 447 {error_page::DNS_PROBE_FINISHED_NXDOMAIN,
444 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 448 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
504 error_domain == net::kErrorDomain) || 508 error_domain == net::kErrorDomain) ||
505 (error_code == error_page::DNS_PROBE_FINISHED_NO_INTERNET && 509 (error_code == error_page::DNS_PROBE_FINISHED_NO_INTERNET &&
506 error_domain == error_page::kDnsProbeErrorDomain)) 510 error_domain == error_page::kDnsProbeErrorDomain))
507 return "icon-offline"; 511 return "icon-offline";
508 512
509 return "icon-generic"; 513 return "icon-generic";
510 } 514 }
511 515
512 // If the first suggestion is for a Google cache copy link. Promote the 516 // If the first suggestion is for a Google cache copy link. Promote the
513 // suggestion to a separate set of strings for displaying as a button. 517 // suggestion to a separate set of strings for displaying as a button.
514 void AddGoogleCachedCopyButton(base::ListValue* suggestions, 518 void AddGoogleCachedCopyButton(base::ListValue* suggestions_summary_list,
515 base::DictionaryValue* error_strings) { 519 base::DictionaryValue* error_strings) {
516 if (!suggestions->empty()) { 520 if (!suggestions_summary_list->empty()) {
517 base::DictionaryValue* suggestion; 521 base::DictionaryValue* suggestion;
518 suggestions->GetDictionary(0, &suggestion); 522 suggestions_summary_list->GetDictionary(0, &suggestion);
519 int type = -1; 523 int type = -1;
520 suggestion->GetInteger("type", &type); 524 suggestion->GetInteger("type", &type);
521 525
522 if (type == kGoogleCachedCopySuggestionType) { 526 if (type == kGoogleCachedCopySuggestionType) {
523 base::string16 cache_url; 527 base::string16 cache_url;
524 suggestion->GetString("urlCorrection", &cache_url); 528 suggestion->GetString("urlCorrection", &cache_url);
525 int cache_tracking_id = -1; 529 int cache_tracking_id = -1;
526 suggestion->GetInteger("trackingId", &cache_tracking_id); 530 suggestion->GetInteger("trackingId", &cache_tracking_id);
527 scoped_ptr<base::DictionaryValue> cache_button(new base::DictionaryValue); 531 scoped_ptr<base::DictionaryValue> cache_button(new base::DictionaryValue);
528 cache_button->SetString( 532 cache_button->SetString(
529 "msg", 533 "msg",
530 l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_SHOW_SAVED_COPY)); 534 l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_SHOW_SAVED_COPY));
531 cache_button->SetString("cacheUrl", cache_url); 535 cache_button->SetString("cacheUrl", cache_url);
532 cache_button->SetInteger("trackingId", cache_tracking_id); 536 cache_button->SetInteger("trackingId", cache_tracking_id);
533 error_strings->Set("cacheButton", cache_button.release()); 537 error_strings->Set("cacheButton", cache_button.release());
534 538
535 // Remove the item from suggestions dictionary so that it does not get 539 // Remove the item from suggestions dictionary so that it does not get
536 // displayed by the template in the details section. 540 // displayed by the template in the details section.
537 suggestions->Remove(0, nullptr); 541 suggestions_summary_list->Remove(0, nullptr);
538 } 542 }
539 } 543 }
544 }
545
546 // Creates a list of suggestions that a user may try to resolve a particular
547 // network error. Appears above the fold underneath heading and intro paragraph.
548 void GetSuggestionsSummaryList(int error_code,
549 base::DictionaryValue* error_strings,
550 int suggestions,
551 const std::string& locale,
552 base::ListValue* suggestions_summary_list) {
553 if (suggestions & SUGGEST_CHECK_CONNECTION) {
554 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
555 suggestion_list_item->SetString("summary",
556 l10n_util::GetStringUTF16(
557 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_SUMMARY));
558 suggestions_summary_list->Append(suggestion_list_item);
mmenke 2016/02/18 19:51:18 Hrm...We do this so much, may be worth adding a he
edwardjung 2016/02/19 18:18:22 Done. Created two helper functions to help here an
559 }
560
561 if (suggestions & SUGGEST_DNS_CONFIG &&
562 suggestions & SUGGEST_FIREWALL_CONFIG) {
mmenke 2016/02/18 19:51:19 This is correct, but I'd suggest doing: (suggestio
edwardjung 2016/02/19 18:18:21 Done.
563 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
564 suggestion_list_item->SetString("summary",
565 l10n_util::GetStringUTF16(
566 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_FIREWALL_DNS_SUMMARY));
mmenke 2016/02/18 19:51:19 So if we want to suggest checking DNS and firewall
edwardjung 2016/02/19 18:18:22 Made it clearer specifying the proxy suggestion in
567 suggestions_summary_list->Append(suggestion_list_item);
568 } else if (suggestions & SUGGEST_FIREWALL_CONFIG &&
569 suggestions & SUGGEST_AV_CONFIG) {
570 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
571 suggestion_list_item->SetString("summary",
572 l10n_util::GetStringUTF16(
573 IDS_ERRORPAGES_SUGGESTION_CHECK_FIREWALL_ANTIVIRUS_SUMMARY));
mmenke 2016/02/18 19:51:18 AV vs ANTIVIRUS - should use consistent naming.
edwardjung 2016/02/19 18:18:22 Changed to ANTIVIRUS
574 suggestions_summary_list->Append(suggestion_list_item);
575 } else if (suggestions & SUGGEST_PROXY_CONFIG &&
576 suggestions & SUGGEST_FIREWALL_CONFIG) {
577 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
578 suggestion_list_item->SetString("summary",
579 l10n_util::GetStringUTF16(
580 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_FIREWALL_SUMMARY));
581 suggestions_summary_list->Append(suggestion_list_item);
582 } else if (suggestions & SUGGEST_PROXY_CONFIG) {
583 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
584 suggestion_list_item->SetString("summary",
585 l10n_util::GetStringUTF16(
586 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_ADDRESS_SUMMARY));
587 suggestions_summary_list->Append(suggestion_list_item);
588 }
589
590 if (suggestions & SUGGEST_CONTACT_ADMINISTRATOR) {
591 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
592 if (error_code == net::ERR_PROXY_CONNECTION_FAILED) {
593 // Unprefixed suggestion which occurs in a list.
594 suggestion_list_item->SetString("summary",
595 l10n_util::GetStringUTF16(
596 IDS_ERRORPAGES_SUGGESTION_CONTACT_ADMIN_SUMMARY));
597 } else {
598 // Standalone suggestion which includes 'Try' prefix to the sentence.
599 suggestion_list_item->SetString("summary",
600 l10n_util::GetStringUTF16(
601 IDS_ERRORPAGES_SUGGESTION_CONTACT_ADMIN_SUMMARY_WITH_PREFIX));
mmenke 2016/02/18 19:51:19 The fact that this one magic suggestion appears al
edwardjung 2016/02/19 18:18:22 Added a separate suggestion to reduce reliance on
602 }
603 suggestions_summary_list->Append(suggestion_list_item);
604 }
605
606 if (suggestions & SUGGEST_LEARNMORE) {
607 GURL learn_more_url;
608 base::string16 suggestion_string;
609 switch (error_code) {
610 case net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY:
611 learn_more_url = GURL(kWeakDHKeyLearnMoreUrl);
612 suggestion_string = l10n_util::GetStringUTF16(
613 IDS_ERRORPAGES_SUGGESTION_LEARNMORE_BODY);
mmenke 2016/02/18 19:51:18 BODY -> SUMMARY
edwardjung 2016/02/19 18:18:22 Done.
614 break;
615 case net::ERR_TOO_MANY_REDIRECTS:
616 learn_more_url = GURL(kRedirectLoopLearnMoreUrl);
617 suggestion_string = l10n_util::GetStringUTF16(
618 IDS_ERRORPAGES_SUGGESTION_CLEAR_COOKIES_SUMMARY);
619 break;
620 default:
621 break;
622 }
623
624 if (learn_more_url.is_valid()) {
625 // Add the language parameter to the URL.
626 std::string query = learn_more_url.query() + "&hl=" + locale;
627 GURL::Replacements repl;
628 repl.SetQueryStr(query);
629 learn_more_url = learn_more_url.ReplaceComponents(repl);
630
631 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
632 suggestion_list_item->SetString("summary", suggestion_string);
633 suggestion_list_item->SetString("learnMoreUrl", learn_more_url.spec());
634 suggestions_summary_list->Append(suggestion_list_item);
635 }
636 }
637
638 if (suggestions & SUGGEST_OFFLINE_CHECKS) {
639 #if defined(OS_ANDROID) or defined(OS_IOS)
640 base::DictionaryValue* suggestion_list_item_airplane =
641 new base::DictionaryValue;
642 suggestion_list_item_airplane->SetString("summary",
643 l10n_util::GetStringUTF16(
644 IDS_ERRORPAGES_SUGGESTION_TURN_OFF_AIRPLANE));
mmenke 2016/02/18 19:51:18 _SUMMARY?
edwardjung 2016/02/19 18:18:22 Done.
645 suggestions_summary_list->Append(suggestion_list_item_airplane);
646
647 base::DictionaryValue* suggestion_list_item_data =
648 new base::DictionaryValue;
649 suggestion_list_item_data->SetString("summary",
650 l10n_util::GetStringUTF16(
651 IDS_ERRORPAGES_SUGGESTION_TURN_ON_DATA));
mmenke 2016/02/18 19:51:19 _SUMMARY?
edwardjung 2016/02/19 18:18:22 Done.
652 suggestions_summary_list->Append(suggestion_list_item_data);
653
654 base::DictionaryValue* suggestion_list_item_signal =
655 new base::DictionaryValue;
656 suggestion_list_item_signal->SetString("summary",
657 l10n_util::GetStringUTF16(
658 IDS_ERRORPAGES_SUGGESTION_CHECKING_SIGNAL));
mmenke 2016/02/18 19:51:18 _SUMMARY?
edwardjung 2016/02/19 18:18:22 Done.
659 suggestions_summary_list->Append(suggestion_list_item_signal);
660 #else
661 base::DictionaryValue* suggestion_list_item_cables =
662 new base::DictionaryValue;
663 suggestion_list_item_cables->SetString("summary",
664 l10n_util::GetStringUTF16(
665 IDS_ERRORPAGES_SUGGESTION_CHECK_CABLES_SUMMARY));
666 suggestions_summary_list->Append(suggestion_list_item_cables);
667
668 base::DictionaryValue* suggestion_list_item_hardware =
669 new base::DictionaryValue;
670 suggestion_list_item_hardware->SetString("summary",
671 l10n_util::GetStringUTF16(
672 IDS_ERRORPAGES_SUGGESTION_RESET_HARDWARE_SUMMARY));
673 suggestions_summary_list->Append(suggestion_list_item_hardware);
674
675 base::DictionaryValue* suggestion_list_item_wifi =
676 new base::DictionaryValue;
677 suggestion_list_item_wifi->SetString("summary",
678 l10n_util::GetStringUTF16(
679 IDS_ERRORPAGES_SUGGESTION_CHECK_WIFI_SUMMARY));
680 suggestions_summary_list->Append(suggestion_list_item_wifi);
681 #endif
682 }
683
684 if (suggestions & SUGGEST_COMPLETE_SETUP) {
685 base::DictionaryValue* suggestion_diagnose = new base::DictionaryValue;
686 suggestion_diagnose->SetString("summary",
687 l10n_util::GetStringUTF16(
688 IDS_ERRORPAGES_SUGGESTION_DIAGNOSE_CONNECTION_SUMMARY));
689 suggestions_summary_list->Append(suggestion_diagnose);
690
691 base::DictionaryValue* suggestion_complete_setup =
692 new base::DictionaryValue;
693 suggestion_complete_setup->SetString("summary",
694 l10n_util::GetStringUTF16(
695 IDS_ERRORPAGES_SUGGESTION_COMPLETE_SETUP_SUMMARY));
696 suggestions_summary_list->Append(suggestion_complete_setup);
697 }
698
699 if (suggestions & SUGGEST_DISABLE_EXTENSION) {
700 base::DictionaryValue* suggest_disable_extension =
701 new base::DictionaryValue;
702 suggest_disable_extension->SetString("summary",
703 l10n_util::GetStringUTF16(
704 IDS_ERRORPAGES_SUGGESTION_DISABLE_EXTENSION_SUMMARY));
705 suggestions_summary_list->Append(suggest_disable_extension);
706 }
707
708 // Only add a explicit reload suggestion if there are other suggestions.
709 // Otherwise we rely on the reload button being used.
mmenke 2016/02/18 19:51:19 Don't use "we" in comments.
edwardjung 2016/02/19 18:18:22 Done.
710 if (suggestions_summary_list->GetSize() > 0 && suggestions & SUGGEST_RELOAD) {
mmenke 2016/02/18 19:51:18 !suggestions_summary_list->GetSize().empty()
edwardjung 2016/02/19 18:18:22 Done.
711 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
712 suggestion_list_item->SetString("summary",
713 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_RELOAD_SUMMARY));
714 // Add as first item.
715 suggestions_summary_list->Insert(0, suggestion_list_item);
716 }
717
718 // Add list prefix header if there are suggestions except
719 // for the 'Incomplete enrollment setup'.
mmenke 2016/02/18 19:51:18 This comment doesn't seem quite correct. It shoul
edwardjung 2016/02/19 18:18:22 Corrected
720 if (suggestions_summary_list->GetSize() > 1 &&
721 !(suggestions & SUGGEST_COMPLETE_SETUP)) {
722 error_strings->SetString("suggestionsSummaryListHeader",
723 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_LIST_HEADER));
724 }
725 }
726
727 // Certain suggestions have supporting details which get displayed under
728 // the "Details" button.
729 void AddSuggestionsDetails(int error_code,
730 base::DictionaryValue* error_strings,
731 int suggestions,
732 base::ListValue* suggestions_details) {
733
mmenke 2016/02/18 19:51:18 nit: Remove blank lines.
edwardjung 2016/02/19 18:18:22 Done.
734 if (suggestions & SUGGEST_CHECK_CONNECTION) {
735 base::DictionaryValue* suggest_check_connection = new base::DictionaryValue;
736 suggest_check_connection->SetString("header",
737 l10n_util::GetStringUTF16(
738 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_HEADER));
739 suggest_check_connection->SetString("body",
740 l10n_util::GetStringUTF16(
741 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_BODY));
742 suggestions_details->Append(suggest_check_connection);
743 }
744
745 if (suggestions & SUGGEST_DNS_CONFIG) {
746 base::DictionaryValue* suggest_dns_config = new base::DictionaryValue;
747 suggest_dns_config->SetString("header",
748 l10n_util::GetStringUTF16(
749 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_HEADER));
750 suggest_dns_config->SetString("body",
751 l10n_util::GetStringUTF16(
752 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_BODY));
753 suggestions_details->Append(suggest_dns_config);
754
755 base::DictionaryValue* suggest_network_prediction =
756 GetStandardMenuItemsText();
757 suggest_network_prediction->SetString("header",
758 l10n_util::GetStringUTF16(
759 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_HEADER));
760 suggest_network_prediction->SetString("body",
761 l10n_util::GetStringUTF16(
762 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_BODY));
763 suggest_network_prediction->SetString(
764 "noNetworkPredictionTitle",
765 l10n_util::GetStringUTF16(
766 IDS_NETWORK_PREDICTION_ENABLED_DESCRIPTION));
767 suggestions_details->Append(suggest_network_prediction);
768 }
769
770 if (suggestions & SUGGEST_FIREWALL_CONFIG) {
771 base::DictionaryValue* suggest_firewall_config = new base::DictionaryValue;
772 suggest_firewall_config->SetString("header",
773 l10n_util::GetStringUTF16(
774 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_HEADER));
775 suggest_firewall_config->SetString("body",
776 l10n_util::GetStringUTF16(
777 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_BODY));
778 suggestions_details->Append(suggest_firewall_config);
779 }
780
781 if (suggestions & SUGGEST_PROXY_CONFIG) {
782 base::DictionaryValue* suggest_proxy_config = GetStandardMenuItemsText();
783 suggest_proxy_config->SetString("header",
784 l10n_util::GetStringUTF16(
785 IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_HEADER));
786 suggest_proxy_config->SetString("body",
787 l10n_util::GetStringFUTF16(IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_BODY,
788 l10n_util::GetStringUTF16(
789 IDS_ERRORPAGES_SUGGESTION_PROXY_DISABLE_PLATFORM)));
790 suggest_proxy_config->SetString("proxyTitle",
791 l10n_util::GetStringUTF16(IDS_OPTIONS_PROXIES_CONFIGURE_BUTTON));
792
793 suggestions_details->Append(suggest_proxy_config);
794 }
795
796 if (suggestions & SUGGEST_VIEW_POLICIES) {
797 base::DictionaryValue* suggest_view_policies = new base::DictionaryValue;
798 suggest_view_policies->SetString(
799 "header",
800 l10n_util::GetStringUTF16(
801 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_HEADER));
802 suggest_view_policies->SetString(
803 "body",
804 l10n_util::GetStringUTF16(
805 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_BODY));
806 suggestions_details->Append(suggest_view_policies);
807 }
808
809 if (suggestions & SUGGEST_UNSUPPORTED_CIPHER) {
810 base::DictionaryValue* suggest_unsupported_cipher =
811 new base::DictionaryValue;
812 suggest_unsupported_cipher->SetString(
813 "body",
814 l10n_util::GetStringUTF16(
815 IDS_ERRORPAGES_SUGGESTION_UNSUPPORTED_CIPHER));
816 suggestions_details->Append(suggest_unsupported_cipher);
mmenke 2016/02/18 19:51:18 Hrm...Know this was like that before, but this is
edwardjung 2016/02/19 18:18:22 Yeah, headers are currently bold so we don't want
817 }
818 }
819
820 std::string HttpErrorCodeToString(int error) {
821 return std::string("HTTP ERROR ") + base::IntToString(error);
540 } 822 }
541 823
542 } // namespace 824 } // namespace
543 825
544 const char LocalizedError::kHttpErrorDomain[] = "http"; 826 const char LocalizedError::kHttpErrorDomain[] = "http";
545 827
546 void LocalizedError::GetStrings(int error_code, 828 void LocalizedError::GetStrings(int error_code,
547 const std::string& error_domain, 829 const std::string& error_domain,
548 const GURL& failed_url, 830 const GURL& failed_url,
549 bool is_post, 831 bool is_post,
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after
644 base::string16 error_string; 926 base::string16 error_string;
645 if (error_domain == net::kErrorDomain) { 927 if (error_domain == net::kErrorDomain) {
646 // Non-internationalized error string, for debugging Chrome itself. 928 // Non-internationalized error string, for debugging Chrome itself.
647 error_string = base::ASCIIToUTF16(net::ErrorToShortString(error_code)); 929 error_string = base::ASCIIToUTF16(net::ErrorToShortString(error_code));
648 } else if (error_domain == error_page::kDnsProbeErrorDomain) { 930 } else if (error_domain == error_page::kDnsProbeErrorDomain) {
649 std::string ascii_error_string = 931 std::string ascii_error_string =
650 error_page::DnsProbeStatusToString(error_code); 932 error_page::DnsProbeStatusToString(error_code);
651 error_string = base::ASCIIToUTF16(ascii_error_string); 933 error_string = base::ASCIIToUTF16(ascii_error_string);
652 } else { 934 } else {
653 DCHECK_EQ(LocalizedError::kHttpErrorDomain, error_domain); 935 DCHECK_EQ(LocalizedError::kHttpErrorDomain, error_domain);
654 error_string = base::IntToString16(error_code); 936 error_string = base::ASCIIToUTF16(HttpErrorCodeToString(error_code));
655 } 937 }
656 error_strings->SetString("errorCode", error_string); 938 error_strings->SetString("errorCode", error_string);
657 939
658 // Platform specific information for diagnosing network issues on OSX and 940 // Platform specific information for diagnosing network issues on OSX and
659 // Windows. 941 // Windows.
660 #if (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN) 942 #if (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN)
661 if (error_domain == net::kErrorDomain && 943 if (error_domain == net::kErrorDomain &&
662 error_code == net::ERR_INTERNET_DISCONNECTED) { 944 error_code == net::ERR_INTERNET_DISCONNECTED) {
663 int platform_string_id = 945 int platform_string_id =
664 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED_PLATFORM; 946 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED_PLATFORM;
(...skipping 17 matching lines...) Expand all
682 l10n_util::GetStringUTF16(platform_string_id))); 964 l10n_util::GetStringUTF16(platform_string_id)));
683 } 965 }
684 #endif // (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN) 966 #endif // (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN)
685 967
686 // If no parameters were provided, use the defaults. 968 // If no parameters were provided, use the defaults.
687 if (!params) { 969 if (!params) {
688 params.reset(new error_page::ErrorPageParams()); 970 params.reset(new error_page::ErrorPageParams());
689 params->suggest_reload = !!(options.suggestions & SUGGEST_RELOAD); 971 params->suggest_reload = !!(options.suggestions & SUGGEST_RELOAD);
690 } 972 }
691 973
692 base::ListValue* suggestions = NULL; 974 base::ListValue* suggestions_details = NULL;
975 base::ListValue* suggestions_summary_list = NULL;
976
693 bool use_default_suggestions = true; 977 bool use_default_suggestions = true;
694 if (!params->override_suggestions) { 978 if (!params->override_suggestions) {
695 suggestions = new base::ListValue(); 979 suggestions_details = new base::ListValue();
980 suggestions_summary_list = new base::ListValue();
981 // Detailed suggestion information.
982 error_strings->Set("suggestionsDetails", suggestions_details);
696 } else { 983 } else {
697 suggestions = params->override_suggestions.release(); 984 suggestions_summary_list = params->override_suggestions.release();
698 use_default_suggestions = false; 985 use_default_suggestions = false;
699 AddGoogleCachedCopyButton(suggestions, error_strings); 986 AddGoogleCachedCopyButton(suggestions_summary_list, error_strings);
700 } 987 }
701 error_strings->Set("suggestions", suggestions); 988 error_strings->Set("suggestionsSummaryList", suggestions_summary_list);
702 989
703 if (params->search_url.is_valid()) { 990 if (params->search_url.is_valid()) {
704 error_strings->SetString("searchHeader", 991 base::DictionaryValue* search_suggestion = new base::DictionaryValue;
705 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_GOOGLE_SEARCH)); 992 search_suggestion->SetString("summary",
706 error_strings->SetString("searchUrl", params->search_url.spec()); 993 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_GOOGLE_SEARCH));
mmenke 2016/02/18 19:51:18 +_SUMMARY?
edwardjung 2016/02/19 18:18:22 Done.
707 error_strings->SetString("searchTerms", params->search_terms); 994 search_suggestion->SetString("searchUrl", params->search_url.spec() +
708 error_strings->SetInteger("searchTrackingId", params->search_tracking_id); 995 params->search_terms);
996 search_suggestion->SetString("searchTerms", params->search_terms);
997 search_suggestion->SetInteger("trackingId",
998 params->search_tracking_id);
999 suggestions_summary_list->Append(search_suggestion);
709 } 1000 }
710 1001
711 // Add the reload suggestion, if needed. 1002 // Add the reload suggestion, if needed.
712 if (params->suggest_reload) { 1003 if (params->suggest_reload) {
713 if (!is_post) { 1004 if (!is_post) {
714 base::DictionaryValue* reload_button = new base::DictionaryValue; 1005 base::DictionaryValue* reload_button = new base::DictionaryValue;
715 reload_button->SetString( 1006 reload_button->SetString(
716 "msg", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_RELOAD)); 1007 "msg", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_RELOAD));
717 reload_button->SetString("reloadUrl", failed_url.spec()); 1008 reload_button->SetString("reloadUrl", failed_url.spec());
718 error_strings->Set("reloadButton", reload_button); 1009 error_strings->Set("reloadButton", reload_button);
719 reload_button->SetInteger("reloadTrackingId", params->reload_tracking_id); 1010 reload_button->SetInteger("reloadTrackingId", params->reload_tracking_id);
720 } else { 1011 } else {
721 // If the page was created by a post, it can't be reloaded in the same 1012 // If the page was created by a post, it can't be reloaded in the same
722 // way, so just add a suggestion instead. 1013 // way, so just add a suggestion instead.
723 // TODO(mmenke): Make the reload button bring up the repost confirmation 1014 // TODO(mmenke): Make the reload button bring up the repost confirmation
724 // dialog for pages resulting from posts. 1015 // dialog for pages resulting from posts.
725 base::DictionaryValue* suggest_reload_repost = new base::DictionaryValue; 1016 base::DictionaryValue* suggest_reload_repost = new base::DictionaryValue;
726 suggest_reload_repost->SetString("header", 1017 suggest_reload_repost->SetString("summary",
727 l10n_util::GetStringUTF16(
728 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_HEADER));
729 suggest_reload_repost->SetString("body",
730 l10n_util::GetStringUTF16( 1018 l10n_util::GetStringUTF16(
731 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_BODY)); 1019 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_BODY));
mmenke 2016/02/18 19:51:19 _BODY -> _SUMMARY?
edwardjung 2016/02/19 18:18:22 Done.
1020
732 // Add at the front, so it appears before other suggestions, in the case 1021 // Add at the front, so it appears before other suggestions, in the case
733 // suggestions are being overridden by |params|. 1022 // suggestions are being overridden by |params|.
734 suggestions->Insert(0, suggest_reload_repost); 1023 suggestions_summary_list->Insert(0, suggest_reload_repost);
735 } 1024 }
736 } 1025 }
737 1026
738 // If not using the default suggestions, nothing else to do. 1027 // If not using the default suggestions, nothing else to do.
739 if (!use_default_suggestions) 1028 if (!use_default_suggestions)
740 return; 1029 return;
741 1030
1031 // Add default suggestions and any relevant supporting details.
1032 GetSuggestionsSummaryList(error_code, error_strings, options.suggestions,
1033 locale, suggestions_summary_list);
1034 AddSuggestionsDetails(error_code, error_strings, options.suggestions,
1035 suggestions_details);
1036
1037 // Add action buttons.
742 const std::string& show_saved_copy_value = 1038 const std::string& show_saved_copy_value =
743 command_line->GetSwitchValueASCII(error_page::switches::kShowSavedCopy); 1039 command_line->GetSwitchValueASCII(error_page::switches::kShowSavedCopy);
744 bool show_saved_copy_primary = 1040 bool show_saved_copy_primary =
745 (show_saved_copy_value == 1041 (show_saved_copy_value ==
746 error_page::switches::kEnableShowSavedCopyPrimary); 1042 error_page::switches::kEnableShowSavedCopyPrimary);
747 bool show_saved_copy_secondary = 1043 bool show_saved_copy_secondary =
748 (show_saved_copy_value == 1044 (show_saved_copy_value ==
749 error_page::switches::kEnableShowSavedCopySecondary); 1045 error_page::switches::kEnableShowSavedCopySecondary);
750 bool show_saved_copy_visible = 1046 bool show_saved_copy_visible =
751 (stale_copy_in_cache && !is_post && 1047 (stale_copy_in_cache && !is_post &&
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
793 #if defined(OS_CHROMEOS) 1089 #if defined(OS_CHROMEOS)
794 // ChromeOS has its own diagnostics extension, which doesn't rely on a 1090 // ChromeOS has its own diagnostics extension, which doesn't rely on a
795 // browser-initiated dialog. 1091 // browser-initiated dialog.
796 can_show_network_diagnostics_dialog = true; 1092 can_show_network_diagnostics_dialog = true;
797 #endif 1093 #endif
798 if (can_show_network_diagnostics_dialog && failed_url.is_valid() && 1094 if (can_show_network_diagnostics_dialog && failed_url.is_valid() &&
799 failed_url.SchemeIsHTTPOrHTTPS()) { 1095 failed_url.SchemeIsHTTPOrHTTPS()) {
800 error_strings->SetString( 1096 error_strings->SetString(
801 "diagnose", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_DIAGNOSE)); 1097 "diagnose", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_DIAGNOSE));
802 } 1098 }
803
804 if (options.suggestions & SUGGEST_CHECK_CONNECTION) {
805 base::DictionaryValue* suggest_check_connection = new base::DictionaryValue;
806 suggest_check_connection->SetString("header",
807 l10n_util::GetStringUTF16(
808 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_HEADER));
809 suggest_check_connection->SetString("body",
810 l10n_util::GetStringUTF16(
811 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_BODY));
812 suggestions->Append(suggest_check_connection);
813 }
814
815 if (options.suggestions & SUGGEST_DNS_CONFIG) {
816 base::DictionaryValue* suggest_dns_config = new base::DictionaryValue;
817 suggest_dns_config->SetString("header",
818 l10n_util::GetStringUTF16(
819 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_HEADER));
820 suggest_dns_config->SetString("body",
821 l10n_util::GetStringUTF16(
822 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_BODY));
823 suggestions->Append(suggest_dns_config);
824
825 base::DictionaryValue* suggest_network_prediction =
826 GetStandardMenuItemsText();
827 suggest_network_prediction->SetString("header",
828 l10n_util::GetStringUTF16(
829 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_HEADER));
830 suggest_network_prediction->SetString("body",
831 l10n_util::GetStringUTF16(
832 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_BODY));
833 suggest_network_prediction->SetString(
834 "noNetworkPredictionTitle",
835 l10n_util::GetStringUTF16(
836 IDS_NETWORK_PREDICTION_ENABLED_DESCRIPTION));
837 suggestions->Append(suggest_network_prediction);
838 }
839
840 // TODO(crbug.com/584615): Does it make sense to show all of these
841 // suggestions on mobile? Several of them seem irrelevant in the mobile
842 // context.
843 if (options.suggestions & SUGGEST_FIREWALL_CONFIG) {
844 base::DictionaryValue* suggest_firewall_config = new base::DictionaryValue;
845 suggest_firewall_config->SetString("header",
846 l10n_util::GetStringUTF16(
847 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_HEADER));
848 suggest_firewall_config->SetString("body",
849 l10n_util::GetStringUTF16(
850 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_BODY));
851 suggestions->Append(suggest_firewall_config);
852 }
853
854 if (options.suggestions & SUGGEST_PROXY_CONFIG) {
855 base::DictionaryValue* suggest_proxy_config = GetStandardMenuItemsText();
856 suggest_proxy_config->SetString("header",
857 l10n_util::GetStringUTF16(
858 IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_HEADER));
859 suggest_proxy_config->SetString("body",
860 l10n_util::GetStringFUTF16(IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_BODY,
861 l10n_util::GetStringUTF16(
862 IDS_ERRORPAGES_SUGGESTION_PROXY_DISABLE_PLATFORM)));
863 suggest_proxy_config->SetString("proxyTitle",
864 l10n_util::GetStringUTF16(IDS_OPTIONS_PROXIES_CONFIGURE_BUTTON));
865
866 suggestions->Append(suggest_proxy_config);
867 }
868
869 if (options.suggestions & SUGGEST_DISABLE_EXTENSION) {
870 base::DictionaryValue* suggest_disable_extension =
871 new base::DictionaryValue;
872 // There's only a header for this suggestion.
873 suggest_disable_extension->SetString("header",
874 l10n_util::GetStringUTF16(
875 IDS_ERRORPAGES_SUGGESTION_DISABLE_EXTENSION_HEADER));
876 suggestions->Append(suggest_disable_extension);
877 }
878
879 if (options.suggestions & SUGGEST_VIEW_POLICIES) {
880 base::DictionaryValue* suggest_view_policies = new base::DictionaryValue;
881 suggest_view_policies->SetString(
882 "header",
883 l10n_util::GetStringUTF16(
884 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_HEADER));
885 suggest_view_policies->SetString(
886 "body",
887 l10n_util::GetStringUTF16(
888 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_BODY));
889 suggestions->Append(suggest_view_policies);
890 }
891
892 if (options.suggestions & SUGGEST_CONTACT_ADMINISTRATOR) {
893 base::DictionaryValue* suggest_contant_administrator =
894 new base::DictionaryValue;
895 suggest_contant_administrator->SetString(
896 "body",
897 l10n_util::GetStringUTF16(
898 IDS_ERRORPAGES_SUGGESTION_CONTACT_ADMINISTRATOR_BODY));
899 suggestions->Append(suggest_contant_administrator);
900 }
901
902 if (options.suggestions & SUGGEST_LEARNMORE) {
903 GURL learn_more_url;
904 switch (options.error_code) {
905 case net::ERR_TOO_MANY_REDIRECTS:
906 learn_more_url = GURL(kRedirectLoopLearnMoreUrl);
907 break;
908 case net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY:
909 learn_more_url = GURL(kWeakDHKeyLearnMoreUrl);
910 break;
911 default:
912 break;
913 }
914
915 if (learn_more_url.is_valid()) {
916 // Add the language parameter to the URL.
917 std::string query = learn_more_url.query() + "&hl=" + locale;
918 GURL::Replacements repl;
919 repl.SetQueryStr(query);
920 learn_more_url = learn_more_url.ReplaceComponents(repl);
921
922 base::DictionaryValue* suggest_learn_more = new base::DictionaryValue;
923 // There's only a body for this suggestion.
924 suggest_learn_more->SetString("body",
925 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_LEARNMORE_BODY));
926 suggest_learn_more->SetString("learnMoreUrl", learn_more_url.spec());
927 suggestions->Append(suggest_learn_more);
928 }
929 }
930
931 if (options.suggestions & SUGGEST_UNSUPPORTED_CIPHER) {
932 base::DictionaryValue* suggest_unsupported_cipher =
933 new base::DictionaryValue;
934 suggest_unsupported_cipher->SetString(
935 "body",
936 l10n_util::GetStringUTF16(
937 IDS_ERRORPAGES_SUGGESTION_UNSUPPORTED_CIPHER));
938 suggestions->Append(suggest_unsupported_cipher);
939 }
940 } 1099 }
941 1100
942 base::string16 LocalizedError::GetErrorDetails(const std::string& error_domain, 1101 base::string16 LocalizedError::GetErrorDetails(const std::string& error_domain,
943 int error_code, 1102 int error_code,
944 bool is_post) { 1103 bool is_post) {
945 const LocalizedErrorMap* error_map = 1104 const LocalizedErrorMap* error_map =
946 LookupErrorMap(error_domain, error_code, is_post); 1105 LookupErrorMap(error_domain, error_code, is_post);
947 if (error_map) 1106 if (error_map)
948 return l10n_util::GetStringUTF16(error_map->details_resource_id); 1107 return l10n_util::GetStringUTF16(error_map->details_resource_id);
949 else 1108 else
950 return l10n_util::GetStringUTF16(IDS_ERRORPAGES_DETAILS_UNKNOWN); 1109 return l10n_util::GetStringUTF16(IDS_ERRORPAGES_DETAILS_UNKNOWN);
951 } 1110 }
952 1111
953 bool LocalizedError::HasStrings(const std::string& error_domain, 1112 bool LocalizedError::HasStrings(const std::string& error_domain,
954 int error_code) { 1113 int error_code) {
955 // Whether or not the there are strings for an error does not depend on 1114 // Whether or not the there are strings for an error does not depend on
956 // whether or not the page was be generated by a POST, so just claim it was 1115 // whether or not the page was be generated by a POST, so just claim it was
957 // not. 1116 // not.
958 return LookupErrorMap(error_domain, error_code, /*is_post=*/false) != NULL; 1117 return LookupErrorMap(error_domain, error_code, /*is_post=*/false) != NULL;
959 } 1118 }
960 1119
961 } // namespace error_page 1120 } // namespace error_page
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698