Index: chrome/browser/chromeos/lock_screen_apps/app_manager.h |
diff --git a/chrome/browser/chromeos/lock_screen_apps/app_manager.h b/chrome/browser/chromeos/lock_screen_apps/app_manager.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4db0f719bf0edfa490ffc98bb59a845a5e4cfc6f |
--- /dev/null |
+++ b/chrome/browser/chromeos/lock_screen_apps/app_manager.h |
@@ -0,0 +1,62 @@ |
+// Copyright 2017 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_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ |
+#define CHROME_BROWSER_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ |
+ |
+#include <string> |
+ |
+#include "base/callback_forward.h" |
+ |
+class Profile; |
+ |
+namespace lock_screen_apps { |
+ |
+// Interface for managing lock screen enabled action handler apps in the lock |
+// screen enabled profile. Initially, it will be used primarily to manage lock |
+// screen note taking apps. |
+class AppManager { |
+ public: |
+ virtual ~AppManager() {} |
+ |
+ // Initializes the manager. |
+ // |primary_profile| - the profile which is the source of the lock screen |
+ // action handler app (if one is set). This is the profile whose |
+ // settings are used to determine whether and for which app lock screen |
+ // action is enabled, and it should be associated with the primary user. |
+ // |lock_screen_profile| - the profile in which lock screen apps should be |
+ // installed and launched. This profile should be annonymous - i.e. not |
+ // associated with any user. |
+ virtual void Initialize(Profile* primary_profile, |
+ Profile* lock_screen_profile) = 0; |
+ |
+ // Activates the manager - this should ensure that lock screen enabled note |
+ // taking app, if available, is loaded and enabled in the lock screen profile. |
+ // |note_taking_changed_callback| - used to notify the client when the note |
+ // taking app availability changes. It's cleared when the AppManager is |
+ // stopped. It is not expected to be run after the app manager instance |
+ // is destroyed. |
+ virtual void Start(const base::Closure& note_taking_changed_callback) = 0; |
+ |
+ // Stops the manager. After this is called, the app can be unloaded from the |
+ // lock screen enabled profile. Subsequent launch requests should not be |
+ // allowed. |
+ virtual void Stop() = 0; |
+ |
+ // If lock screen note taking app is available, launches the app with lock |
+ // screen note taking action. |
+ // Returns whether the app launch was attempted. |
+ virtual bool LaunchNoteTaking() = 0; |
+ |
+ // Returns whether a lock screen note taking is enabled and ready to launch. |
+ virtual bool IsNoteTakingAppAvailable() const = 0; |
+ |
+ // Returns the lock screen enabled lock screen note taking app, if a note |
+ // taking app is enabled on lock screen (for primary profile). |
+ virtual std::string GetNoteTakingAppId() const = 0; |
+}; |
+ |
+} // namespace lock_screen_apps |
+ |
+#endif // CHROME_BROWSER_CHROMEOS_LOCK_SCREEN_APPS_APP_MANAGER_H_ |