Home | History | Annotate | Download | only in history
      1 // Copyright (c) 2013 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 CHROME_BROWSER_HISTORY_DELETE_DIRECTIVE_HANDLER_H_
      6 #define CHROME_BROWSER_HISTORY_DELETE_DIRECTIVE_HANDLER_H_
      7 
      8 #include "base/memory/scoped_ptr.h"
      9 #include "base/memory/weak_ptr.h"
     10 #include "base/threading/thread_checker.h"
     11 #include "chrome/browser/common/cancelable_request.h"
     12 #include "sync/api/sync_change_processor.h"
     13 #include "sync/api/sync_data.h"
     14 
     15 namespace sync_pb {
     16 class HistoryDeleteDirectiveSpecifics;
     17 }
     18 
     19 class HistoryService;
     20 
     21 namespace history {
     22 
     23 // DeleteDirectiveHandler sends delete directives created locally to sync
     24 // engine to propagate to other clients. It also expires local history entries
     25 // according to given delete directives from server.
     26 class DeleteDirectiveHandler {
     27  public:
     28   DeleteDirectiveHandler();
     29   ~DeleteDirectiveHandler();
     30 
     31   // Start/stop processing delete directives when sync is enabled/disabled.
     32   void Start(HistoryService* history_service,
     33              const syncer::SyncDataList& initial_sync_data,
     34              scoped_ptr<syncer::SyncChangeProcessor> sync_processor);
     35   void Stop();
     36 
     37   // Create delete directives for the deletion of visits identified by
     38   // |global_ids| (which may be empty), in the time range specified by
     39   // |begin_time| and |end_time|.
     40   bool CreateDeleteDirectives(
     41       const std::set<int64>& global_ids,
     42       base::Time begin_time,
     43       base::Time end_time);
     44 
     45   // Sends the given |delete_directive| to SyncChangeProcessor (if it exists).
     46   // Returns any error resulting from sending the delete directive to sync.
     47   // NOTE: the given |delete_directive| is not processed to remove local
     48   //       history entries that match. Caller still needs to call other
     49   //       interfaces, e.g. HistoryService::ExpireHistoryBetween(), to delete
     50   //       local history entries.
     51   syncer::SyncError ProcessLocalDeleteDirective(
     52       const sync_pb::HistoryDeleteDirectiveSpecifics& delete_directive);
     53 
     54   // Expires local history entries according to delete directives from server.
     55   syncer::SyncError ProcessSyncChanges(
     56       HistoryService* history_service,
     57       const syncer::SyncChangeList& change_list);
     58 
     59  private:
     60   class DeleteDirectiveTask;
     61   friend class DeleteDirectiveTask;
     62 
     63   // Action to take on processed delete directives.
     64   enum PostProcessingAction {
     65     KEEP_AFTER_PROCESSING,
     66     DROP_AFTER_PROCESSING
     67   };
     68 
     69   // Callback when history backend finishes deleting visits according to
     70   // |delete_directives|.
     71   void FinishProcessing(PostProcessingAction post_processing_action,
     72                         const syncer::SyncDataList& delete_directives);
     73 
     74   CancelableRequestConsumer internal_consumer_;
     75   scoped_ptr<syncer::SyncChangeProcessor> sync_processor_;
     76   base::ThreadChecker thread_checker_;
     77   base::WeakPtrFactory<DeleteDirectiveHandler> weak_ptr_factory_;
     78 
     79   DISALLOW_COPY_AND_ASSIGN(DeleteDirectiveHandler);
     80 };
     81 
     82 }  // namespace history
     83 
     84 #endif  // CHROME_BROWSER_HISTORY_DELETE_DIRECTIVE_HANDLER_H_
     85