blob: 9d740415a3bc66e247d506c144ab05a130349a1e [file] [log] [blame]
[email protected]45f5b7d2014-01-22 23:47:131// Copyright 2014 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef EXTENSIONS_BROWSER_RUNTIME_DATA_H_
6#define EXTENSIONS_BROWSER_RUNTIME_DATA_H_
7
8#include <map>
9#include <string>
10
11#include "base/compiler_specific.h"
12#include "extensions/browser/extension_registry_observer.h"
13
14namespace extensions {
15
16class Extension;
17class ExtensionRegistry;
18
19// Contains per-extension data that can change during the life of the process,
20// but does not persist across restarts. Shared between incognito and regular
21// browser contexts. Lives on the UI thread. Must be destroyed before
22// ExtensionRegistry.
23class RuntimeData : public ExtensionRegistryObserver {
24 public:
25 // Observes |registry| to clean itself up when extensions change state.
26 // |registry| must not be NULL.
27 explicit RuntimeData(ExtensionRegistry* registry);
dcheng9168b2f2014-10-21 12:38:2428 ~RuntimeData() override;
[email protected]45f5b7d2014-01-22 23:47:1329
30 // Whether the persistent background page, if any, is ready. We don't load
31 // other components until then. If there is no background page, or if it is
32 // non-persistent (lazy), we consider it to be ready.
33 bool IsBackgroundPageReady(const Extension* extension) const;
34 void SetBackgroundPageReady(const Extension* extension, bool value);
35
36 // Getter and setter for the flag that specifies whether the extension is
37 // being upgraded.
38 bool IsBeingUpgraded(const Extension* extension) const;
39 void SetBeingUpgraded(const Extension* extension, bool value);
40
41 // Getter and setter for the flag that specifies if the extension has used
42 // the webrequest API.
[email protected]45f5b7d2014-01-22 23:47:1343 bool HasUsedWebRequest(const Extension* extension) const;
44 void SetHasUsedWebRequest(const Extension* extension, bool value);
45
46 // Returns true if the extension is being tracked. Used only for testing.
47 bool HasExtensionForTesting(const Extension* extension) const;
48
49 // Erase runtime data for all extensions. Used only for testing. Cannot be
50 // named ClearAllForTesting due to false-positive presubmit errors.
51 void ClearAll();
52
53 // ExtensionRegistryObserver overrides. Public for testing.
dcheng9168b2f2014-10-21 12:38:2454 void OnExtensionUnloaded(content::BrowserContext* browser_context,
55 const Extension* extension,
56 UnloadedExtensionInfo::Reason reason) override;
[email protected]45f5b7d2014-01-22 23:47:1357
58 private:
59 // Bitmasks for runtime states.
60 enum RuntimeFlag {
61 // Set if the background page is ready.
62 BACKGROUND_PAGE_READY = 1 << 0,
63 // Set while the extension is being upgraded.
64 BEING_UPGRADED = 1 << 1,
65 // Set if the extension has used the webRequest API.
66 HAS_USED_WEBREQUEST = 1 << 2,
67 };
68
69 // Returns the setting for the flag or false if the extension isn't found.
70 bool HasFlag(const Extension* extension, RuntimeFlag flag) const;
71
72 // Sets |flag| for |extension| to |value|. Adds |extension| to the list of
73 // extensions if it isn't present.
74 void SetFlag(const Extension* extension, RuntimeFlag flag, bool value);
75
76 // Map from extension ID to the RuntimeFlags bits.
77 typedef std::map<std::string, int> ExtensionFlagsMap;
78 ExtensionFlagsMap extension_flags_;
79
80 ExtensionRegistry* registry_; // Not owned.
81};
82
83} // namespace extensions
84
85#endif // EXTENSIONS_BROWSER_RUNTIME_DATA_H_