OLD | NEW |
---|---|
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |