Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6686)

Unified Diff: chrome/browser/extensions/activity_log/activity_log_policy.h

Issue 21646004: Compressed activity log database storage (Closed) Base URL: http://git.chromium.org/chromium/src.git@refactor-cleanups
Patch Set: Delete a debugging log message Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/activity_log/activity_log_policy.h
diff --git a/chrome/browser/extensions/activity_log/activity_log_policy.h b/chrome/browser/extensions/activity_log/activity_log_policy.h
index e8421dc8819b055b8664356dc0ca9e5ed4d554eb..ebfdf4e033476fc6eca39f3b32dc3b5eebca27a0 100644
--- a/chrome/browser/extensions/activity_log/activity_log_policy.h
+++ b/chrome/browser/extensions/activity_log/activity_log_policy.h
@@ -5,6 +5,7 @@
#ifndef CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_POLICY_H_
#define CHROME_BROWSER_EXTENSIONS_ACTIVITY_LOG_ACTIVITY_LOG_POLICY_H_
+#include <set>
#include <string>
#include "base/bind.h"
@@ -51,23 +52,10 @@ class ActivityLogPolicy {
public:
enum PolicyType {
POLICY_FULLSTREAM,
- POLICY_NOARGS,
+ POLICY_COUNTS,
POLICY_INVALID,
};
- // For all subclasses, add all the key types they might support here.
- // The actual key is returned by calling GetKey(KeyType). The subclasses
- // are free to return an empty string for keys they don't support.
- // For every key added here, you should update the GetKey member function
- // for at least one policy.
- enum KeyType {
- PARAM_KEY_REASON, // Why an action was blocked
- PARAM_KEY_DOM_ACTION, // Getter, Setter, Method,...
- PARAM_KEY_URL_TITLE,
- PARAM_KEY_DETAILS_STRING,
- PARAM_KEY_EXTRA,
- };
-
// Parameters are the profile and the thread that will be used to execute
// the callback when ReadData is called.
// TODO(felt,dbabic) Since only ReadData uses thread_id, it would be
@@ -99,10 +87,52 @@ class ActivityLogPolicy {
const base::Callback
<void(scoped_ptr<Action::ActionVector>)>& callback) = 0;
- virtual std::string GetKey(KeyType key_id) const;
-
// For unit testing only.
- void SetClockForTesting(base::Clock* clock) { testing_clock_ = clock; }
+ void SetClockForTesting(scoped_ptr<base::Clock> clock);
+
+ // A collection of methods that are useful for implementing policies. These
+ // are all static methods; the ActivityLogPolicy::Util class cannot be
+ // instantiated. This is nested within ActivityLogPolicy to make calling
+ // these methods more convenient from within a policy, but they are public.
+ class Util {
+ public:
+ // Serialize a Value as a JSON string. Returns an empty string if value is
+ // null.
+ static std::string Serialize(const base::Value* value);
+
+ // Removes potentially privacy-sensitive data that should not be logged.
+ // This should generally be called on an Action before logging, unless
+ // debugging flags are enabled. Modifies the Action object in place; if
+ // the action might be shared with other users, it is up to the caller to
+ // call ->Clone() first.
+ static void StripPrivacySensitiveFields(scoped_refptr<Action> action);
+
+ // Strip arguments from most API actions, preserving actions only for a
+ // whitelisted set. Modifies the Action object in-place.
+ static void StripArguments(const std::set<std::string>& api_whitelist,
+ scoped_refptr<Action> action);
+
+ // Given a base day (timestamp at local midnight), computes the timestamp
+ // at midnight the given number of days before or after.
+ static base::Time AddDays(const base::Time& base_date, int days);
+
+ // Compute the time bounds that should be used for a database query to
+ // cover a time range days_ago days in the past, relative to the specified
+ // time.
+ static void ComputeDatabaseTimeBounds(const base::Time& now,
+ int days_ago,
+ int64* early_bound,
+ int64* late_bound);
+
+ // Deletes obsolete database tables from an activity log database. This
+ // can be used in InitDatabase() methods of ActivityLogDatabasePolicy
+ // subclasses to clean up data from old versions of the activity logging
+ // code. Returns true on success, false on database error.
+ static bool DropObsoleteTables(sql::Connection* db);
+
+ private:
+ DISALLOW_IMPLICIT_CONSTRUCTORS(Util);
+ };
protected:
// An ActivityLogPolicy is not directly destroyed. Instead, call Close()
@@ -118,7 +148,7 @@ class ActivityLogPolicy {
// Support for a mock clock for testing purposes. This is used by ReadData
// to determine the date for "today" when when interpreting date ranges to
// fetch. This has no effect on batching of writes to the database.
- base::Clock* testing_clock_;
+ scoped_ptr<base::Clock> testing_clock_;
DISALLOW_COPY_AND_ASSIGN(ActivityLogPolicy);
};
« no previous file with comments | « chrome/browser/extensions/activity_log/activity_log.cc ('k') | chrome/browser/extensions/activity_log/activity_log_policy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698