blob: 990758cb7ba0c96918fdc3966d32c4ff52b349e7 [file] [log] [blame]
// 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.
#ifndef CHROME_BROWSER_UI_PASSWORDS_MANAGE_PASSWORDS_STATE_H_
#define CHROME_BROWSER_UI_PASSWORDS_MANAGE_PASSWORDS_STATE_H_
#include "base/callback.h"
#include "base/macros.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/scoped_vector.h"
#include "components/autofill/core/common/password_form.h"
#include "components/password_manager/core/browser/password_store_change.h"
#include "components/password_manager/core/common/password_manager_ui.h"
#include "url/gurl.h"
namespace password_manager {
struct CredentialInfo;
class PasswordFormManager;
class PasswordManagerClient;
}
// ManagePasswordsState keeps the current state for ManagePasswordsUIController
// as well as up-to-date data for this state.
class ManagePasswordsState {
public:
using CredentialsCallback =
base::Callback<void(const password_manager::CredentialInfo&)>;
ManagePasswordsState();
~ManagePasswordsState();
// The embedder of this class has to set the client for logging.
void set_client(password_manager::PasswordManagerClient* client) {
client_ = client;
}
// The methods below discard the current state/data of the object and move it
// to the specified state.
// Move to PENDING_PASSWORD_STATE.
void OnPendingPassword(
scoped_ptr<password_manager::PasswordFormManager> form_manager);
// Move to PENDING_PASSWORD_UPDATE_STATE.
void OnUpdatePassword(
scoped_ptr<password_manager::PasswordFormManager> form_manager);
// Move to CREDENTIAL_REQUEST_STATE.
void OnRequestCredentials(
ScopedVector<autofill::PasswordForm> local_credentials,
ScopedVector<autofill::PasswordForm> federated_credentials,
const GURL& origin);
// Move to AUTO_SIGNIN_STATE. |local_forms| can't be empty.
void OnAutoSignin(ScopedVector<autofill::PasswordForm> local_forms);
// Move to CONFIRMATION_STATE.
void OnAutomaticPasswordSave(
scoped_ptr<password_manager::PasswordFormManager> form_manager);
// Move to MANAGE_STATE or INACTIVE_STATE for PSL matched passwords.
// |password_form_map| contains best matches from the password store for the
// form which was autofilled, |origin| is an origin of the form which was
// autofilled.
void OnPasswordAutofilled(const autofill::PasswordFormMap& password_form_map,
const GURL& origin);
// Move to INACTIVE_STATE.
void OnInactive();
// Moves the object to |state| without resetting the internal data. Allowed:
// * -> MANAGE_STATE
void TransitionToState(password_manager::ui::State state);
// Updates the internal state applying |changes|.
void ProcessLoginsChanged(
const password_manager::PasswordStoreChangeList& changes);
password_manager::ui::State state() const { return state_; }
const GURL& origin() const { return origin_; }
password_manager::PasswordFormManager* form_manager() const {
return form_manager_.get();
}
const CredentialsCallback& credentials_callback() {
return credentials_callback_;
}
void set_credentials_callback(const CredentialsCallback& callback) {
credentials_callback_ = callback;
}
// Current local forms. ManagePasswordsState is responsible for the forms.
const std::vector<const autofill::PasswordForm*>& GetCurrentForms() const {
return form_manager_ ? current_forms_weak_ : local_credentials_forms_.get();
}
// Current federated forms.
const std::vector<const autofill::PasswordForm*>&
federated_credentials_forms() const {
return federated_credentials_forms_.get();
}
private:
// Removes all the PasswordForms stored in this object.
void ClearData();
// Add |form| to the internal state.
void AddForm(const autofill::PasswordForm& form);
// Updates |form| in the internal state.
bool UpdateForm(const autofill::PasswordForm& form);
// Removes |form| from the internal state.
void DeleteForm(const autofill::PasswordForm& form);
void SetState(password_manager::ui::State state);
// The origin of the current page. It's used to determine which PasswordStore
// changes are applicable to the internal state.
GURL origin_;
// Contains the password that was submitted.
scoped_ptr<password_manager::PasswordFormManager> form_manager_;
// Weak references to the passwords for the current status. The hard pointers
// are scattered between |form_manager_| and |local_credentials_forms_|. If
// |form_manager_| is nullptr then all the forms are stored in
// |local_credentials_forms_|. |current_forms_weak_| remains empty.
std::vector<const autofill::PasswordForm*> current_forms_weak_;
// If |form_manager_| is nullptr then |local_credentials_forms_| contains all
// the current forms. Otherwise, it's a container for the new forms coming
// from the PasswordStore.
ScopedVector<const autofill::PasswordForm> local_credentials_forms_;
// Federated credentials for the CREDENTIAL_REQUEST_STATE.
ScopedVector<const autofill::PasswordForm> federated_credentials_forms_;
// A callback to be invoked when user selects a credential.
CredentialsCallback credentials_callback_;
// The current state of the password manager UI.
password_manager::ui::State state_;
// The client used for logging.
password_manager::PasswordManagerClient* client_;
DISALLOW_COPY_AND_ASSIGN(ManagePasswordsState);
};
#endif // CHROME_BROWSER_UI_PASSWORDS_MANAGE_PASSWORDS_STATE_H_