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

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: Fix browser and unit tests 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 // Unprefixed suggestion which occurs in a list.
64 SUGGEST_UNSUPPORTED_CIPHER = 1 << 9, 64 SUGGEST_CONTACT_ADMINISTRATOR = 1 << 8,
65 // Standalone suggestion which cannot be mixed with others.
66 // Includes 'Try' prefix to the bulleted suggestion.
67 SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE = 1 << 9,
68 SUGGEST_UNSUPPORTED_CIPHER = 1 << 10,
69 SUGGEST_ANTIVIRUS_CONFIG = 1 << 11,
70 SUGGEST_OFFLINE_CHECKS = 1 << 13,
71 // Standalone suggestion to complete the device setup.
72 // Should not be mixed with others and is not prefixed with 'Try'.
73 SUGGEST_COMPLETE_SETUP_STANDALONE = 1 << 14,
74 // Standalone reload page suggestion for pages created by a post.
75 // Should not be mixed with others and is not prefixed with 'Try'.
76 SUGGEST_RELOAD_STANDALONE = 1 << 15,
65 }; 77 };
66 78
67 struct LocalizedErrorMap { 79 struct LocalizedErrorMap {
68 int error_code; 80 int error_code;
69 unsigned int title_resource_id; 81 unsigned int title_resource_id;
70 unsigned int heading_resource_id; 82 unsigned int heading_resource_id;
71 // Detailed summary used when the error is in the main frame. 83 // Detailed summary used when the error is in the main frame.
72 unsigned int summary_resource_id; 84 unsigned int summary_resource_id;
73 // Short one sentence description shown on mouse over when the error is in 85 // Short one sentence description shown on mouse over when the error is in
74 // a frame. 86 // a frame.
75 unsigned int details_resource_id; 87 unsigned int details_resource_id;
76 int suggestions; // Bitmap of SUGGEST_* values. 88 int suggestions; // Bitmap of SUGGEST_* values.
77 unsigned int error_explanation_id;
78 }; 89 };
79 90
80 const LocalizedErrorMap net_error_options[] = { 91 const LocalizedErrorMap net_error_options[] = {
81 {net::ERR_TIMED_OUT, 92 {net::ERR_TIMED_OUT,
82 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 93 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
83 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 94 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
84 IDS_ERRORPAGES_SUMMARY_TIMED_OUT, 95 IDS_ERRORPAGES_SUMMARY_TIMED_OUT,
85 IDS_ERRORPAGES_DETAILS_TIMED_OUT, 96 IDS_ERRORPAGES_DETAILS_TIMED_OUT,
86 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | 97 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
87 SUGGEST_PROXY_CONFIG, 98 SUGGEST_PROXY_CONFIG,
88 }, 99 },
89 {net::ERR_CONNECTION_TIMED_OUT, 100 {net::ERR_CONNECTION_TIMED_OUT,
90 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 101 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
91 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 102 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
92 IDS_ERRORPAGES_SUMMARY_TIMED_OUT, 103 IDS_ERRORPAGES_SUMMARY_TIMED_OUT,
93 IDS_ERRORPAGES_DETAILS_TIMED_OUT, 104 IDS_ERRORPAGES_DETAILS_TIMED_OUT,
94 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | 105 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
95 SUGGEST_PROXY_CONFIG, 106 SUGGEST_PROXY_CONFIG,
96 }, 107 },
97 {net::ERR_CONNECTION_CLOSED, 108 {net::ERR_CONNECTION_CLOSED,
98 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 109 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
99 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 110 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
100 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED, 111 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED,
101 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED, 112 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED,
102 SUGGEST_RELOAD, 113 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
114 SUGGEST_PROXY_CONFIG,
103 }, 115 },
104 {net::ERR_CONNECTION_RESET, 116 {net::ERR_CONNECTION_RESET,
105 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 117 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
106 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 118 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
107 IDS_ERRORPAGES_SUMMARY_CONNECTION_RESET, 119 IDS_ERRORPAGES_SUMMARY_CONNECTION_RESET,
108 IDS_ERRORPAGES_DETAILS_CONNECTION_RESET, 120 IDS_ERRORPAGES_DETAILS_CONNECTION_RESET,
109 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG | 121 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
110 SUGGEST_PROXY_CONFIG, 122 SUGGEST_PROXY_CONFIG,
111 }, 123 },
112 {net::ERR_CONNECTION_REFUSED, 124 {net::ERR_CONNECTION_REFUSED,
(...skipping 24 matching lines...) Expand all
137 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 149 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
138 IDS_ERRORPAGES_SUMMARY_ICANN_NAME_COLLISION, 150 IDS_ERRORPAGES_SUMMARY_ICANN_NAME_COLLISION,
139 IDS_ERRORPAGES_DETAILS_ICANN_NAME_COLLISION, 151 IDS_ERRORPAGES_DETAILS_ICANN_NAME_COLLISION,
140 SUGGEST_NONE, 152 SUGGEST_NONE,
141 }, 153 },
142 {net::ERR_ADDRESS_UNREACHABLE, 154 {net::ERR_ADDRESS_UNREACHABLE,
143 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 155 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
144 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 156 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
145 IDS_ERRORPAGES_SUMMARY_ADDRESS_UNREACHABLE, 157 IDS_ERRORPAGES_SUMMARY_ADDRESS_UNREACHABLE,
146 IDS_ERRORPAGES_DETAILS_ADDRESS_UNREACHABLE, 158 IDS_ERRORPAGES_DETAILS_ADDRESS_UNREACHABLE,
147 SUGGEST_RELOAD | SUGGEST_FIREWALL_CONFIG | SUGGEST_PROXY_CONFIG, 159 SUGGEST_RELOAD,
148 }, 160 },
149 {net::ERR_NETWORK_ACCESS_DENIED, 161 {net::ERR_NETWORK_ACCESS_DENIED,
150 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 162 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
151 IDS_ERRORPAGES_HEADING_NETWORK_ACCESS_DENIED, 163 IDS_ERRORPAGES_HEADING_NETWORK_ACCESS_DENIED,
152 IDS_ERRORPAGES_SUMMARY_NETWORK_ACCESS_DENIED, 164 IDS_ERRORPAGES_SUMMARY_NETWORK_ACCESS_DENIED,
153 IDS_ERRORPAGES_DETAILS_NETWORK_ACCESS_DENIED, 165 IDS_ERRORPAGES_DETAILS_NETWORK_ACCESS_DENIED,
154 SUGGEST_FIREWALL_CONFIG, 166 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG |
167 SUGGEST_ANTIVIRUS_CONFIG,
155 }, 168 },
156 {net::ERR_PROXY_CONNECTION_FAILED, 169 {net::ERR_PROXY_CONNECTION_FAILED,
157 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 170 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
158 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 171 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
159 IDS_ERRORPAGES_SUMMARY_PROXY_CONNECTION_FAILED, 172 IDS_ERRORPAGES_SUMMARY_PROXY_CONNECTION_FAILED,
160 IDS_ERRORPAGES_DETAILS_PROXY_CONNECTION_FAILED, 173 IDS_ERRORPAGES_DETAILS_PROXY_CONNECTION_FAILED,
161 SUGGEST_PROXY_CONFIG, 174 SUGGEST_PROXY_CONFIG | SUGGEST_CONTACT_ADMINISTRATOR,
162 }, 175 },
163 {net::ERR_INTERNET_DISCONNECTED, 176 {net::ERR_INTERNET_DISCONNECTED,
164 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 177 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
165 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 178 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
166 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED, 179 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED,
167 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED, 180 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED,
168 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG, 181 SUGGEST_OFFLINE_CHECKS,
169 }, 182 },
170 {net::ERR_FILE_NOT_FOUND, 183 {net::ERR_FILE_NOT_FOUND,
171 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 184 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
172 IDS_ERRORPAGES_HEADING_FILE_NOT_FOUND, 185 IDS_ERRORPAGES_HEADING_FILE_NOT_FOUND,
173 IDS_ERRORPAGES_SUMMARY_FILE_NOT_FOUND, 186 IDS_ERRORPAGES_SUMMARY_FILE_NOT_FOUND,
174 IDS_ERRORPAGES_DETAILS_FILE_NOT_FOUND, 187 IDS_ERRORPAGES_DETAILS_FILE_NOT_FOUND,
175 SUGGEST_RELOAD, 188 SUGGEST_RELOAD,
176 }, 189 },
177 {net::ERR_CACHE_MISS, 190 {net::ERR_CACHE_MISS,
178 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 191 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
242 IDS_ERRORPAGES_HEADING_PAGE_NOT_WORKING, 255 IDS_ERRORPAGES_HEADING_PAGE_NOT_WORKING,
243 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED, 256 IDS_ERRORPAGES_SUMMARY_CONNECTION_CLOSED,
244 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED, 257 IDS_ERRORPAGES_DETAILS_CONNECTION_CLOSED,
245 SUGGEST_RELOAD, 258 SUGGEST_RELOAD,
246 }, 259 },
247 {net::ERR_SSL_PROTOCOL_ERROR, 260 {net::ERR_SSL_PROTOCOL_ERROR,
248 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 261 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
249 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 262 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
250 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE, 263 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE,
251 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR, 264 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR,
252 SUGGEST_NONE, 265 SUGGEST_RELOAD,
253 }, 266 },
254 {net::ERR_BAD_SSL_CLIENT_AUTH_CERT, 267 {net::ERR_BAD_SSL_CLIENT_AUTH_CERT,
255 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 268 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
256 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 269 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
257 IDS_ERRORPAGES_SUMMARY_BAD_SSL_CLIENT_AUTH_CERT, 270 IDS_ERRORPAGES_SUMMARY_BAD_SSL_CLIENT_AUTH_CERT,
258 IDS_ERRORPAGES_DETAILS_BAD_SSL_CLIENT_AUTH_CERT, 271 IDS_ERRORPAGES_DETAILS_BAD_SSL_CLIENT_AUTH_CERT,
259 SUGGEST_NONE, 272 SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE,
260 }, 273 },
261 {net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY, 274 {net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY,
262 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 275 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
263 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 276 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
264 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR, 277 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR,
265 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR, 278 IDS_ERRORPAGES_DETAILS_SSL_PROTOCOL_ERROR,
266 SUGGEST_LEARNMORE, 279 SUGGEST_LEARNMORE,
267 }, 280 },
268 {net::ERR_SSL_PINNED_KEY_NOT_IN_CERT_CHAIN, 281 {net::ERR_SSL_PINNED_KEY_NOT_IN_CERT_CHAIN,
269 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 282 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
270 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 283 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
271 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DETAILS, 284 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DETAILS,
272 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DESCRIPTION, 285 IDS_CERT_ERROR_SUMMARY_PINNING_FAILURE_DESCRIPTION,
273 SUGGEST_NONE, 286 SUGGEST_NONE,
274 }, 287 },
275 {net::ERR_TEMPORARILY_THROTTLED, 288 {net::ERR_TEMPORARILY_THROTTLED,
276 IDS_ERRORPAGES_TITLE_ACCESS_DENIED, 289 IDS_ERRORPAGES_TITLE_ACCESS_DENIED,
277 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 290 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
278 IDS_ERRORPAGES_SUMMARY_NOT_AVAILABLE, 291 IDS_ERRORPAGES_SUMMARY_NOT_AVAILABLE,
279 IDS_ERRORPAGES_DETAILS_TEMPORARILY_THROTTLED, 292 IDS_ERRORPAGES_DETAILS_TEMPORARILY_THROTTLED,
280 SUGGEST_NONE, 293 SUGGEST_DISABLE_EXTENSION,
281 }, 294 },
282 {net::ERR_BLOCKED_BY_CLIENT, 295 {net::ERR_BLOCKED_BY_CLIENT,
283 IDS_ERRORPAGES_TITLE_BLOCKED, 296 IDS_ERRORPAGES_TITLE_BLOCKED,
284 IDS_ERRORPAGES_HEADING_BLOCKED, 297 IDS_ERRORPAGES_HEADING_BLOCKED,
285 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_EXTENSION, 298 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_EXTENSION,
286 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_EXTENSION, 299 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_EXTENSION,
287 SUGGEST_RELOAD | SUGGEST_DISABLE_EXTENSION, 300 SUGGEST_RELOAD | SUGGEST_DISABLE_EXTENSION,
288 }, 301 },
289 {net::ERR_NETWORK_CHANGED, 302 {net::ERR_NETWORK_CHANGED,
290 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 303 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
291 IDS_ERRORPAGES_HEADING_CONNECTION_INTERRUPTED, 304 IDS_ERRORPAGES_HEADING_CONNECTION_INTERRUPTED,
292 IDS_ERRORPAGES_SUMMARY_NETWORK_CHANGED, 305 IDS_ERRORPAGES_SUMMARY_NETWORK_CHANGED,
293 IDS_ERRORPAGES_DETAILS_NETWORK_CHANGED, 306 IDS_ERRORPAGES_DETAILS_NETWORK_CHANGED,
294 SUGGEST_RELOAD | SUGGEST_CHECK_CONNECTION, 307 SUGGEST_RELOAD,
295 }, 308 },
296 {net::ERR_BLOCKED_BY_ADMINISTRATOR, 309 {net::ERR_BLOCKED_BY_ADMINISTRATOR,
297 IDS_ERRORPAGES_TITLE_BLOCKED, 310 IDS_ERRORPAGES_TITLE_BLOCKED,
298 IDS_ERRORPAGES_HEADING_BLOCKED, 311 IDS_ERRORPAGES_HEADING_BLOCKED,
299 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_ADMINISTRATOR, 312 IDS_ERRORPAGES_SUMMARY_BLOCKED_BY_ADMINISTRATOR,
300 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_ADMINISTRATOR, 313 IDS_ERRORPAGES_DETAILS_BLOCKED_BY_ADMINISTRATOR,
301 SUGGEST_VIEW_POLICIES | SUGGEST_CONTACT_ADMINISTRATOR, 314 SUGGEST_VIEW_POLICIES | SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE,
302 }, 315 },
303 {net::ERR_BLOCKED_ENROLLMENT_CHECK_PENDING, 316 {net::ERR_BLOCKED_ENROLLMENT_CHECK_PENDING,
304 IDS_ERRORPAGES_TITLE_BLOCKED, 317 IDS_ERRORPAGES_TITLE_BLOCKED,
305 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 318 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
306 IDS_ERRORPAGES_SUMMARY_BLOCKED_ENROLLMENT_CHECK_PENDING, 319 IDS_ERRORPAGES_SUMMARY_BLOCKED_ENROLLMENT_CHECK_PENDING,
307 IDS_ERRORPAGES_DETAILS_BLOCKED_ENROLLMENT_CHECK_PENDING, 320 IDS_ERRORPAGES_DETAILS_BLOCKED_ENROLLMENT_CHECK_PENDING,
308 SUGGEST_CHECK_CONNECTION, 321 SUGGEST_COMPLETE_SETUP_STANDALONE,
309 }, 322 },
310 {net::ERR_SSL_FALLBACK_BEYOND_MINIMUM_VERSION, 323 {net::ERR_SSL_FALLBACK_BEYOND_MINIMUM_VERSION,
311 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 324 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
312 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 325 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
313 IDS_ERRORPAGES_SUMMARY_SSL_SECURITY_ERROR, 326 IDS_ERRORPAGES_SUMMARY_INVALID_RESPONSE,
314 IDS_ERRORPAGES_DETAILS_SSL_FALLBACK_BEYOND_MINIMUM_VERSION, 327 IDS_ERRORPAGES_DETAILS_SSL_FALLBACK_BEYOND_MINIMUM_VERSION,
315 SUGGEST_NONE, 328 SUGGEST_NONE,
316 }, 329 },
317 {net::ERR_SSL_VERSION_OR_CIPHER_MISMATCH, 330 {net::ERR_SSL_VERSION_OR_CIPHER_MISMATCH,
318 IDS_ERRORPAGES_TITLE_LOAD_FAILED, 331 IDS_ERRORPAGES_TITLE_LOAD_FAILED,
319 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION, 332 IDS_ERRORPAGES_HEADING_INSECURE_CONNECTION,
320 IDS_ERRORPAGES_SUMMARY_SSL_VERSION_OR_CIPHER_MISMATCH, 333 IDS_ERRORPAGES_SUMMARY_SSL_VERSION_OR_CIPHER_MISMATCH,
321 IDS_ERRORPAGES_DETAILS_SSL_VERSION_OR_CIPHER_MISMATCH, 334 IDS_ERRORPAGES_DETAILS_SSL_VERSION_OR_CIPHER_MISMATCH,
322 SUGGEST_UNSUPPORTED_CIPHER, 335 SUGGEST_UNSUPPORTED_CIPHER,
323 }, 336 },
(...skipping 15 matching lines...) Expand all
339 352
340 // Special error page to be used in the case of navigating back to a page 353 // Special error page to be used in the case of navigating back to a page
341 // generated by a POST. LocalizedError::HasStrings expects this net error code 354 // generated by a POST. LocalizedError::HasStrings expects this net error code
342 // to also appear in the array above. 355 // to also appear in the array above.
343 const LocalizedErrorMap repost_error = { 356 const LocalizedErrorMap repost_error = {
344 net::ERR_CACHE_MISS, 357 net::ERR_CACHE_MISS,
345 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 358 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
346 IDS_HTTP_POST_WARNING_TITLE, 359 IDS_HTTP_POST_WARNING_TITLE,
347 IDS_ERRORPAGES_HTTP_POST_WARNING, 360 IDS_ERRORPAGES_HTTP_POST_WARNING,
348 IDS_ERRORPAGES_DETAILS_CACHE_READ_FAILURE, 361 IDS_ERRORPAGES_DETAILS_CACHE_READ_FAILURE,
349 SUGGEST_RELOAD, 362 SUGGEST_RELOAD_STANDALONE,
350 }; 363 };
351 364
352 const LocalizedErrorMap http_error_options[] = { 365 const LocalizedErrorMap http_error_options[] = {
353 {403, 366 {403,
354 IDS_ERRORPAGES_TITLE_ACCESS_DENIED, 367 IDS_ERRORPAGES_TITLE_ACCESS_DENIED,
355 IDS_ERRORPAGES_HEADING_ACCESS_DENIED, 368 IDS_ERRORPAGES_HEADING_ACCESS_DENIED,
356 IDS_ERRORPAGES_SUMMARY_FORBIDDEN, 369 IDS_ERRORPAGES_SUMMARY_FORBIDDEN,
357 IDS_ERRORPAGES_DETAILS_FORBIDDEN, 370 IDS_ERRORPAGES_DETAILS_FORBIDDEN,
358 SUGGEST_NONE, 371 SUGGEST_RELOAD,
359 }, 372 },
360 {410, 373 {410,
361 IDS_ERRORPAGES_TITLE_NOT_FOUND, 374 IDS_ERRORPAGES_TITLE_NOT_FOUND,
362 IDS_ERRORPAGES_HEADING_NOT_FOUND, 375 IDS_ERRORPAGES_HEADING_NOT_FOUND,
363 IDS_ERRORPAGES_SUMMARY_GONE, 376 IDS_ERRORPAGES_SUMMARY_GONE,
364 IDS_ERRORPAGES_DETAILS_GONE, 377 IDS_ERRORPAGES_DETAILS_GONE,
365 SUGGEST_NONE, 378 SUGGEST_NONE,
366 }, 379 },
367 380
368 {500, 381 {500,
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after
424 }, 437 },
425 438
426 // DNS_PROBE_FINISHED_UNKNOWN is not here; NetErrorHelper will restore the 439 // DNS_PROBE_FINISHED_UNKNOWN is not here; NetErrorHelper will restore the
427 // original error, which might be one of several DNS-related errors. 440 // original error, which might be one of several DNS-related errors.
428 441
429 {error_page::DNS_PROBE_FINISHED_NO_INTERNET, 442 {error_page::DNS_PROBE_FINISHED_NO_INTERNET,
430 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 443 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
431 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED, 444 IDS_ERRORPAGES_HEADING_INTERNET_DISCONNECTED,
432 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED, 445 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED,
433 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED, 446 IDS_ERRORPAGES_DETAILS_INTERNET_DISCONNECTED,
434 SUGGEST_CHECK_CONNECTION | SUGGEST_FIREWALL_CONFIG, 447 SUGGEST_OFFLINE_CHECKS,
435 }, 448 },
436 {error_page::DNS_PROBE_FINISHED_BAD_CONFIG, 449 {error_page::DNS_PROBE_FINISHED_BAD_CONFIG,
437 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 450 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
438 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 451 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
439 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED, 452 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED,
440 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED, 453 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED,
441 SUGGEST_RELOAD | SUGGEST_DNS_CONFIG | SUGGEST_FIREWALL_CONFIG, 454 SUGGEST_RELOAD | SUGGEST_DNS_CONFIG | SUGGEST_FIREWALL_CONFIG |
455 SUGGEST_PROXY_CONFIG,
442 }, 456 },
443 {error_page::DNS_PROBE_FINISHED_NXDOMAIN, 457 {error_page::DNS_PROBE_FINISHED_NXDOMAIN,
444 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE, 458 IDS_ERRORPAGES_TITLE_NOT_AVAILABLE,
445 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE, 459 IDS_ERRORPAGES_HEADING_NOT_AVAILABLE,
446 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED, 460 IDS_ERRORPAGES_SUMMARY_NAME_NOT_RESOLVED,
447 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED, 461 IDS_ERRORPAGES_DETAILS_NAME_NOT_RESOLVED,
448 SUGGEST_RELOAD, 462 SUGGEST_RELOAD,
449 }, 463 },
450 }; 464 };
451 465
452 const LocalizedErrorMap* FindErrorMapInArray(const LocalizedErrorMap* maps, 466 const LocalizedErrorMap* FindErrorMapInArray(const LocalizedErrorMap* maps,
453 size_t num_maps, 467 size_t num_maps,
454 int error_code) { 468 int error_code) {
455 for (size_t i = 0; i < num_maps; ++i) { 469 for (size_t i = 0; i < num_maps; ++i) {
456 if (maps[i].error_code == error_code) 470 if (maps[i].error_code == error_code)
457 return &maps[i]; 471 return &maps[i];
458 } 472 }
459 return NULL; 473 return nullptr;
460 } 474 }
461 475
462 const LocalizedErrorMap* LookupErrorMap(const std::string& error_domain, 476 const LocalizedErrorMap* LookupErrorMap(const std::string& error_domain,
463 int error_code, bool is_post) { 477 int error_code, bool is_post) {
464 if (error_domain == net::kErrorDomain) { 478 if (error_domain == net::kErrorDomain) {
465 // Display a different page in the special case of navigating through the 479 // Display a different page in the special case of navigating through the
466 // history to an uncached page created by a POST. 480 // history to an uncached page created by a POST.
467 if (is_post && error_code == net::ERR_CACHE_MISS) 481 if (is_post && error_code == net::ERR_CACHE_MISS)
468 return &repost_error; 482 return &repost_error;
469 return FindErrorMapInArray(net_error_options, 483 return FindErrorMapInArray(net_error_options,
470 arraysize(net_error_options), 484 arraysize(net_error_options),
471 error_code); 485 error_code);
472 } else if (error_domain == LocalizedError::kHttpErrorDomain) { 486 } else if (error_domain == LocalizedError::kHttpErrorDomain) {
473 return FindErrorMapInArray(http_error_options, 487 return FindErrorMapInArray(http_error_options,
474 arraysize(http_error_options), 488 arraysize(http_error_options),
475 error_code); 489 error_code);
476 } else if (error_domain == error_page::kDnsProbeErrorDomain) { 490 } else if (error_domain == error_page::kDnsProbeErrorDomain) {
477 const LocalizedErrorMap* map = 491 const LocalizedErrorMap* map =
478 FindErrorMapInArray(dns_probe_error_options, 492 FindErrorMapInArray(dns_probe_error_options,
479 arraysize(dns_probe_error_options), 493 arraysize(dns_probe_error_options),
480 error_code); 494 error_code);
481 DCHECK(map); 495 DCHECK(map);
482 return map; 496 return map;
483 } else { 497 } else {
484 NOTREACHED(); 498 NOTREACHED();
485 return NULL; 499 return nullptr;
486 } 500 }
487 } 501 }
488 502
489 // Returns a dictionary containing the strings for the settings menu under the 503 // Returns a dictionary containing the strings for the settings menu under the
490 // app menu, and the advanced settings button. 504 // app menu, and the advanced settings button.
491 base::DictionaryValue* GetStandardMenuItemsText() { 505 base::DictionaryValue* GetStandardMenuItemsText() {
492 base::DictionaryValue* standard_menu_items_text = new base::DictionaryValue(); 506 base::DictionaryValue* standard_menu_items_text = new base::DictionaryValue();
493 standard_menu_items_text->SetString("settingsTitle", 507 standard_menu_items_text->SetString("settingsTitle",
494 l10n_util::GetStringUTF16(IDS_SETTINGS_TITLE)); 508 l10n_util::GetStringUTF16(IDS_SETTINGS_TITLE));
495 standard_menu_items_text->SetString("advancedTitle", 509 standard_menu_items_text->SetString("advancedTitle",
496 l10n_util::GetStringUTF16(IDS_SETTINGS_SHOW_ADVANCED_SETTINGS)); 510 l10n_util::GetStringUTF16(IDS_SETTINGS_SHOW_ADVANCED_SETTINGS));
497 return standard_menu_items_text; 511 return standard_menu_items_text;
498 } 512 }
499 513
500 // Gets the icon class for a given |error_domain| and |error_code|. 514 // Gets the icon class for a given |error_domain| and |error_code|.
501 const char* GetIconClassForError(const std::string& error_domain, 515 const char* GetIconClassForError(const std::string& error_domain,
502 int error_code) { 516 int error_code) {
503 if ((error_code == net::ERR_INTERNET_DISCONNECTED && 517 if ((error_code == net::ERR_INTERNET_DISCONNECTED &&
504 error_domain == net::kErrorDomain) || 518 error_domain == net::kErrorDomain) ||
505 (error_code == error_page::DNS_PROBE_FINISHED_NO_INTERNET && 519 (error_code == error_page::DNS_PROBE_FINISHED_NO_INTERNET &&
506 error_domain == error_page::kDnsProbeErrorDomain)) 520 error_domain == error_page::kDnsProbeErrorDomain))
507 return "icon-offline"; 521 return "icon-offline";
508 522
509 return "icon-generic"; 523 return "icon-generic";
510 } 524 }
511 525
512 // If the first suggestion is for a Google cache copy link. Promote the 526 // 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. 527 // suggestion to a separate set of strings for displaying as a button.
514 void AddGoogleCachedCopyButton(base::ListValue* suggestions, 528 void AddGoogleCachedCopyButton(base::ListValue* suggestions_summary_list,
515 base::DictionaryValue* error_strings) { 529 base::DictionaryValue* error_strings) {
516 if (!suggestions->empty()) { 530 if (!suggestions_summary_list->empty()) {
517 base::DictionaryValue* suggestion; 531 base::DictionaryValue* suggestion;
518 suggestions->GetDictionary(0, &suggestion); 532 suggestions_summary_list->GetDictionary(0, &suggestion);
519 int type = -1; 533 int type = -1;
520 suggestion->GetInteger("type", &type); 534 suggestion->GetInteger("type", &type);
521 535
522 if (type == kGoogleCachedCopySuggestionType) { 536 if (type == kGoogleCachedCopySuggestionType) {
523 base::string16 cache_url; 537 base::string16 cache_url;
524 suggestion->GetString("urlCorrection", &cache_url); 538 suggestion->GetString("urlCorrection", &cache_url);
525 int cache_tracking_id = -1; 539 int cache_tracking_id = -1;
526 suggestion->GetInteger("trackingId", &cache_tracking_id); 540 suggestion->GetInteger("trackingId", &cache_tracking_id);
527 scoped_ptr<base::DictionaryValue> cache_button(new base::DictionaryValue); 541 scoped_ptr<base::DictionaryValue> cache_button(new base::DictionaryValue);
528 cache_button->SetString( 542 cache_button->SetString(
529 "msg", 543 "msg",
530 l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_SHOW_SAVED_COPY)); 544 l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_SHOW_SAVED_COPY));
531 cache_button->SetString("cacheUrl", cache_url); 545 cache_button->SetString("cacheUrl", cache_url);
532 cache_button->SetInteger("trackingId", cache_tracking_id); 546 cache_button->SetInteger("trackingId", cache_tracking_id);
533 error_strings->Set("cacheButton", cache_button.release()); 547 error_strings->Set("cacheButton", cache_button.release());
534 548
535 // Remove the item from suggestions dictionary so that it does not get 549 // Remove the item from suggestions dictionary so that it does not get
536 // displayed by the template in the details section. 550 // displayed by the template in the details section.
537 suggestions->Remove(0, nullptr); 551 suggestions_summary_list->Remove(0, nullptr);
538 } 552 }
539 } 553 }
540 } 554 }
541 555
556 // Helper function that creates a single entry dictionary and adds it
557 // to a ListValue,
558 void AddSingleEntryDictionaryToList(base::ListValue* list,
559 const char* path,
560 int message_id,
561 bool insert_as_first_item) {
562 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
563 suggestion_list_item->SetString(path, l10n_util::GetStringUTF16(message_id));
564
565 if (insert_as_first_item) {
566 list->Insert(0, suggestion_list_item);
567 } else {
568 list->Append(suggestion_list_item);
569 }
570 }
571
572 // Creates a list of suggestions that a user may try to resolve a particular
573 // network error. Appears above the fold underneath heading and intro paragraph.
574 void GetSuggestionsSummaryList(int error_code,
575 base::DictionaryValue* error_strings,
576 int suggestions,
577 const std::string& locale,
578 base::ListValue* suggestions_summary_list) {
579 if (suggestions & SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE) {
580 DCHECK(suggestions_summary_list->empty());
581 DCHECK(!((suggestions & ~SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE) &&
582 (suggestions & ~SUGGEST_VIEW_POLICIES)));
583 DCHECK(suggestions & ~SUGGEST_COMPLETE_SETUP_STANDALONE);
584 DCHECK(suggestions & ~SUGGEST_RELOAD_STANDALONE);
585 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
586 IDS_ERRORPAGES_SUGGESTION_CONTACT_ADMIN_SUMMARY_WITH_PREFIX, false);
587 return;
588 }
589
590 if (suggestions & SUGGEST_COMPLETE_SETUP_STANDALONE) {
591 DCHECK(suggestions_summary_list->empty());
592 DCHECK(!(suggestions & ~SUGGEST_COMPLETE_SETUP_STANDALONE));
593 DCHECK(suggestions & ~SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE);
594 DCHECK(suggestions & ~SUGGEST_RELOAD_STANDALONE);
595 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
596 IDS_ERRORPAGES_SUGGESTION_DIAGNOSE_CONNECTION_SUMMARY, false);
597 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
598 IDS_ERRORPAGES_SUGGESTION_COMPLETE_SETUP_SUMMARY, false);
599 return;
600 }
601
602 if (suggestions & SUGGEST_RELOAD_STANDALONE) {
603 DCHECK(suggestions_summary_list->empty());
604 DCHECK(!(suggestions & ~SUGGEST_RELOAD_STANDALONE));
605 DCHECK(suggestions & ~SUGGEST_CONTACT_ADMINISTRATOR_STANDALONE);
606 DCHECK(suggestions & ~SUGGEST_COMPLETE_SETUP_STANDALONE);
607 // If the page was created by a post, it can't be reloaded in the same
608 // way, so just add a suggestion instead.
609 // TODO(mmenke): Make the reload button bring up the repost confirmation
610 // dialog for pages resulting from posts.
611 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
612 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_SUMMARY, false);
613 return;
614 }
615
616 if (suggestions & SUGGEST_CHECK_CONNECTION) {
617 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
618 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_SUMMARY, false);
619 }
620
621 if ((suggestions & SUGGEST_DNS_CONFIG) &&
622 (suggestions & SUGGEST_FIREWALL_CONFIG) &&
623 (suggestions & SUGGEST_PROXY_CONFIG)) {
624 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
625 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_FIREWALL_DNS_SUMMARY, false);
626 } else if ((suggestions & SUGGEST_FIREWALL_CONFIG) &&
627 (suggestions & SUGGEST_ANTIVIRUS_CONFIG)) {
628 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
629 IDS_ERRORPAGES_SUGGESTION_CHECK_FIREWALL_ANTIVIRUS_SUMMARY, false);
630 } else if ((suggestions & SUGGEST_PROXY_CONFIG) &&
631 (suggestions & SUGGEST_FIREWALL_CONFIG)) {
632 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
633 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_FIREWALL_SUMMARY, false);
634 } else if (suggestions & SUGGEST_PROXY_CONFIG) {
635 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
636 IDS_ERRORPAGES_SUGGESTION_CHECK_PROXY_ADDRESS_SUMMARY, false);
637 } else {
638 DCHECK(!(suggestions & SUGGEST_PROXY_CONFIG));
639 DCHECK(!(suggestions & SUGGEST_FIREWALL_CONFIG));
640 DCHECK(!(suggestions & SUGGEST_DNS_CONFIG));
641 }
642
643 if (suggestions & SUGGEST_CONTACT_ADMINISTRATOR) {
644 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
645 IDS_ERRORPAGES_SUGGESTION_CONTACT_ADMIN_SUMMARY, false);
646 }
647
648 if (suggestions & SUGGEST_OFFLINE_CHECKS) {
649 #if defined(OS_ANDROID) || defined(OS_IOS)
650 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
651 IDS_ERRORPAGES_SUGGESTION_TURN_OFF_AIRPLANE_SUMMARY, false);
652 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
653 IDS_ERRORPAGES_SUGGESTION_TURN_ON_DATA_SUMMARY, false);
654 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
655 IDS_ERRORPAGES_SUGGESTION_CHECKING_SIGNAL_SUMMARY, false);
656 #else
657 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
658 IDS_ERRORPAGES_SUGGESTION_CHECK_CABLES_SUMMARY, false);
659 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
660 IDS_ERRORPAGES_SUGGESTION_RESET_HARDWARE_SUMMARY, false);
661 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
662 IDS_ERRORPAGES_SUGGESTION_CHECK_WIFI_SUMMARY, false);
663 #endif
664 }
665
666 if (suggestions & SUGGEST_DISABLE_EXTENSION) {
667 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
668 IDS_ERRORPAGES_SUGGESTION_DISABLE_EXTENSION_SUMMARY, false);
669 }
670
671 if (suggestions & SUGGEST_LEARNMORE) {
672 GURL learn_more_url;
673 base::string16 suggestion_string;
674 switch (error_code) {
675 case net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY:
676 learn_more_url = GURL(kWeakDHKeyLearnMoreUrl);
677 suggestion_string = l10n_util::GetStringUTF16(
678 IDS_ERRORPAGES_SUGGESTION_LEARNMORE_SUMMARY);
679 break;
680 case net::ERR_TOO_MANY_REDIRECTS:
681 learn_more_url = GURL(kRedirectLoopLearnMoreUrl);
682 suggestion_string = l10n_util::GetStringUTF16(
683 IDS_ERRORPAGES_SUGGESTION_CLEAR_COOKIES_SUMMARY);
684 break;
685 default:
686 NOTREACHED();
687 break;
688 }
689
690 DCHECK(learn_more_url.is_valid());
691 // Add the language parameter to the URL.
692 std::string query = learn_more_url.query() + "&hl=" + locale;
693 GURL::Replacements repl;
694 repl.SetQueryStr(query);
695 learn_more_url = learn_more_url.ReplaceComponents(repl);
696
697 base::DictionaryValue* suggestion_list_item = new base::DictionaryValue;
698 suggestion_list_item->SetString("summary", suggestion_string);
699 suggestion_list_item->SetString("learnMoreUrl", learn_more_url.spec());
700 suggestions_summary_list->Append(suggestion_list_item);
701 }
702
703 // Only add a explicit reload suggestion if there are other suggestions.
704 // Otherwise rely on the reload button being used.
705 if (!suggestions_summary_list->empty() && (suggestions & SUGGEST_RELOAD)) {
706 AddSingleEntryDictionaryToList(suggestions_summary_list, "summary",
707 IDS_ERRORPAGES_SUGGESTION_RELOAD_SUMMARY, true);
708 }
709
710 // Add list prefix header.
711 error_strings->SetString("suggestionsSummaryListHeader",
712 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_LIST_HEADER));
713 }
714
715 // Creates a dictionary with "header" and "body" entries and adds it
716 // to a ListValue, Returns the dictionary to allow further items to be added.
717 base::DictionaryValue* AddSuggestionDetailDictionaryToList(
718 base::ListValue* list,
719 int header_message_id,
720 int body_message_id,
721 bool append_standard_menu_items) {
722 base::DictionaryValue* suggestion_list_item;
723 if (append_standard_menu_items) {
724 suggestion_list_item = GetStandardMenuItemsText();
725 } else {
726 suggestion_list_item = new base::DictionaryValue;
727 }
728
729 if (header_message_id) {
730 suggestion_list_item->SetString("header",
731 l10n_util::GetStringUTF16(header_message_id));
732 }
733 if (body_message_id) {
734 suggestion_list_item->SetString("body",
735 l10n_util::GetStringUTF16(body_message_id));
736 }
737 list->Append(suggestion_list_item);
738 return suggestion_list_item;
739 }
740
741 // Certain suggestions have supporting details which get displayed under
742 // the "Details" button.
743 void AddSuggestionsDetails(int error_code,
744 base::DictionaryValue* error_strings,
745 int suggestions,
746 base::ListValue* suggestions_details) {
747 if (suggestions & SUGGEST_CHECK_CONNECTION) {
748 AddSuggestionDetailDictionaryToList(suggestions_details,
749 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_HEADER,
750 IDS_ERRORPAGES_SUGGESTION_CHECK_CONNECTION_BODY, false);
751 }
752
753 if (suggestions & SUGGEST_DNS_CONFIG) {
754 AddSuggestionDetailDictionaryToList(suggestions_details,
755 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_HEADER,
756 IDS_ERRORPAGES_SUGGESTION_DNS_CONFIG_BODY, false);
757
758 base::DictionaryValue* suggest_network_prediction =
759 AddSuggestionDetailDictionaryToList(suggestions_details,
760 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_HEADER,
761 IDS_ERRORPAGES_SUGGESTION_NETWORK_PREDICTION_BODY, true);
762
763 suggest_network_prediction->SetString(
764 "noNetworkPredictionTitle",
765 l10n_util::GetStringUTF16(
766 IDS_NETWORK_PREDICTION_ENABLED_DESCRIPTION));
767 }
768
769 if (suggestions & SUGGEST_FIREWALL_CONFIG) {
770 AddSuggestionDetailDictionaryToList(suggestions_details,
771 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_HEADER,
772 IDS_ERRORPAGES_SUGGESTION_FIREWALL_CONFIG_BODY, false);
773 }
774
775 if (suggestions & SUGGEST_PROXY_CONFIG) {
776 base::DictionaryValue* suggest_proxy_config =
777 AddSuggestionDetailDictionaryToList(suggestions_details,
778 IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_HEADER,
779 0, true);
780
781 // Custom body string.
782 suggest_proxy_config->SetString("body",
783 l10n_util::GetStringFUTF16(IDS_ERRORPAGES_SUGGESTION_PROXY_CONFIG_BODY,
784 l10n_util::GetStringUTF16(
785 IDS_ERRORPAGES_SUGGESTION_PROXY_DISABLE_PLATFORM)));
786
787 suggest_proxy_config->SetString("proxyTitle",
788 l10n_util::GetStringUTF16(IDS_OPTIONS_PROXIES_CONFIGURE_BUTTON));
789 }
790
791 if (suggestions & SUGGEST_VIEW_POLICIES) {
792 AddSuggestionDetailDictionaryToList(suggestions_details,
793 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_HEADER,
794 IDS_ERRORPAGES_SUGGESTION_VIEW_POLICIES_BODY, false);
795 }
796
797 if (suggestions & SUGGEST_UNSUPPORTED_CIPHER) {
798 AddSuggestionDetailDictionaryToList(suggestions_details,
799 IDS_ERRORPAGES_SUGGESTION_UNSUPPORTED_CIPHER_HEADER,
800 IDS_ERRORPAGES_SUGGESTION_UNSUPPORTED_CIPHER_BODY, false);
801 }
802 }
803
804 std::string HttpErrorCodeToString(int error) {
805 return std::string("HTTP ERROR ") + base::IntToString(error);
806 }
807
542 } // namespace 808 } // namespace
543 809
544 const char LocalizedError::kHttpErrorDomain[] = "http"; 810 const char LocalizedError::kHttpErrorDomain[] = "http";
545 811
546 void LocalizedError::GetStrings(int error_code, 812 void LocalizedError::GetStrings(int error_code,
547 const std::string& error_domain, 813 const std::string& error_domain,
548 const GURL& failed_url, 814 const GURL& failed_url,
549 bool is_post, 815 bool is_post,
550 bool stale_copy_in_cache, 816 bool stale_copy_in_cache,
551 bool can_show_network_diagnostics_dialog, 817 bool can_show_network_diagnostics_dialog,
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after
644 base::string16 error_string; 910 base::string16 error_string;
645 if (error_domain == net::kErrorDomain) { 911 if (error_domain == net::kErrorDomain) {
646 // Non-internationalized error string, for debugging Chrome itself. 912 // Non-internationalized error string, for debugging Chrome itself.
647 error_string = base::ASCIIToUTF16(net::ErrorToShortString(error_code)); 913 error_string = base::ASCIIToUTF16(net::ErrorToShortString(error_code));
648 } else if (error_domain == error_page::kDnsProbeErrorDomain) { 914 } else if (error_domain == error_page::kDnsProbeErrorDomain) {
649 std::string ascii_error_string = 915 std::string ascii_error_string =
650 error_page::DnsProbeStatusToString(error_code); 916 error_page::DnsProbeStatusToString(error_code);
651 error_string = base::ASCIIToUTF16(ascii_error_string); 917 error_string = base::ASCIIToUTF16(ascii_error_string);
652 } else { 918 } else {
653 DCHECK_EQ(LocalizedError::kHttpErrorDomain, error_domain); 919 DCHECK_EQ(LocalizedError::kHttpErrorDomain, error_domain);
654 error_string = base::IntToString16(error_code); 920 error_string = base::ASCIIToUTF16(HttpErrorCodeToString(error_code));
655 } 921 }
656 error_strings->SetString("errorCode", error_string); 922 error_strings->SetString("errorCode", error_string);
657 923
658 // Platform specific information for diagnosing network issues on OSX and 924 // Platform specific information for diagnosing network issues on OSX and
659 // Windows. 925 // Windows.
660 #if (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN) 926 #if (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN)
661 if (error_domain == net::kErrorDomain && 927 if (error_domain == net::kErrorDomain &&
662 error_code == net::ERR_INTERNET_DISCONNECTED) { 928 error_code == net::ERR_INTERNET_DISCONNECTED) {
663 int platform_string_id = 929 int platform_string_id =
664 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED_PLATFORM; 930 IDS_ERRORPAGES_SUMMARY_INTERNET_DISCONNECTED_PLATFORM;
(...skipping 17 matching lines...) Expand all
682 l10n_util::GetStringUTF16(platform_string_id))); 948 l10n_util::GetStringUTF16(platform_string_id)));
683 } 949 }
684 #endif // (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN) 950 #endif // (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN)
685 951
686 // If no parameters were provided, use the defaults. 952 // If no parameters were provided, use the defaults.
687 if (!params) { 953 if (!params) {
688 params.reset(new error_page::ErrorPageParams()); 954 params.reset(new error_page::ErrorPageParams());
689 params->suggest_reload = !!(options.suggestions & SUGGEST_RELOAD); 955 params->suggest_reload = !!(options.suggestions & SUGGEST_RELOAD);
690 } 956 }
691 957
692 base::ListValue* suggestions = NULL; 958 base::ListValue* suggestions_details = nullptr;
959 base::ListValue* suggestions_summary_list = nullptr;
960
693 bool use_default_suggestions = true; 961 bool use_default_suggestions = true;
694 if (!params->override_suggestions) { 962 if (!params->override_suggestions) {
695 suggestions = new base::ListValue(); 963 suggestions_details = new base::ListValue();
964 suggestions_summary_list = new base::ListValue();
965 // Detailed suggestion information.
966 error_strings->Set("suggestionsDetails", suggestions_details);
696 } else { 967 } else {
697 suggestions = params->override_suggestions.release(); 968 suggestions_summary_list = params->override_suggestions.release();
698 use_default_suggestions = false; 969 use_default_suggestions = false;
699 AddGoogleCachedCopyButton(suggestions, error_strings); 970 AddGoogleCachedCopyButton(suggestions_summary_list, error_strings);
700 } 971 }
701 error_strings->Set("suggestions", suggestions); 972 error_strings->Set("suggestionsSummaryList", suggestions_summary_list);
702 973
703 if (params->search_url.is_valid()) { 974 if (params->search_url.is_valid()) {
704 error_strings->SetString("searchHeader", 975 base::DictionaryValue* search_suggestion = new base::DictionaryValue;
705 l10n_util::GetStringUTF16(IDS_ERRORPAGES_SUGGESTION_GOOGLE_SEARCH)); 976 search_suggestion->SetString("summary",l10n_util::GetStringUTF16(
706 error_strings->SetString("searchUrl", params->search_url.spec()); 977 IDS_ERRORPAGES_SUGGESTION_GOOGLE_SEARCH_SUMMARY));
707 error_strings->SetString("searchTerms", params->search_terms); 978 search_suggestion->SetString("searchUrl", params->search_url.spec() +
708 error_strings->SetInteger("searchTrackingId", params->search_tracking_id); 979 params->search_terms);
980 search_suggestion->SetString("searchTerms", params->search_terms);
981 search_suggestion->SetInteger("trackingId",
982 params->search_tracking_id);
983 suggestions_summary_list->Append(search_suggestion);
709 } 984 }
710 985
711 // Add the reload suggestion, if needed. 986 // Add the reload suggestion, if needed for pages that didn't come
712 if (params->suggest_reload) { 987 // from a post.
713 if (!is_post) { 988 if (params->suggest_reload && !is_post) {
714 base::DictionaryValue* reload_button = new base::DictionaryValue; 989 base::DictionaryValue* reload_button = new base::DictionaryValue;
715 reload_button->SetString( 990 reload_button->SetString(
716 "msg", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_RELOAD)); 991 "msg", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_RELOAD));
717 reload_button->SetString("reloadUrl", failed_url.spec()); 992 reload_button->SetString("reloadUrl", failed_url.spec());
718 error_strings->Set("reloadButton", reload_button); 993 error_strings->Set("reloadButton", reload_button);
719 reload_button->SetInteger("reloadTrackingId", params->reload_tracking_id); 994 reload_button->SetInteger("reloadTrackingId", params->reload_tracking_id);
720 } else {
721 // If the page was created by a post, it can't be reloaded in the same
722 // way, so just add a suggestion instead.
723 // TODO(mmenke): Make the reload button bring up the repost confirmation
724 // dialog for pages resulting from posts.
725 base::DictionaryValue* suggest_reload_repost = new base::DictionaryValue;
726 suggest_reload_repost->SetString("header",
727 l10n_util::GetStringUTF16(
728 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_HEADER));
729 suggest_reload_repost->SetString("body",
730 l10n_util::GetStringUTF16(
731 IDS_ERRORPAGES_SUGGESTION_RELOAD_REPOST_BODY));
732 // Add at the front, so it appears before other suggestions, in the case
733 // suggestions are being overridden by |params|.
734 suggestions->Insert(0, suggest_reload_repost);
735 }
736 } 995 }
737 996
738 // If not using the default suggestions, nothing else to do. 997 // If not using the default suggestions, nothing else to do.
739 if (!use_default_suggestions) 998 if (!use_default_suggestions)
740 return; 999 return;
741 1000
1001 // Add default suggestions and any relevant supporting details.
1002 GetSuggestionsSummaryList(error_code, error_strings, options.suggestions,
1003 locale, suggestions_summary_list);
1004 AddSuggestionsDetails(error_code, error_strings, options.suggestions,
1005 suggestions_details);
1006
1007 // Add action buttons.
742 const std::string& show_saved_copy_value = 1008 const std::string& show_saved_copy_value =
743 command_line->GetSwitchValueASCII(error_page::switches::kShowSavedCopy); 1009 command_line->GetSwitchValueASCII(error_page::switches::kShowSavedCopy);
744 bool show_saved_copy_primary = 1010 bool show_saved_copy_primary =
745 (show_saved_copy_value == 1011 (show_saved_copy_value ==
746 error_page::switches::kEnableShowSavedCopyPrimary); 1012 error_page::switches::kEnableShowSavedCopyPrimary);
747 bool show_saved_copy_secondary = 1013 bool show_saved_copy_secondary =
748 (show_saved_copy_value == 1014 (show_saved_copy_value ==
749 error_page::switches::kEnableShowSavedCopySecondary); 1015 error_page::switches::kEnableShowSavedCopySecondary);
750 bool show_saved_copy_visible = 1016 bool show_saved_copy_visible =
751 (stale_copy_in_cache && !is_post && 1017 (stale_copy_in_cache && !is_post &&
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
793 #if defined(OS_CHROMEOS) 1059 #if defined(OS_CHROMEOS)
794 // ChromeOS has its own diagnostics extension, which doesn't rely on a 1060 // ChromeOS has its own diagnostics extension, which doesn't rely on a
795 // browser-initiated dialog. 1061 // browser-initiated dialog.
796 can_show_network_diagnostics_dialog = true; 1062 can_show_network_diagnostics_dialog = true;
797 #endif 1063 #endif
798 if (can_show_network_diagnostics_dialog && failed_url.is_valid() && 1064 if (can_show_network_diagnostics_dialog && failed_url.is_valid() &&
799 failed_url.SchemeIsHTTPOrHTTPS()) { 1065 failed_url.SchemeIsHTTPOrHTTPS()) {
800 error_strings->SetString( 1066 error_strings->SetString(
801 "diagnose", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_DIAGNOSE)); 1067 "diagnose", l10n_util::GetStringUTF16(IDS_ERRORPAGES_BUTTON_DIAGNOSE));
802 } 1068 }
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 } 1069 }
941 1070
942 base::string16 LocalizedError::GetErrorDetails(const std::string& error_domain, 1071 base::string16 LocalizedError::GetErrorDetails(const std::string& error_domain,
943 int error_code, 1072 int error_code,
944 bool is_post) { 1073 bool is_post) {
945 const LocalizedErrorMap* error_map = 1074 const LocalizedErrorMap* error_map =
946 LookupErrorMap(error_domain, error_code, is_post); 1075 LookupErrorMap(error_domain, error_code, is_post);
947 if (error_map) 1076 if (error_map)
948 return l10n_util::GetStringUTF16(error_map->details_resource_id); 1077 return l10n_util::GetStringUTF16(error_map->details_resource_id);
949 else 1078 else
950 return l10n_util::GetStringUTF16(IDS_ERRORPAGES_DETAILS_UNKNOWN); 1079 return l10n_util::GetStringUTF16(IDS_ERRORPAGES_DETAILS_UNKNOWN);
951 } 1080 }
952 1081
953 bool LocalizedError::HasStrings(const std::string& error_domain, 1082 bool LocalizedError::HasStrings(const std::string& error_domain,
954 int error_code) { 1083 int error_code) {
955 // Whether or not the there are strings for an error does not depend on 1084 // 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 1085 // whether or not the page was be generated by a POST, so just claim it was
957 // not. 1086 // not.
958 return LookupErrorMap(error_domain, error_code, /*is_post=*/false) != NULL; 1087 return LookupErrorMap(error_domain, error_code, /*is_post=*/false) != nullptr;
959 } 1088 }
960 1089
961 } // namespace error_page 1090 } // namespace error_page
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698