OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_LOGIN_OWNERSHIP_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_CHROMEOS_LOGIN_OWNERSHIP_SERVICE_H_ |
6 #define CHROME_BROWSER_CHROMEOS_LOGIN_OWNERSHIP_SERVICE_H_ | 6 #define CHROME_BROWSER_CHROMEOS_LOGIN_OWNERSHIP_SERVICE_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
11 | 11 |
12 #include "base/callback.h" | 12 #include "base/callback.h" |
13 #include "base/compiler_specific.h" | 13 #include "base/compiler_specific.h" |
14 #include "base/synchronization/lock.h" | 14 #include "base/synchronization/lock.h" |
15 #include "chrome/browser/chromeos/login/owner_key_utils.h" | 15 #include "chrome/browser/chromeos/login/owner_key_utils.h" |
16 #include "chrome/browser/chromeos/login/owner_manager.h" | 16 #include "chrome/browser/chromeos/login/owner_manager.h" |
17 #include "chrome/browser/policy/proto/device_management_backend.pb.h" | |
18 #include "content/public/browser/browser_thread.h" | 17 #include "content/public/browser/browser_thread.h" |
19 #include "content/public/browser/notification_observer.h" | 18 #include "content/public/browser/notification_observer.h" |
20 #include "content/public/browser/notification_registrar.h" | 19 #include "content/public/browser/notification_registrar.h" |
21 | 20 |
22 namespace base { | 21 namespace base { |
23 template <typename T> struct DefaultLazyInstanceTraits; | 22 template <typename T> struct DefaultLazyInstanceTraits; |
24 } | 23 } |
25 | 24 |
26 namespace em = enterprise_management; | |
27 namespace chromeos { | 25 namespace chromeos { |
28 | 26 |
29 class OwnershipService : public content::NotificationObserver { | 27 class OwnershipService : public content::NotificationObserver { |
30 public: | 28 public: |
31 enum Status { | 29 enum Status { |
32 // Listed in upgrade order. | 30 // Listed in upgrade order. |
33 OWNERSHIP_UNKNOWN = 0, | 31 OWNERSHIP_UNKNOWN = 0, |
34 OWNERSHIP_NONE, | 32 OWNERSHIP_NONE, |
35 OWNERSHIP_TAKEN | 33 OWNERSHIP_TAKEN |
36 }; | 34 }; |
37 | 35 |
38 // Returns the singleton instance of the OwnershipService. | 36 // Returns the singleton instance of the OwnershipService. |
39 static OwnershipService* GetSharedInstance(); | 37 static OwnershipService* GetSharedInstance(); |
40 virtual ~OwnershipService(); | 38 virtual ~OwnershipService(); |
41 | 39 |
42 // Called after FILE thread is created to prefetch ownership status and avoid | 40 // Called after FILE thread is created to prefetch ownership status and avoid |
43 // blocking on UI thread. | 41 // blocking on UI thread. |
44 void Prewarm(); | 42 void Prewarm(); |
45 | 43 |
46 // Owner settings are being re-implemented as a single, signed protobuf | |
47 // that is stored by the session manager. Thus, to write a setting, you | |
48 // need to have the existing policy, update it, re-sign it, and then have | |
49 // it stored. This could be done by requesting the policy every time, or | |
50 // by caching it and updating it upon every successful store. | |
51 // Caching is faster and easier, so we'll do that. These are the | |
52 // getters/setters for the cached policy. | |
53 virtual void set_cached_policy(const em::PolicyData& pol); | |
54 virtual bool has_cached_policy(); | |
55 virtual const em::PolicyData& cached_policy(); | |
56 | |
57 // Sets a new owner key. This will _not_ load the key material from disk, but | 44 // Sets a new owner key. This will _not_ load the key material from disk, but |
58 // rather update Chrome's in-memory copy of the key. |callback| will be | 45 // rather update Chrome's in-memory copy of the key. |callback| will be |
59 // invoked once the operation completes. | 46 // invoked once the operation completes. |
60 virtual void StartUpdateOwnerKey(const std::vector<uint8>& new_key, | 47 virtual void StartUpdateOwnerKey(const std::vector<uint8>& new_key, |
61 OwnerManager::KeyUpdateDelegate* d); | 48 OwnerManager::KeyUpdateDelegate* d); |
62 | 49 |
63 // If the device has been owned already, posts a task to the FILE thread to | 50 // If the device has been owned already, posts a task to the FILE thread to |
64 // fetch the public key off disk. | 51 // fetch the public key off disk. |
65 // | 52 // |
66 // Sends out a OWNER_KEY_FETCH_ATTEMPT_SUCCESS notification on success, | 53 // Sends out a OWNER_KEY_FETCH_ATTEMPT_SUCCESS notification on success, |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
130 const content::BrowserThread::ID thread_id, | 117 const content::BrowserThread::ID thread_id, |
131 const std::string& data, | 118 const std::string& data, |
132 const std::vector<uint8>& signature, | 119 const std::vector<uint8>& signature, |
133 OwnerManager::Delegate* d); | 120 OwnerManager::Delegate* d); |
134 static void FailAttempt(OwnerManager::Delegate* d); | 121 static void FailAttempt(OwnerManager::Delegate* d); |
135 | 122 |
136 OwnerManager* manager() { return manager_.get(); } | 123 OwnerManager* manager() { return manager_.get(); } |
137 | 124 |
138 scoped_refptr<OwnerManager> manager_; | 125 scoped_refptr<OwnerManager> manager_; |
139 scoped_refptr<OwnerKeyUtils> utils_; | 126 scoped_refptr<OwnerKeyUtils> utils_; |
140 scoped_ptr<em::PolicyData> policy_; | |
141 content::NotificationRegistrar notification_registrar_; | 127 content::NotificationRegistrar notification_registrar_; |
142 volatile Status ownership_status_; | 128 volatile Status ownership_status_; |
143 base::Lock ownership_status_lock_; | 129 base::Lock ownership_status_lock_; |
144 }; | 130 }; |
145 | 131 |
146 } // namespace chromeos | 132 } // namespace chromeos |
147 | 133 |
148 #endif // CHROME_BROWSER_CHROMEOS_LOGIN_OWNERSHIP_SERVICE_H_ | 134 #endif // CHROME_BROWSER_CHROMEOS_LOGIN_OWNERSHIP_SERVICE_H_ |
OLD | NEW |