Chromium Code Reviews| 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 |