| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "chrome/browser/extensions/api/storage/managed_value_store_cache.h" | 5 #include "chrome/browser/extensions/api/storage/managed_value_store_cache.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/files/file_util.h" | 10 #include "base/files/file_util.h" |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 68 : public ExtensionRegistryObserver { | 68 : public ExtensionRegistryObserver { |
| 69 public: | 69 public: |
| 70 explicit ExtensionTracker(Profile* profile); | 70 explicit ExtensionTracker(Profile* profile); |
| 71 ~ExtensionTracker() override {} | 71 ~ExtensionTracker() override {} |
| 72 | 72 |
| 73 private: | 73 private: |
| 74 // ExtensionRegistryObserver implementation. | 74 // ExtensionRegistryObserver implementation. |
| 75 void OnExtensionWillBeInstalled(content::BrowserContext* browser_context, | 75 void OnExtensionWillBeInstalled(content::BrowserContext* browser_context, |
| 76 const Extension* extension, | 76 const Extension* extension, |
| 77 bool is_update, | 77 bool is_update, |
| 78 bool from_ephemeral, | |
| 79 const std::string& old_name) override; | 78 const std::string& old_name) override; |
| 80 void OnExtensionUninstalled(content::BrowserContext* browser_context, | 79 void OnExtensionUninstalled(content::BrowserContext* browser_context, |
| 81 const Extension* extension, | 80 const Extension* extension, |
| 82 extensions::UninstallReason reason) override; | 81 extensions::UninstallReason reason) override; |
| 83 | 82 |
| 84 // Handler for the signal from ExtensionSystem::ready(). | 83 // Handler for the signal from ExtensionSystem::ready(). |
| 85 void OnExtensionsReady(); | 84 void OnExtensionsReady(); |
| 86 | 85 |
| 87 // Starts a schema load for all extensions that use managed storage. | 86 // Starts a schema load for all extensions that use managed storage. |
| 88 void LoadSchemas(scoped_ptr<ExtensionSet> added); | 87 void LoadSchemas(scoped_ptr<ExtensionSet> added); |
| (...skipping 26 matching lines...) Expand all Loading... |
| 115 ExtensionSystem::Get(profile_)->ready().Post( | 114 ExtensionSystem::Get(profile_)->ready().Post( |
| 116 FROM_HERE, | 115 FROM_HERE, |
| 117 base::Bind(&ExtensionTracker::OnExtensionsReady, | 116 base::Bind(&ExtensionTracker::OnExtensionsReady, |
| 118 weak_factory_.GetWeakPtr())); | 117 weak_factory_.GetWeakPtr())); |
| 119 } | 118 } |
| 120 | 119 |
| 121 void ManagedValueStoreCache::ExtensionTracker::OnExtensionWillBeInstalled( | 120 void ManagedValueStoreCache::ExtensionTracker::OnExtensionWillBeInstalled( |
| 122 content::BrowserContext* browser_context, | 121 content::BrowserContext* browser_context, |
| 123 const Extension* extension, | 122 const Extension* extension, |
| 124 bool is_update, | 123 bool is_update, |
| 125 bool from_ephemeral, | |
| 126 const std::string& old_name) { | 124 const std::string& old_name) { |
| 127 // Some extensions are installed on the first run before the ExtensionSystem | 125 // Some extensions are installed on the first run before the ExtensionSystem |
| 128 // becomes ready. Wait until all of them are ready before registering the | 126 // becomes ready. Wait until all of them are ready before registering the |
| 129 // schemas of managed extensions, so that the policy loaders are reloaded at | 127 // schemas of managed extensions, so that the policy loaders are reloaded at |
| 130 // most once. | 128 // most once. |
| 131 if (!ExtensionSystem::Get(profile_)->ready().is_signaled()) | 129 if (!ExtensionSystem::Get(profile_)->ready().is_signaled()) |
| 132 return; | 130 return; |
| 133 scoped_ptr<ExtensionSet> added(new ExtensionSet); | 131 scoped_ptr<ExtensionSet> added(new ExtensionSet); |
| 134 added->Insert(extension); | 132 added->Insert(extension); |
| 135 LoadSchemas(added.Pass()); | 133 LoadSchemas(added.Pass()); |
| (...skipping 231 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 367 | 365 |
| 368 return store; | 366 return store; |
| 369 } | 367 } |
| 370 | 368 |
| 371 bool ManagedValueStoreCache::HasStore(const std::string& extension_id) const { | 369 bool ManagedValueStoreCache::HasStore(const std::string& extension_id) const { |
| 372 // TODO(joaodasilva): move this check to a ValueStore method. | 370 // TODO(joaodasilva): move this check to a ValueStore method. |
| 373 return base::DirectoryExists(base_path_.AppendASCII(extension_id)); | 371 return base::DirectoryExists(base_path_.AppendASCII(extension_id)); |
| 374 } | 372 } |
| 375 | 373 |
| 376 } // namespace extensions | 374 } // namespace extensions |
| OLD | NEW |