| 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 #ifndef CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ |
| 6 #define CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ |
| 7 | 7 |
| 8 #include <map> | 8 #include <map> |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 79 const std::string& api_name, | 79 const std::string& api_name, |
| 80 const std::string& page_url, | 80 const std::string& page_url, |
| 81 const std::string& arg_url, | 81 const std::string& arg_url, |
| 82 const int days_ago, | 82 const int days_ago, |
| 83 const base::Callback | 83 const base::Callback |
| 84 <void(scoped_ptr<std::vector<scoped_refptr<Action> > >)>& callback); | 84 <void(scoped_ptr<std::vector<scoped_refptr<Action> > >)>& callback); |
| 85 | 85 |
| 86 // ExtensionRegistryObserver. | 86 // ExtensionRegistryObserver. |
| 87 // We keep track of whether the whitelisted extension is installed; if it is, | 87 // We keep track of whether the whitelisted extension is installed; if it is, |
| 88 // we want to recompute whether to have logging enabled. | 88 // we want to recompute whether to have logging enabled. |
| 89 virtual void OnExtensionLoaded(content::BrowserContext* browser_context, | 89 void OnExtensionLoaded(content::BrowserContext* browser_context, |
| 90 const Extension* extension) override; | 90 const Extension* extension) override; |
| 91 virtual void OnExtensionUnloaded( | 91 void OnExtensionUnloaded(content::BrowserContext* browser_context, |
| 92 content::BrowserContext* browser_context, | 92 const Extension* extension, |
| 93 const Extension* extension, | 93 UnloadedExtensionInfo::Reason reason) override; |
| 94 UnloadedExtensionInfo::Reason reason) override; | 94 void OnExtensionUninstalled(content::BrowserContext* browser_context, |
| 95 virtual void OnExtensionUninstalled( | 95 const Extension* extension, |
| 96 content::BrowserContext* browser_context, | 96 extensions::UninstallReason reason) override; |
| 97 const Extension* extension, | |
| 98 extensions::UninstallReason reason) override; | |
| 99 | 97 |
| 100 // ApiActivityMonitor. | 98 // ApiActivityMonitor. |
| 101 virtual void OnApiEventDispatched( | 99 void OnApiEventDispatched(const std::string& extension_id, |
| 102 const std::string& extension_id, | 100 const std::string& event_name, |
| 103 const std::string& event_name, | 101 scoped_ptr<base::ListValue> event_args) override; |
| 104 scoped_ptr<base::ListValue> event_args) override; | 102 void OnApiFunctionCalled(const std::string& extension_id, |
| 105 virtual void OnApiFunctionCalled( | 103 const std::string& api_name, |
| 106 const std::string& extension_id, | 104 scoped_ptr<base::ListValue> event_args) override; |
| 107 const std::string& api_name, | |
| 108 scoped_ptr<base::ListValue> event_args) override; | |
| 109 | 105 |
| 110 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); | 106 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); |
| 111 | 107 |
| 112 // Remove actions from the activity log database which IDs specified in the | 108 // Remove actions from the activity log database which IDs specified in the |
| 113 // action_ids array. | 109 // action_ids array. |
| 114 void RemoveActions(const std::vector<int64>& action_ids); | 110 void RemoveActions(const std::vector<int64>& action_ids); |
| 115 | 111 |
| 116 // Clean up URLs from the activity log database. | 112 // Clean up URLs from the activity log database. |
| 117 // If restrict_urls is empty then all URLs in the activity log database are | 113 // If restrict_urls is empty then all URLs in the activity log database are |
| 118 // removed, otherwise only those in restrict_urls are removed. | 114 // removed, otherwise only those in restrict_urls are removed. |
| 119 void RemoveURLs(const std::vector<GURL>& restrict_urls); | 115 void RemoveURLs(const std::vector<GURL>& restrict_urls); |
| 120 void RemoveURLs(const std::set<GURL>& restrict_urls); | 116 void RemoveURLs(const std::set<GURL>& restrict_urls); |
| 121 void RemoveURL(const GURL& url); | 117 void RemoveURL(const GURL& url); |
| 122 | 118 |
| 123 // Deletes the database associated with the policy that's currently in use. | 119 // Deletes the database associated with the policy that's currently in use. |
| 124 void DeleteDatabase(); | 120 void DeleteDatabase(); |
| 125 | 121 |
| 126 // If we're in a browser test, we need to pretend that the watchdog app is | 122 // If we're in a browser test, we need to pretend that the watchdog app is |
| 127 // active. | 123 // active. |
| 128 void SetWatchdogAppActiveForTesting(bool active); | 124 void SetWatchdogAppActiveForTesting(bool active); |
| 129 | 125 |
| 130 private: | 126 private: |
| 131 friend class ActivityLogTest; | 127 friend class ActivityLogTest; |
| 132 friend class BrowserContextKeyedAPIFactory<ActivityLog>; | 128 friend class BrowserContextKeyedAPIFactory<ActivityLog>; |
| 133 | 129 |
| 134 explicit ActivityLog(content::BrowserContext* context); | 130 explicit ActivityLog(content::BrowserContext* context); |
| 135 virtual ~ActivityLog(); | 131 ~ActivityLog() override; |
| 136 | 132 |
| 137 // Specifies if the Watchdog app is active (installed & enabled). | 133 // Specifies if the Watchdog app is active (installed & enabled). |
| 138 // If so, we need to log to the database and stream to the API. | 134 // If so, we need to log to the database and stream to the API. |
| 139 bool IsWatchdogAppActive(); | 135 bool IsWatchdogAppActive(); |
| 140 | 136 |
| 141 // Specifies if we need to record actions to the db. If so, we need to log to | 137 // Specifies if we need to record actions to the db. If so, we need to log to |
| 142 // the database. This is true if the Watchdog app is active *or* the | 138 // the database. This is true if the Watchdog app is active *or* the |
| 143 // --enable-extension-activity-logging flag is set. | 139 // --enable-extension-activity-logging flag is set. |
| 144 bool IsDatabaseEnabled(); | 140 bool IsDatabaseEnabled(); |
| 145 | 141 |
| 146 // Delayed initialization of ExtensionRegistry which waits until after the | 142 // Delayed initialization of ExtensionRegistry which waits until after the |
| 147 // ExtensionSystem/ExtensionService are done with their own setup. | 143 // ExtensionSystem/ExtensionService are done with their own setup. |
| 148 void StartObserving(); | 144 void StartObserving(); |
| 149 | 145 |
| 150 // ScriptExecutionObserver implementation. | 146 // ScriptExecutionObserver implementation. |
| 151 // Fires when a ContentScript is executed. | 147 // Fires when a ContentScript is executed. |
| 152 virtual void OnScriptsExecuted( | 148 void OnScriptsExecuted(const content::WebContents* web_contents, |
| 153 const content::WebContents* web_contents, | 149 const ExecutingScriptsMap& extension_ids, |
| 154 const ExecutingScriptsMap& extension_ids, | 150 const GURL& on_url) override; |
| 155 const GURL& on_url) override; | |
| 156 | 151 |
| 157 // At the moment, ActivityLog will use only one policy for summarization. | 152 // At the moment, ActivityLog will use only one policy for summarization. |
| 158 // These methods are used to choose and set the most appropriate policy. | 153 // These methods are used to choose and set the most appropriate policy. |
| 159 // Changing policies at runtime is not recommended, and likely only should be | 154 // Changing policies at runtime is not recommended, and likely only should be |
| 160 // done for unit tests. | 155 // done for unit tests. |
| 161 void ChooseDatabasePolicy(); | 156 void ChooseDatabasePolicy(); |
| 162 void SetDatabasePolicy(ActivityLogPolicy::PolicyType policy_type); | 157 void SetDatabasePolicy(ActivityLogPolicy::PolicyType policy_type); |
| 163 | 158 |
| 164 // BrowserContextKeyedAPI implementation. | 159 // BrowserContextKeyedAPI implementation. |
| 165 static const char* service_name() { return "ActivityLog"; } | 160 static const char* service_name() { return "ActivityLog"; } |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 FRIEND_TEST_ALL_PREFIXES(ActivityLogEnabledTest, WatchdogSwitch); | 212 FRIEND_TEST_ALL_PREFIXES(ActivityLogEnabledTest, WatchdogSwitch); |
| 218 DISALLOW_COPY_AND_ASSIGN(ActivityLog); | 213 DISALLOW_COPY_AND_ASSIGN(ActivityLog); |
| 219 }; | 214 }; |
| 220 | 215 |
| 221 template <> | 216 template <> |
| 222 void BrowserContextKeyedAPIFactory<ActivityLog>::DeclareFactoryDependencies(); | 217 void BrowserContextKeyedAPIFactory<ActivityLog>::DeclareFactoryDependencies(); |
| 223 | 218 |
| 224 } // namespace extensions | 219 } // namespace extensions |
| 225 | 220 |
| 226 #endif // CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ | 221 #endif // CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_H_ |
| OLD | NEW |