OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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_POLICY_DEVICE_LOCAL_ACCOUNT_H_ | 5 #ifndef CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_LOCAL_ACCOUNT_H_ |
6 #define CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_LOCAL_ACCOUNT_H_ | 6 #define CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_LOCAL_ACCOUNT_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 14 matching lines...) Expand all Loading... |
25 // Sentinel, must be last. | 25 // Sentinel, must be last. |
26 TYPE_COUNT | 26 TYPE_COUNT |
27 }; | 27 }; |
28 | 28 |
29 DeviceLocalAccount(Type type, | 29 DeviceLocalAccount(Type type, |
30 const std::string& account_id, | 30 const std::string& account_id, |
31 const std::string& kiosk_app_id); | 31 const std::string& kiosk_app_id); |
32 ~DeviceLocalAccount(); | 32 ~DeviceLocalAccount(); |
33 | 33 |
34 Type type; | 34 Type type; |
| 35 // A device-local account has two identifiers: |
| 36 // * The |account_id| is chosen by the entity that defines the device-local |
| 37 // account. The only constraints are that the |account_id| be unique and, |
| 38 // for legacy reasons, it contain an @ symbol. |
| 39 // * The |user_id| is a synthesized identifier that is guaranteed to be |
| 40 // unique, contain an @ symbol, not collide with the |user_id| of any other |
| 41 // user on the device (such as regular users or supervised users) and be |
| 42 // identifiable as belonging to a device-local account by. |
| 43 // The |account_id| is primarily used by policy code: If device policy defines |
| 44 // a device-local account with a certain |account_id|, the user policy for |
| 45 // that account has to be fetched by referencing the same |account_id|. |
| 46 // The |user_id| is passed to the chromeos::UserManager where it becomes part |
| 47 // of the global user list on the device. The |account_id| would not be safe |
| 48 // to use here as it is a free-form identifier that could conflict with |
| 49 // another |user_id| on the device and cannot be easily identified as |
| 50 // belonging to a device-local account. |
35 std::string account_id; | 51 std::string account_id; |
36 std::string user_id; | 52 std::string user_id; |
37 std::string kiosk_app_id; | 53 std::string kiosk_app_id; |
38 }; | 54 }; |
39 | 55 |
40 std::string GenerateDeviceLocalAccountUserId(const std::string& account_id, | 56 std::string GenerateDeviceLocalAccountUserId(const std::string& account_id, |
41 DeviceLocalAccount::Type type); | 57 DeviceLocalAccount::Type type); |
42 | 58 |
43 // Determines whether |user_id| belongs to a device-local account and if so, | 59 // Determines whether |user_id| belongs to a device-local account and if so, |
44 // returns the type of device-local account in |type| unless |type| is NULL. | 60 // returns the type of device-local account in |type| unless |type| is NULL. |
45 bool IsDeviceLocalAccountUser(const std::string& user_id, | 61 bool IsDeviceLocalAccountUser(const std::string& user_id, |
46 DeviceLocalAccount::Type* type); | 62 DeviceLocalAccount::Type* type); |
47 | 63 |
48 // Stores a list of device-local accounts in |cros_settings|. The accounts are | 64 // Stores a list of device-local accounts in |cros_settings|. The accounts are |
49 // stored as a list of dictionaries with each dictionary containing the | 65 // stored as a list of dictionaries with each dictionary containing the |
50 // information about one |DeviceLocalAccount|. | 66 // information about one |DeviceLocalAccount|. |
51 void SetDeviceLocalAccounts( | 67 void SetDeviceLocalAccounts( |
52 chromeos::CrosSettings* cros_settings, | 68 chromeos::CrosSettings* cros_settings, |
53 const std::vector<DeviceLocalAccount>& accounts); | 69 const std::vector<DeviceLocalAccount>& accounts); |
54 | 70 |
55 // Retrieves a list of device-local accounts from |cros_settings|. | 71 // Retrieves a list of device-local accounts from |cros_settings|. |
56 std::vector<DeviceLocalAccount> GetDeviceLocalAccounts( | 72 std::vector<DeviceLocalAccount> GetDeviceLocalAccounts( |
57 chromeos::CrosSettings* cros_settings); | 73 chromeos::CrosSettings* cros_settings); |
58 | 74 |
59 } // namespace policy | 75 } // namespace policy |
60 | 76 |
61 #endif // CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_LOCAL_ACCOUNT_H_ | 77 #endif // CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_LOCAL_ACCOUNT_H_ |
OLD | NEW |