| Index: chrome/browser/password_manager/password_manager.cc
|
| diff --git a/chrome/browser/password_manager/password_manager.cc b/chrome/browser/password_manager/password_manager.cc
|
| index b3a2a5351d3fd7ac03dff132c4bff60b2747de69..fdd0138b3141358c1da03cefc3fa80a8b1954b6d 100644
|
| --- a/chrome/browser/password_manager/password_manager.cc
|
| +++ b/chrome/browser/password_manager/password_manager.cc
|
| @@ -6,6 +6,7 @@
|
|
|
| #include "base/metrics/histogram.h"
|
| #include "base/threading/platform_thread.h"
|
| +#include "base/string_util.h"
|
| #include "base/utf_string_conversions.h"
|
| #include "chrome/browser/password_manager/password_form_manager.h"
|
| #include "chrome/browser/password_manager/password_manager_delegate.h"
|
| @@ -25,6 +26,8 @@ using webkit::forms::PasswordFormMap;
|
|
|
| namespace {
|
|
|
| +const char kSpdyProxyRealm[] = "/SpdyProxy";
|
| +
|
| // This routine is called when PasswordManagers are constructed.
|
| //
|
| // Currently we report metrics only once at startup. We require
|
| @@ -212,6 +215,11 @@ void PasswordManager::OnPasswordFormsParsed(
|
|
|
| for (std::vector<PasswordForm>::const_iterator iter = forms.begin();
|
| iter != forms.end(); ++iter) {
|
| + // Don't involve the password manager if this form corresponds to
|
| + // SpdyProxy authentication, as indicated by the realm.
|
| + if (EndsWith(iter->signon_realm, kSpdyProxyRealm, true))
|
| + continue;
|
| +
|
| bool ssl_valid = iter->origin.SchemeIsSecure() && !had_ssl_error;
|
| PasswordFormManager* manager =
|
| new PasswordFormManager(delegate_->GetProfile(),
|
|
|