// Copyright (c) 2009 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 CHROME_BROWSER_BROWSING_DATA_REMOVER_H_ #define CHROME_BROWSER_BROWSING_DATA_REMOVER_H_ #include "base/observer_list.h" #include "base/scoped_ptr.h" #include "base/time.h" #include "chrome/browser/cancelable_request.h" #include "chrome/common/notification_registrar.h" #include "webkit/database/database_tracker.h" class Profile; class URLRequestContextGetter; // BrowsingDataRemover is responsible for removing data related to browsing: // visits in url database, downloads, cookies ... class BrowsingDataRemover : public NotificationObserver { public: // Time period ranges available when doing browsing data removals. enum TimePeriod { LAST_HOUR = 0, LAST_DAY, LAST_WEEK, FOUR_WEEKS, EVERYTHING }; // Mask used for Remove. // In addition to visits, this removes keywords and the last session. static const int REMOVE_HISTORY = 1 << 0; static const int REMOVE_DOWNLOADS = 1 << 1; static const int REMOVE_COOKIES = 1 << 2; static const int REMOVE_PASSWORDS = 1 << 3; static const int REMOVE_FORM_DATA = 1 << 4; static const int REMOVE_CACHE = 1 << 5; // Observer is notified when the removal is done. Done means keywords have // been deleted, cache cleared and all other tasks scheduled. class Observer { public: virtual void OnBrowsingDataRemoverDone() = 0; protected: virtual ~Observer() {} }; // Creates a BrowsingDataRemover to remove browser data from the specified // profile in the specified time range. Use Remove to initiate the removal. BrowsingDataRemover(Profile* profile, base::Time delete_begin, base::Time delete_end); // Creates a BrowsingDataRemover to remove browser data from the specified // profile in the specified time range. BrowsingDataRemover(Profile* profile, TimePeriod time_period, base::Time delete_end); // Removes the specified items related to browsing. void Remove(int remove_mask); void AddObserver(Observer* observer); void RemoveObserver(Observer* observer); // Called when history deletion is done. void OnHistoryDeletionDone(); static bool is_removing() { return removing_; } private: // BrowsingDataRemover deletes itself (using DeleteTask) and is not supposed // to be deleted by other objects so make destructor private and DeleteTask // a friend. friend class DeleteTask; ~BrowsingDataRemover(); // NotificationObserver method. Callback when TemplateURLModel has finished // loading. Deletes the entries from the model, and if we're not waiting on // anything else notifies observers and deletes this BrowsingDataRemover. void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); // If we're not waiting on anything, notifies observers and deletes this // object. void NotifyAndDeleteIfDone(); // Callback when the cache has been deleted. Invokes NotifyAndDeleteIfDone. void ClearedCache(); // Invoked on the IO thread to delete from the cache. void ClearCacheOnIOThread(URLRequestContextGetter* main_context_getter, URLRequestContextGetter* media_context_getter, base::Time delete_begin, base::Time delete_end); // Callback when HTML5 databases have been deleted. Invokes // NotifyAndDeleteIfDone. void OnClearedDatabases(int rv); // Invoked on the FILE thread to delete HTML5 databases. void ClearDatabasesOnFILEThread(base::Time delete_begin); // Calculate the begin time for the deletion range specified by |time_period|. base::Time CalculateBeginDeleteTime(TimePeriod time_period); // Returns true if we're all done. bool all_done() { return registrar_.IsEmpty() && !waiting_for_clear_cache_ && !waiting_for_clear_history_ && !waiting_for_clear_databases_; } NotificationRegistrar registrar_; // Profile we're to remove from. Profile* profile_; // Start time to delete from. const base::Time delete_begin_; // End time to delete to. const base::Time delete_end_; // True if Remove has been invoked. static bool removing_; // Reference to database tracker held while deleting databases. scoped_refptr database_tracker_; net::CompletionCallbackImpl database_cleared_callback_; // True if we're waiting for HTML5 databases to be deleted. bool waiting_for_clear_databases_; // True if we're waiting for the history to be deleted. bool waiting_for_clear_history_; // True if we're waiting for the cache to be cleared. bool waiting_for_clear_cache_; ObserverList observer_list_; // Used if we need to clear history. CancelableRequestConsumer request_consumer_; DISALLOW_COPY_AND_ASSIGN(BrowsingDataRemover); }; #endif // CHROME_BROWSER_BROWSING_DATA_REMOVER_H_