1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_PASSWORD_MANAGER_ANDROID_CRED_MAN_CONTROLLER_H_
#define CHROME_BROWSER_PASSWORD_MANAGER_ANDROID_CRED_MAN_CONTROLLER_H_
#include <string>
#include "base/functional/callback.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "components/password_manager/core/browser/password_manager_client.h"
namespace webauthn {
class WebAuthnCredManDelegate;
} // namespace webauthn
namespace password_manager {
class PasswordCredentialFiller;
class KeyboardReplacingSurfaceVisibilityController;
class ContentPasswordManagerDriver;
// This class is responsible for the logic to show Credential Manager UI. The
// interaction with Credential Manager UI is delegated to WebAuthnCredMan class.
// Its lifecycle is tied to ChromePasswordManagerClient. CredManController is
// used in Android U+ only.
class CredManController {
public:
using PasskeyDelayCallback =
base::OnceCallback<void(base::OnceCallback<void(base::OnceClosure)>)>;
CredManController(base::WeakPtr<KeyboardReplacingSurfaceVisibilityController>
visibility_controller,
password_manager::PasswordManagerClient* password_client);
CredManController(const CredManController&) = delete;
CredManController& operator=(const CredManController&) = delete;
~CredManController();
// Determines if the Android Credential Manager UI should be shown and shows
// if required. Returns true if the Android Credential Manager UI is shown,
// false otherwise.
// If `delay_callback` is not null and passkeys are not yet enumerated,
// invokes `delay_callback` and returns true. `delay_callback` takes as an
// argument a callback that registers for notifications when passkeys become
// available. If `delay_callback` is not null and passkeys enumeration has
// completed, the callback will be destroyed without invocation.
bool Show(raw_ptr<webauthn::WebAuthnCredManDelegate> cred_man_delegate,
std::unique_ptr<PasswordCredentialFiller> filler,
base::WeakPtr<password_manager::ContentPasswordManagerDriver>
frame_driver,
bool is_webauthn_form,
PasskeyDelayCallback delay_callback);
private:
void Dismiss(bool success);
void TriggerFilling(const std::u16string& username,
const std::u16string& password);
void FillUsernameAndPassword(const std::u16string& username,
const std::u16string& password);
void OnReauthCompleted(const std::u16string& username,
const std::u16string& password,
bool auth_successful);
base::WeakPtr<KeyboardReplacingSurfaceVisibilityController>
visibility_controller_;
// The password manager client is used to check whether re-auth is required.
const raw_ptr<password_manager::PasswordManagerClient> password_client_;
// The authenticator used to trigger a biometric re-auth before filling.
std::unique_ptr<device_reauth::DeviceAuthenticator> authenticator_;
std::unique_ptr<PasswordCredentialFiller> filler_;
base::WeakPtrFactory<CredManController> weak_ptr_factory_{this};
};
} // namespace password_manager
#endif // CHROME_BROWSER_PASSWORD_MANAGER_ANDROID_CRED_MAN_CONTROLLER_H_
|