OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ | 5 #ifndef CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ |
6 #define CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ | 6 #define CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "chrome/browser/chromeos/arc/arc_auth_service.h" | 9 #include "chrome/browser/chromeos/arc/arc_auth_service.h" |
| 10 #include "chrome/browser/chromeos/arc/extensions/arc_support_message_host.h" |
10 #include "components/prefs/pref_change_registrar.h" | 11 #include "components/prefs/pref_change_registrar.h" |
11 #include "extensions/browser/api/messaging/native_message_host.h" | 12 #include "extensions/browser/api/messaging/native_message_host.h" |
12 #include "ui/display/display_observer.h" | 13 #include "ui/display/display_observer.h" |
13 | 14 |
14 // Supports communication with Arc support dialog. | 15 // Native interface to control ARC support chrome App. |
15 class ArcSupportHost : public extensions::NativeMessageHost, | 16 // TODO(hidehiko): Move more implementation for the UI control from |
16 public arc::ArcAuthService::Observer, | 17 // ArcAuthService to this class. |
| 18 // TODO(hidehiko,lhchavez,khmel): Extract preference observing into a |
| 19 // standalone class so that it can be shared with OOBE flow. |
| 20 // TODO(hidehiko,lhchavez): Move this into extensions/ directory, and put it |
| 21 // into "arc" namespace. Add unittests at the time. |
| 22 class ArcSupportHost : public arc::ArcSupportMessageHost::Observer, |
17 public display::DisplayObserver { | 23 public display::DisplayObserver { |
18 public: | 24 public: |
19 static const char kHostName[]; | |
20 static const char kHostAppId[]; | 25 static const char kHostAppId[]; |
21 static const char kStorageId[]; | 26 static const char kStorageId[]; |
22 static const char* const kHostOrigin[]; | |
23 | 27 |
24 static std::unique_ptr<NativeMessageHost> Create(); | 28 ArcSupportHost(); |
| 29 ~ArcSupportHost() override; |
25 | 30 |
26 ~ArcSupportHost() override; | 31 // Called when the communication to arc_support Chrome App is ready. |
| 32 void SetMessageHost(arc::ArcSupportMessageHost* message_host); |
| 33 |
| 34 // Called when the communication to arc_support Chrome App is closed. |
| 35 // The argument message_host is used to check if the given |message_host| |
| 36 // is what this instance uses know, to avoid racy case. |
| 37 // If |message_host| is different from the one this instance knows, |
| 38 // this is no op. |
| 39 void UnsetMessageHost(arc::ArcSupportMessageHost* message_host); |
27 | 40 |
28 // Requests to close the extension window. | 41 // Requests to close the extension window. |
29 void Close(); | 42 void Close(); |
| 43 void ShowPage(arc::ArcAuthService::UIPage page, const base::string16& status); |
30 | 44 |
31 // Overrides NativeMessageHost: | 45 // arc::ArcSupportMessageHost::Observer override: |
32 void Start(Client* client) override; | 46 void OnMessage(const base::DictionaryValue& message) override; |
33 void OnMessage(const std::string& request_string) override; | |
34 scoped_refptr<base::SingleThreadTaskRunner> task_runner() const override; | |
35 | |
36 // Overrides arc::ArcAuthService::Observer: | |
37 // TODO(hidehiko): Get rid of Observer interface. | |
38 void OnOptInUIClose() override; | |
39 void OnOptInUIShowPage(arc::ArcAuthService::UIPage page, | |
40 const base::string16& status) override; | |
41 | 47 |
42 // display::DisplayObserver: | 48 // display::DisplayObserver: |
43 void OnDisplayAdded(const display::Display& new_display) override; | 49 void OnDisplayAdded(const display::Display& new_display) override; |
44 void OnDisplayRemoved(const display::Display& old_display) override; | 50 void OnDisplayRemoved(const display::Display& old_display) override; |
45 void OnDisplayMetricsChanged(const display::Display& display, | 51 void OnDisplayMetricsChanged(const display::Display& display, |
46 uint32_t changed_metrics) override; | 52 uint32_t changed_metrics) override; |
47 | 53 |
48 private: | 54 private: |
49 ArcSupportHost(); | |
50 | |
51 bool Initialize(); | 55 bool Initialize(); |
52 void OnMetricsPreferenceChanged(); | 56 void OnMetricsPreferenceChanged(); |
53 void OnBackupAndRestorePreferenceChanged(); | 57 void OnBackupAndRestorePreferenceChanged(); |
54 void OnLocationServicePreferenceChanged(); | 58 void OnLocationServicePreferenceChanged(); |
55 | 59 |
56 // Utilities on preference update. | 60 // Utilities on preference update. |
57 void SendMetricsMode(); | 61 void SendMetricsMode(); |
58 void SendBackupAndRestoreMode(); | 62 void SendBackupAndRestoreMode(); |
59 void SendLocationServicesMode(); | 63 void SendLocationServicesMode(); |
60 void SendOptionMode(const std::string& action_name, | 64 void SendOptionMode(const std::string& action_name, |
61 const std::string& pref_name); | 65 const std::string& pref_name); |
62 | 66 |
63 // Sends a preference update to the extension. | 67 // Sends a preference update to the extension. |
64 // The message will be | 68 // The message will be |
65 // { | 69 // { |
66 // 'action': action_name, | 70 // 'action': action_name, |
67 // 'enabled': is_enabled, | 71 // 'enabled': is_enabled, |
68 // 'managed': is_managed | 72 // 'managed': is_managed |
69 // } | 73 // } |
70 void SendPreferenceUpdate(const std::string& action_name, | 74 void SendPreferenceUpdate(const std::string& action_name, |
71 bool is_enabled, | 75 bool is_enabled, |
72 bool is_managed); | 76 bool is_managed); |
73 | 77 |
74 void EnableMetrics(bool is_enabled); | 78 void EnableMetrics(bool is_enabled); |
75 void EnableBackupRestore(bool is_enabled); | 79 void EnableBackupRestore(bool is_enabled); |
76 void EnableLocationService(bool is_enabled); | 80 void EnableLocationService(bool is_enabled); |
77 | 81 |
78 // Unowned pointer. | 82 void DisconnectMessageHost(); |
79 Client* client_ = nullptr; | |
80 | 83 |
81 // Keep if Close() is requested from the browser. | 84 // The instance is created and managed by Chrome. |
82 // TODO(hidehiko): Remove this. This is temporarily introduced for checking | 85 arc::ArcSupportMessageHost* message_host_ = nullptr; |
83 // if ArcAuthService::CancelAuthCode() needs to be invoked or not. | |
84 // ArcAuthService should know its own state and the transition so moving to | |
85 // there should simplify the structure. However, it is blocked by the current | |
86 // dependency. For the clean up, more refactoring is needed, which can be | |
87 // bigger changes. | |
88 bool close_requested_ = false; | |
89 | 86 |
90 // Used to track metrics preference. | 87 // Used to track metrics preference. |
91 PrefChangeRegistrar pref_local_change_registrar_; | 88 PrefChangeRegistrar pref_local_change_registrar_; |
92 // Used to track backup&restore and location service preference. | 89 // Used to track backup&restore and location service preference. |
93 PrefChangeRegistrar pref_change_registrar_; | 90 PrefChangeRegistrar pref_change_registrar_; |
94 | 91 |
95 DISALLOW_COPY_AND_ASSIGN(ArcSupportHost); | 92 DISALLOW_COPY_AND_ASSIGN(ArcSupportHost); |
96 }; | 93 }; |
97 | 94 |
98 #endif // CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ | 95 #endif // CHROME_BROWSER_CHROMEOS_ARC_ARC_SUPPORT_HOST_H_ |
OLD | NEW |