| OLD | NEW |
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 "base/field_trial.h" | 5 #include "base/field_trial.h" |
| 6 #include "base/histogram.h" | 6 #include "base/histogram.h" |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/sha2.h" | 8 #include "base/sha2.h" |
| 9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
| 10 #include "net/base/base64.h" | 10 #include "net/base/base64.h" |
| (...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 165 // TODO(jar): Remove this failsafe conservative hack which is more restrictive | 165 // TODO(jar): Remove this failsafe conservative hack which is more restrictive |
| 166 // than current SDCH spec when needed, and justified by security audit. | 166 // than current SDCH spec when needed, and justified by security audit. |
| 167 if (!referring_url.SchemeIs("http")) { | 167 if (!referring_url.SchemeIs("http")) { |
| 168 SdchErrorRecovery(DICTIONARY_SELECTED_FROM_NON_HTTP); | 168 SdchErrorRecovery(DICTIONARY_SELECTED_FROM_NON_HTTP); |
| 169 return false; | 169 return false; |
| 170 } | 170 } |
| 171 | 171 |
| 172 return true; | 172 return true; |
| 173 } | 173 } |
| 174 | 174 |
| 175 void SdchManager::FetchDictionary(const GURL& referring_url, | 175 void SdchManager::FetchDictionary(const GURL& dictionary_url) { |
| 176 const GURL& dictionary_url) { | |
| 177 if (!CanFetchDictionary(referring_url, dictionary_url)) | |
| 178 return; | |
| 179 if (fetcher_.get()) | 176 if (fetcher_.get()) |
| 180 fetcher_->Schedule(dictionary_url); | 177 fetcher_->Schedule(dictionary_url); |
| 181 } | 178 } |
| 182 | 179 |
| 183 bool SdchManager::AddSdchDictionary(const std::string& dictionary_text, | 180 bool SdchManager::AddSdchDictionary(const std::string& dictionary_text, |
| 184 const GURL& dictionary_url) { | 181 const GURL& dictionary_url) { |
| 185 std::string client_hash; | 182 std::string client_hash; |
| 186 std::string server_hash; | 183 std::string server_hash; |
| 187 GenerateHash(dictionary_text, &client_hash, &server_hash); | 184 GenerateHash(dictionary_text, &client_hash, &server_hash); |
| 188 if (dictionaries_.find(server_hash) != dictionaries_.end()) { | 185 if (dictionaries_.find(server_hash) != dictionaries_.end()) { |
| (...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 372 1. The dictionary has no Domain attribute. | 369 1. The dictionary has no Domain attribute. |
| 373 2. The effective host name that derives from the referer URL host name does | 370 2. The effective host name that derives from the referer URL host name does |
| 374 not domain-match the Domain attribute. | 371 not domain-match the Domain attribute. |
| 375 3. The Domain attribute is a top level domain. | 372 3. The Domain attribute is a top level domain. |
| 376 4. The referer URL host is a host domain name (not IP address) and has the | 373 4. The referer URL host is a host domain name (not IP address) and has the |
| 377 form HD, where D is the value of the Domain attribute, and H is a string | 374 form HD, where D is the value of the Domain attribute, and H is a string |
| 378 that contains one or more dots. | 375 that contains one or more dots. |
| 379 5. If the dictionary has a Port attribute and the referer URL's port was not | 376 5. If the dictionary has a Port attribute and the referer URL's port was not |
| 380 in the list. | 377 in the list. |
| 381 */ | 378 */ |
| 379 |
| 380 // TODO(jar): Redirects in dictionary fetches might plausibly be problematic, |
| 381 // and hence the conservative approach is to not allow any redirects (if there |
| 382 // were any... then don't allow the dictionary to be set). |
| 383 |
| 382 if (domain.empty()) { | 384 if (domain.empty()) { |
| 383 SdchErrorRecovery(DICTIONARY_MISSING_DOMAIN_SPECIFIER); | 385 SdchErrorRecovery(DICTIONARY_MISSING_DOMAIN_SPECIFIER); |
| 384 return false; // Domain is required. | 386 return false; // Domain is required. |
| 385 } | 387 } |
| 386 if (net::RegistryControlledDomainService::GetDomainAndRegistry(domain).size() | 388 if (net::RegistryControlledDomainService::GetDomainAndRegistry(domain).size() |
| 387 == 0) { | 389 == 0) { |
| 388 SdchErrorRecovery(DICTIONARY_SPECIFIES_TOP_LEVEL_DOMAIN); | 390 SdchErrorRecovery(DICTIONARY_SPECIFIES_TOP_LEVEL_DOMAIN); |
| 389 return false; // domain was a TLD. | 391 return false; // domain was a TLD. |
| 390 } | 392 } |
| 391 if (!Dictionary::DomainMatch(dictionary_url, domain)) { | 393 if (!Dictionary::DomainMatch(dictionary_url, domain)) { |
| (...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 496 return false; | 498 return false; |
| 497 return restriction[prefix_length - 1] == '/' || path[prefix_length] == '/'; | 499 return restriction[prefix_length - 1] == '/' || path[prefix_length] == '/'; |
| 498 } | 500 } |
| 499 | 501 |
| 500 // static | 502 // static |
| 501 bool SdchManager::Dictionary::DomainMatch(const GURL& gurl, | 503 bool SdchManager::Dictionary::DomainMatch(const GURL& gurl, |
| 502 const std::string& restriction) { | 504 const std::string& restriction) { |
| 503 // TODO(jar): This is not precisely a domain match definition. | 505 // TODO(jar): This is not precisely a domain match definition. |
| 504 return gurl.DomainIs(restriction.data(), restriction.size()); | 506 return gurl.DomainIs(restriction.data(), restriction.size()); |
| 505 } | 507 } |
| OLD | NEW |