blob: bbcba879b07aa75c322123ac6462b8c2e25668d5 (
plain)
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
81
82
83
84
85
86
87
88
89
90
91
92
93
|
// Copyright 2018 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 COMPONENTS_AUTOFILL_ASSISTANT_BROWSER_CLIENT_H_
#define COMPONENTS_AUTOFILL_ASSISTANT_BROWSER_CLIENT_H_
#include <string>
#include "components/autofill_assistant/browser/device_context.h"
#include "components/autofill_assistant/browser/metrics.h"
#include "content/public/browser/web_contents.h"
namespace autofill {
class PersonalDataManager;
} // namespace autofill
namespace password_manager {
class PasswordManagerClient;
} // namespace password_manager
namespace version_info {
enum class Channel;
} // namespace version_info
namespace autofill_assistant {
class AccessTokenFetcher;
class WebsiteLoginManager;
// A client interface that needs to be supplied to the controller by the
// embedder.
class Client {
public:
virtual ~Client() = default;
// Attaches the controller to the UI.
//
// This method does whatever is necessary to guarantee that, at the end of the
// call, there is a Controller associated with a UI.
virtual void AttachUI() = 0;
// Destroys the UI immediately.
virtual void DestroyUI() = 0;
// Returns the channel for the installation (canary, dev, beta, stable).
// Returns unknown otherwise.
virtual version_info::Channel GetChannel() const = 0;
// Returns the e-mail address that corresponds to the auth credentials. Might
// be empty.
virtual std::string GetEmailAddressForAccessTokenAccount() const = 0;
// Returns the e-mail address used to sign into Chrome, or an empty string if
// the user is not signed in.
virtual std::string GetChromeSignedInEmailAddress() const = 0;
// Returns the AccessTokenFetcher to use to get oauth credentials.
virtual AccessTokenFetcher* GetAccessTokenFetcher() = 0;
// Returns the current active personal data manager.
virtual autofill::PersonalDataManager* GetPersonalDataManager() const = 0;
// Return the password manager client for the current WebContents.
virtual password_manager::PasswordManagerClient* GetPasswordManagerClient()
const = 0;
// Returns the currently active login fetcher.
virtual WebsiteLoginManager* GetWebsiteLoginManager() const = 0;
// Returns the locale.
virtual std::string GetLocale() const = 0;
// Returns the country code.
virtual std::string GetCountryCode() const = 0;
// Returns details about the device.
virtual DeviceContext GetDeviceContext() const = 0;
// Returns whether a11y (talkback and touch exploration) is enabled or not.
virtual bool IsAccessibilityEnabled() const = 0;
// Returns current WebContents.
virtual content::WebContents* GetWebContents() const = 0;
// Stops autofill assistant for the current WebContents, both controller
// and UI.
virtual void Shutdown(Metrics::DropOutReason reason) = 0;
protected:
Client() = default;
};
} // namespace autofill_assistant
#endif // COMPONENTS_AUTOFILL_ASSISTANT_BROWSER_CLIENT_H_
|