| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/safe_browsing/password_protection/password_protection_servi
ce.h" | 5 #include "components/safe_browsing/password_protection/password_protection_servi
ce.h" |
| 6 | 6 |
| 7 #include "base/base64.h" | 7 #include "base/base64.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 51 | 51 |
| 52 // Returns the number of path segments in |cache_expression_path|. | 52 // Returns the number of path segments in |cache_expression_path|. |
| 53 // For example, return 0 for "/", since there is no path after the leading | 53 // For example, return 0 for "/", since there is no path after the leading |
| 54 // slash; return 3 for "/abc/def/gh.html". | 54 // slash; return 3 for "/abc/def/gh.html". |
| 55 size_t GetPathDepth(const std::string& cache_expression_path) { | 55 size_t GetPathDepth(const std::string& cache_expression_path) { |
| 56 return base::SplitString(base::StringPiece(cache_expression_path), "/", | 56 return base::SplitString(base::StringPiece(cache_expression_path), "/", |
| 57 base::KEEP_WHITESPACE, base::SPLIT_WANT_NONEMPTY) | 57 base::KEEP_WHITESPACE, base::SPLIT_WANT_NONEMPTY) |
| 58 .size(); | 58 .size(); |
| 59 } | 59 } |
| 60 | 60 |
| 61 // Given a URL of either http or https scheme, return its scheme://hostname. | 61 // Given a URL of either http or https scheme, return its http://hostname. |
| 62 // e.g., "https://www.foo.com:80/bar/test.cgi" -> "http://www.foo.com". | 62 // e.g., "https://www.foo.com:80/bar/test.cgi" -> "http://www.foo.com". |
| 63 GURL GetHostNameWithHTTPScheme(const GURL& url) { | 63 GURL GetHostNameWithHTTPScheme(const GURL& url) { |
| 64 DCHECK(url.SchemeIsHTTPOrHTTPS()); | 64 DCHECK(url.SchemeIsHTTPOrHTTPS()); |
| 65 std::string result(url::kHttpScheme); | 65 std::string result(url::kHttpScheme); |
| 66 result.append(url::kStandardSchemeSeparator).append(url.HostNoBrackets()); | 66 result.append(url::kStandardSchemeSeparator).append(url.host()); |
| 67 return GURL(result); | 67 return GURL(result); |
| 68 } | 68 } |
| 69 | 69 |
| 70 } // namespace | 70 } // namespace |
| 71 | 71 |
| 72 const base::Feature kPasswordFieldOnFocusPinging{ | 72 const base::Feature kPasswordFieldOnFocusPinging{ |
| 73 "PasswordFieldOnFocusPinging", base::FEATURE_DISABLED_BY_DEFAULT}; | 73 "PasswordFieldOnFocusPinging", base::FEATURE_DISABLED_BY_DEFAULT}; |
| 74 | 74 |
| 75 const base::Feature kProtectedPasswordEntryPinging{ | 75 const base::Feature kProtectedPasswordEntryPinging{ |
| 76 "ProtectedPasswordEntryPinging", base::FEATURE_DISABLED_BY_DEFAULT}; | 76 "ProtectedPasswordEntryPinging", base::FEATURE_DISABLED_BY_DEFAULT}; |
| (...skipping 26 matching lines...) Expand all Loading... |
| 103 tracker_.TryCancelAll(); | 103 tracker_.TryCancelAll(); |
| 104 CancelPendingRequests(); | 104 CancelPendingRequests(); |
| 105 history_service_observer_.RemoveAll(); | 105 history_service_observer_.RemoveAll(); |
| 106 weak_factory_.InvalidateWeakPtrs(); | 106 weak_factory_.InvalidateWeakPtrs(); |
| 107 } | 107 } |
| 108 | 108 |
| 109 bool PasswordProtectionService::CanGetReputationOfURL(const GURL& url) { | 109 bool PasswordProtectionService::CanGetReputationOfURL(const GURL& url) { |
| 110 if (!url.is_valid() || !url.SchemeIsHTTPOrHTTPS()) | 110 if (!url.is_valid() || !url.SchemeIsHTTPOrHTTPS()) |
| 111 return false; | 111 return false; |
| 112 | 112 |
| 113 const std::string& hostname = url.HostNoBrackets(); | 113 const std::string hostname = url.HostNoBrackets(); |
| 114 return !net::IsLocalhost(hostname) && !net::IsHostnameNonUnique(hostname) && | 114 return !net::IsLocalhost(hostname) && !net::IsHostnameNonUnique(hostname) && |
| 115 hostname.find('.') != std::string::npos; | 115 hostname.find('.') != std::string::npos; |
| 116 } | 116 } |
| 117 | 117 |
| 118 LoginReputationClientResponse::VerdictType | 118 LoginReputationClientResponse::VerdictType |
| 119 PasswordProtectionService::GetCachedVerdict( | 119 PasswordProtectionService::GetCachedVerdict( |
| 120 const GURL& url, | 120 const GURL& url, |
| 121 LoginReputationClientResponse* out_response) { | 121 LoginReputationClientResponse* out_response) { |
| 122 if (!url.is_valid()) | 122 if (!url.is_valid()) |
| 123 return LoginReputationClientResponse::VERDICT_TYPE_UNSPECIFIED; | 123 return LoginReputationClientResponse::VERDICT_TYPE_UNSPECIFIED; |
| (...skipping 454 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 578 if (is_password_entry_ping) { | 578 if (is_password_entry_ping) { |
| 579 UMA_HISTOGRAM_ENUMERATION(kPasswordEntryRequestOutcomeHistogramName, reason, | 579 UMA_HISTOGRAM_ENUMERATION(kPasswordEntryRequestOutcomeHistogramName, reason, |
| 580 MAX_OUTCOME); | 580 MAX_OUTCOME); |
| 581 } else { | 581 } else { |
| 582 UMA_HISTOGRAM_ENUMERATION(kPasswordOnFocusRequestOutcomeHistogramName, | 582 UMA_HISTOGRAM_ENUMERATION(kPasswordOnFocusRequestOutcomeHistogramName, |
| 583 reason, MAX_OUTCOME); | 583 reason, MAX_OUTCOME); |
| 584 } | 584 } |
| 585 } | 585 } |
| 586 | 586 |
| 587 } // namespace safe_browsing | 587 } // namespace safe_browsing |
| OLD | NEW |