Chromium Code Reviews| Index: chrome/browser/password_manager/update_password_infobar_delegate.cc |
| diff --git a/chrome/browser/password_manager/update_password_infobar_delegate.cc b/chrome/browser/password_manager/update_password_infobar_delegate.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8460829afaeda08b44ba0e24e2e1b43b340d2fb3 |
| --- /dev/null |
| +++ b/chrome/browser/password_manager/update_password_infobar_delegate.cc |
| @@ -0,0 +1,107 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/password_manager/update_password_infobar_delegate.h" |
| + |
| +#include "chrome/browser/infobars/infobar_service.h" |
| +#include "chrome/browser/password_manager/chrome_password_manager_client.h" |
| +#include "chrome/browser/profiles/profile.h" |
| +#include "chrome/browser/sync/profile_sync_service_factory.h" |
| +#include "chrome/browser/ui/android/infobars/auto_signin_first_run_infobar.h" |
| +#include "chrome/browser/ui/android/infobars/update_password_infobar.h" |
| +#include "chrome/browser/ui/passwords/manage_passwords_view_utils.h" |
| +#include "chrome/grit/chromium_strings.h" |
| +#include "chrome/grit/generated_resources.h" |
| +#include "components/browser_sync/browser/profile_sync_service.h" |
| +#include "components/infobars/core/infobar.h" |
| +#include "components/password_manager/core/browser/password_bubble_experiment.h" |
| +#include "content/public/browser/web_contents.h" |
| +#include "ui/base/l10n/l10n_util.h" |
| + |
| +// static |
| +void UpdatePasswordInfoBarDelegate::Create( |
| + content::WebContents* web_contents, |
| + scoped_ptr<password_manager::PasswordFormManager> form_to_save) { |
| + Profile* profile = |
| + Profile::FromBrowserContext(web_contents->GetBrowserContext()); |
| + sync_driver::SyncService* sync_service = |
| + ProfileSyncServiceFactory::GetForProfile(profile); |
| + bool is_smartlock_branding_enabled = |
| + password_bubble_experiment::IsSmartLockBrandingEnabled(sync_service); |
| + UpdatePasswordInfoBarDelegate* update_password_infobar_delegate = |
|
vabr (Chromium)
2016/01/13 09:44:45
Please make this a scoped_ptr instead of waiting u
melandory
2016/01/13 15:11:36
With scoped ptr it's too long in my taste. I'd bet
vabr (Chromium)
2016/01/13 16:04:34
Your inlining looks good to me. Just as an alterna
|
| + new UpdatePasswordInfoBarDelegate(web_contents, std::move(form_to_save), |
| + is_smartlock_branding_enabled); |
| + InfoBarService::FromWebContents(web_contents) |
| + ->AddInfoBar(make_scoped_ptr(new UpdatePasswordInfoBar( |
| + make_scoped_ptr(update_password_infobar_delegate)))); |
| +} |
| + |
| +UpdatePasswordInfoBarDelegate::UpdatePasswordInfoBarDelegate( |
| + content::WebContents* web_contents, |
| + scoped_ptr<password_manager::PasswordFormManager> form_to_update, |
| + bool is_smartlock_branding_enabled) |
| + : PasswordManagerInfoBarDelegate(), |
| + is_smartlock_branding_enabled_(is_smartlock_branding_enabled) { |
| + // TODO(melandory): Add histograms. |
|
vabr (Chromium)
2016/01/13 09:44:45
optional: It is better to create a bug for the TOD
melandory
2016/01/13 15:11:36
Done.
|
| + passwords_data_.set_client( |
| + ChromePasswordManagerClient::FromWebContents(web_contents)); |
| + passwords_data_.OnUpdatePassword(std::move(form_to_update)); |
| + if (is_smartlock_branding_enabled) { |
| + base::string16 branding_ = l10n_util::GetStringUTF16( |
| + IDS_PASSWORD_MANAGER_SMART_LOCK_FOR_PASSWORDS); |
| + } else { |
| + branding_ = l10n_util::GetStringUTF16(IDS_PASSWORD_MANAGER_TITLE_BRAND); |
| + } |
| +} |
| + |
| +UpdatePasswordInfoBarDelegate::~UpdatePasswordInfoBarDelegate() {} |
| + |
| +bool UpdatePasswordInfoBarDelegate::ShowMultipleAccounts() const { |
| + const password_manager::PasswordFormManager* form_manager = |
| + passwords_data_.form_manager(); |
| + bool is_password_overriden = |
| + form_manager ? form_manager->password_overridden() : false; |
| + return GetCurrentForms().size() > 1 && !is_password_overriden; |
| +} |
| + |
| +base::string16 UpdatePasswordInfoBarDelegate::GetUsernameForOneAccountCase() { |
| + password_manager::PasswordFormManager* form_manager = |
| + passwords_data_.form_manager(); |
| + return form_manager->pending_credentials().username_value; |
| +} |
| + |
| +void UpdatePasswordInfoBarDelegate::UpdatePasswordInternal( |
| + unsigned int form_index) { |
| + if (ShowMultipleAccounts()) { |
| + CHECK_GE(GetCurrentForms().size(), form_index); // +-1 error; |
|
vabr (Chromium)
2016/01/13 09:44:45
Should this be CHECK_GT? I don't think form_index
melandory
2016/01/13 15:11:36
My comment is actually saying that I should change
|
| + password_manager::PasswordFormManager* form_manager = |
| + passwords_data_.form_manager(); |
| + |
| + form_manager->Update(*GetCurrentForms()[form_index]); |
| + } |
| +} |
| + |
| +infobars::InfoBarDelegate::InfoBarIdentifier |
| +UpdatePasswordInfoBarDelegate::GetIdentifier() const { |
| + return UPDATE_PASSWORD_INFOBAR_DELEGATE; |
| +} |
| + |
| +base::string16 UpdatePasswordInfoBarDelegate::GetButtonLabel( |
| + InfoBarButton button) const { |
| + return l10n_util::GetStringUTF16((button == BUTTON_OK) |
| + ? IDS_PASSWORD_MANAGER_UPDATE_BUTTON |
| + : IDS_PASSWORD_MANAGER_CANCEL_BUTTON); |
| +} |
| + |
| +bool UpdatePasswordInfoBarDelegate::Accept() { |
| + password_manager::PasswordFormManager* form_manager = |
| + passwords_data_.form_manager(); |
| + if (!ShowMultipleAccounts()) |
|
vabr (Chromium)
2016/01/13 09:44:45
nit: Add a comment explaining what happens if Show
melandory
2016/01/13 15:11:36
I also change a code a bit, so it reflects the upd
|
| + form_manager->Update(form_manager->pending_credentials()); |
| + return true; |
| +} |
| + |
| +bool UpdatePasswordInfoBarDelegate::Cancel() { |
| + return true; |
| +} |