// Copyright 2014 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 EXTENSIONS_BROWSER_STATE_STORE_H_ #define EXTENSIONS_BROWSER_STATE_STORE_H_ #include #include #include "base/files/file_path.h" #include "base/memory/weak_ptr.h" #include "base/scoped_observer.h" #include "content/public/browser/notification_observer.h" #include "content/public/browser/notification_registrar.h" #include "extensions/browser/extension_registry_observer.h" #include "extensions/browser/value_store/value_store_frontend.h" namespace content { class BrowserContext; } namespace extensions { class ExtensionRegistry; class ValueStoreFactory; // A storage area for per-extension state that needs to be persisted to disk. class StateStore : public base::SupportsWeakPtr, public ExtensionRegistryObserver, public content::NotificationObserver { public: typedef ValueStoreFrontend::ReadCallback ReadCallback; // If |deferred_load| is true, we won't load the database until the first // page has been loaded. StateStore(content::BrowserContext* context, const scoped_refptr& store_factory, ValueStoreFrontend::BackendType backend_type, bool deferred_load); // This variant is useful for testing (using a mock ValueStore). StateStore(content::BrowserContext* context, scoped_ptr store); ~StateStore() override; // Requests that the state store to be initialized after its usual delay. Can // be explicitly called by an embedder when the embedder does not trigger the // usual page load notifications. void RequestInitAfterDelay(); // Register a key for removal upon extension install/uninstall. We remove // for install to reset state when an extension upgrades. void RegisterKey(const std::string& key); // Get the value associated with the given extension and key, and pass // it to |callback| asynchronously. void GetExtensionValue(const std::string& extension_id, const std::string& key, ReadCallback callback); // Sets a value for a given extension and key. void SetExtensionValue(const std::string& extension_id, const std::string& key, scoped_ptr value); // Removes a value for a given extension and key. void RemoveExtensionValue(const std::string& extension_id, const std::string& key); // Return whether or not the StateStore has initialized itself. bool IsInitialized() const; private: class DelayedTaskQueue; // content::NotificationObserver void Observe(int type, const content::NotificationSource& source, const content::NotificationDetails& details) override; void Init(); // When StateStore is constructed with |deferred_load| its initialization is // delayed to avoid slowing down startup. void InitAfterDelay(); // Removes all keys registered for the given extension. void RemoveKeysForExtension(const std::string& extension_id); // ExtensionRegistryObserver implementation. void OnExtensionUninstalled(content::BrowserContext* browser_context, const Extension* extension, extensions::UninstallReason reason) override; void OnExtensionWillBeInstalled(content::BrowserContext* browser_context, const Extension* extension, bool is_update, const std::string& old_name) override; // The store that holds our key/values. scoped_ptr store_; // List of all known keys. They will be cleared for each extension when it is // (un)installed. std::set registered_keys_; // Keeps track of tasks we have delayed while starting up. scoped_ptr task_queue_; content::NotificationRegistrar registrar_; ScopedObserver extension_registry_observer_; }; } // namespace extensions #endif // EXTENSIONS_BROWSER_STATE_STORE_H_