OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_CHROMEOS_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ |
6 #define CHROME_BROWSER_CHROMEOS_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ | 6 #define CHROME_BROWSER_CHROMEOS_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ |
7 | 7 |
| 8 #include <queue> |
8 #include <string> | 9 #include <string> |
9 #include <vector> | 10 #include <vector> |
10 | 11 |
11 #include "base/callback_forward.h" | 12 #include "base/callback_forward.h" |
12 #include "base/macros.h" | 13 #include "base/macros.h" |
| 14 #include "base/memory/linked_ptr.h" |
13 #include "base/memory/scoped_ptr.h" | 15 #include "base/memory/scoped_ptr.h" |
14 #include "base/memory/weak_ptr.h" | 16 #include "base/memory/weak_ptr.h" |
15 #include "chrome/browser/chromeos/platform_keys/platform_keys.h" | 17 #include "chrome/browser/chromeos/platform_keys/platform_keys.h" |
16 #include "components/keyed_service/core/keyed_service.h" | 18 #include "components/keyed_service/core/keyed_service.h" |
17 | 19 |
18 namespace content { | 20 namespace content { |
19 class BrowserContext; | 21 class BrowserContext; |
20 } | 22 } |
21 | 23 |
22 namespace base { | 24 namespace base { |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
108 // certificate dialog. | 110 // certificate dialog. |
109 void SelectClientCertificates( | 111 void SelectClientCertificates( |
110 const platform_keys::ClientCertificateRequest& request, | 112 const platform_keys::ClientCertificateRequest& request, |
111 const std::string& extension_id, | 113 const std::string& extension_id, |
112 const SelectCertificatesCallback& callback); | 114 const SelectCertificatesCallback& callback); |
113 | 115 |
114 private: | 116 private: |
115 using GetPlatformKeysCallback = | 117 using GetPlatformKeysCallback = |
116 base::Callback<void(scoped_ptr<base::ListValue> platform_keys)>; | 118 base::Callback<void(scoped_ptr<base::ListValue> platform_keys)>; |
117 | 119 |
118 // Registers the given public key as newly generated key, which is allowed to | 120 class Task; |
119 // be used for signing for a single time. Afterwards, calls |callback|. If | 121 class SignTask; |
120 // registration was successful, passes |true| otherwise |false| to the | 122 class PermissionUpdateTask; |
121 // callback. | |
122 void RegisterPublicKey(const std::string& extension_id, | |
123 const std::string& public_key_spki_der, | |
124 const base::Closure& callback); | |
125 | 123 |
126 // Gets the current validity of the given public key by reading StateStore. | 124 // Starts |task| eventually. To ensures that at most one |Task| is running at |
127 // Invalidates the key if it was found to be valid. Finally, calls |callback| | 125 // a time, it queues |task| for later execution if necessary. |
128 // with the old validity. | 126 void StartOrQueueTask(scoped_ptr<Task> task); |
129 void ReadValidityAndInvalidateKey(const std::string& extension_id, | 127 |
130 const std::string& public_key_spki_der, | 128 // Must be called after |task| is done. |task| will be invalid after this |
131 const base::Callback<void(bool)>& callback); | 129 // call. This must not be called for any but the task that ran last. If any |
| 130 // other tasks are queued (see StartOrQueueTask()), it will start the next |
| 131 // one. |
| 132 void TaskFinished(Task* task); |
132 | 133 |
133 // Reads the list of public keys currently registered for |extension_id| from | 134 // Reads the list of public keys currently registered for |extension_id| from |
134 // StateStore. Calls |callback| with the read list, or a new empty list if | 135 // StateStore. Calls |callback| with the read list, or a new empty list if |
135 // none existed. If an error occurred, calls |callback| with NULL. | 136 // none existed. If an error occurred, calls |callback| with NULL. |
136 void GetPlatformKeysOfExtension(const std::string& extension_id, | 137 void GetPlatformKeysOfExtension(const std::string& extension_id, |
137 const GetPlatformKeysCallback& callback); | 138 const GetPlatformKeysCallback& callback); |
138 | 139 |
139 // Writes |platform_keys| to the state store of the extension with id | 140 // Writes |platform_keys| to the state store of the extension with id |
140 // |extension_id|. | 141 // |extension_id|. |
141 void SetPlatformKeysOfExtension(const std::string& extension_id, | 142 void SetPlatformKeysOfExtension(const std::string& extension_id, |
142 scoped_ptr<base::ListValue> platform_keys); | 143 scoped_ptr<base::ListValue> platform_keys); |
143 | 144 |
144 // Callback used by |GenerateRSAKey|. | 145 // Callback used by |GenerateRSAKey|. |
145 // If the key generation was successful, registers the generated public key | 146 // If the key generation was successful, registers the generated public key |
146 // for the given extension. If any error occurs during key generation or | 147 // for the given extension. If any error occurs during key generation or |
147 // registration, calls |callback| with an error. Otherwise, on success, calls | 148 // registration, calls |callback| with an error. Otherwise, on success, calls |
148 // |callback| with the public key. | 149 // |callback| with the public key. |
149 void GenerateRSAKeyCallback(const std::string& extension_id, | 150 void GeneratedKey(const std::string& extension_id, |
150 const GenerateKeyCallback& callback, | 151 const GenerateKeyCallback& callback, |
151 const std::string& public_key_spki_der, | 152 const std::string& public_key_spki_der, |
152 const std::string& error_message); | 153 const std::string& error_message); |
| 154 |
| 155 // Callback used by |GeneratedKey|. |
| 156 // |public_key_spki_der| will contain the X.509 Subject Public Key Info of |
| 157 // the generated key in DER encoding. |task| points to the finished |Task| |
| 158 // object. |
| 159 void DidRegisterGeneratedKey(const GenerateKeyCallback& callback, |
| 160 const std::string& public_key_spki_der, |
| 161 Task* task); |
153 | 162 |
154 // Calback used by |SelectClientCertificates|. | 163 // Calback used by |SelectClientCertificates|. |
155 // If the certificate request could be processed successfully, |matches| will | 164 // If the certificate request could be processed successfully, |matches| will |
156 // contain the list of matching certificates (maybe empty) and |error_message| | 165 // contain the list of matching certificates (maybe empty) and |error_message| |
157 // will be empty. If an error occurred, |matches| will be null and | 166 // will be empty. If an error occurred, |matches| will be null and |
158 // |error_message| contain an error message. | 167 // |error_message| contain an error message. |
159 void SelectClientCertificatesCallback( | 168 void SelectClientCertificatesCallback( |
160 const std::string& extension_id, | 169 const std::string& extension_id, |
161 const SelectCertificatesCallback& callback, | 170 const SelectCertificatesCallback& callback, |
162 scoped_ptr<net::CertificateList> matches, | 171 scoped_ptr<net::CertificateList> matches, |
163 const std::string& error_message); | 172 const std::string& error_message); |
164 | 173 |
165 // Callback used by |RegisterPublicKey|. | |
166 // Updates the old |platform_keys| read from the StateStore and writes the | |
167 // updated value back to the StateStore. | |
168 void RegisterPublicKeyGotPlatformKeys( | |
169 const std::string& extension_id, | |
170 const std::string& public_key_spki_der, | |
171 const base::Closure& callback, | |
172 scoped_ptr<base::ListValue> platform_keys); | |
173 | |
174 // Callback used by |ReadValidityAndInvalidateKey|. | |
175 // Invalidates the given public key so that future signing is prohibited and | |
176 // calls |callback| with the old validity. | |
177 void InvalidateKey(const std::string& extension_id, | |
178 const std::string& public_key_spki_der, | |
179 const base::Callback<void(bool)>& callback, | |
180 scoped_ptr<base::ListValue> platform_keys); | |
181 | |
182 // Callback used by |GetPlatformKeysOfExtension|. | 174 // Callback used by |GetPlatformKeysOfExtension|. |
183 // Is called with |value| set to the PlatformKeys value read from the | 175 // Is called with |value| set to the PlatformKeys value read from the |
184 // StateStore, which it forwards to |callback|. On error, calls |callback| | 176 // StateStore, which it forwards to |callback|. On error, calls |callback| |
185 // with NULL; if no value existed, with an empty list. | 177 // with NULL; if no value existed, with an empty list. |
186 void GotPlatformKeysOfExtension(const std::string& extension_id, | 178 void GotPlatformKeysOfExtension(const std::string& extension_id, |
187 const GetPlatformKeysCallback& callback, | 179 const GetPlatformKeysCallback& callback, |
188 scoped_ptr<base::Value> value); | 180 scoped_ptr<base::Value> value); |
189 | 181 |
190 content::BrowserContext* browser_context_; | 182 content::BrowserContext* browser_context_; |
191 extensions::StateStore* state_store_; | 183 extensions::StateStore* state_store_; |
192 bool permission_check_enabled_ = true; | 184 bool permission_check_enabled_ = true; |
| 185 std::queue<linked_ptr<Task>> tasks_; |
193 base::WeakPtrFactory<PlatformKeysService> weak_factory_; | 186 base::WeakPtrFactory<PlatformKeysService> weak_factory_; |
194 | 187 |
195 DISALLOW_COPY_AND_ASSIGN(PlatformKeysService); | 188 DISALLOW_COPY_AND_ASSIGN(PlatformKeysService); |
196 }; | 189 }; |
197 | 190 |
198 } // namespace chromeos | 191 } // namespace chromeos |
199 | 192 |
200 #endif // CHROME_BROWSER_CHROMEOS_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ | 193 #endif // CHROME_BROWSER_CHROMEOS_PLATFORM_KEYS_PLATFORM_KEYS_SERVICE_H_ |
OLD | NEW |