• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 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 SYNC_NOTIFIER_DROPPED_INVALIDATION_TRACKER_H_
6 #define SYNC_NOTIFIER_DROPPED_INVALIDATION_TRACKER_H_
7 
8 #include "google/cacheinvalidation/include/types.h"
9 #include "sync/base/sync_export.h"
10 #include "sync/internal_api/public/base/ack_handle.h"
11 #include "sync/internal_api/public/util/weak_handle.h"
12 #include "sync/notifier/ack_handler.h"
13 
14 namespace syncer {
15 
16 class Invalidation;
17 
18 // Helps InvalidationHandlers keep track of dropped invalidations for a given
19 // ObjectId.
20 //
21 // The intent of this class is to hide some of the implementation details around
22 // how the invalidations system manages dropping and drop recovery.  Any
23 // invalidation handler that intends to buffer and occasionally drop
24 // invalidations should keep one instance of it per registered ObjectId.
25 //
26 // When an invalidation handler wishes to drop an invalidation, it must provide
27 // an instance of this class to that Invalidation's Drop() method.  In order to
28 // indicate recovery from a drop, the handler can call this class'
29 // RecordRecoveryFromDropEvent().
30 class SYNC_EXPORT DroppedInvalidationTracker {
31  public:
32   explicit DroppedInvalidationTracker(const invalidation::ObjectId& id);
33   ~DroppedInvalidationTracker();
34 
35   const invalidation::ObjectId& object_id() const;
36 
37   // Called by Invalidation::Drop() to keep track of a drop event.
38   //
39   // Takes ownership of the internals belonging to a soon to be discarded
40   // dropped invalidation.  See also the comment for this class'
41   // |drop_ack_handler_| member.
42   void RecordDropEvent(WeakHandle<AckHandler> handler, AckHandle handle);
43 
44   // Returns true if we're still recovering from a drop event.
45   bool IsRecoveringFromDropEvent() const;
46 
47   // Called by the InvalidationHandler when it recovers from the drop event.
48   void RecordRecoveryFromDropEvent();
49 
50  private:
51   invalidation::ObjectId id_;
52   AckHandle drop_ack_handle_;
53 
54   // A WeakHandle to the enitity responsible for persisting invalidation
55   // acknowledgement state on disk.  We can get away with using a WeakHandle
56   // because we don't care if our drop recovery message doesn't gets delivered
57   // in some shutdown cases.  If that happens, we'll have to process the
58   // invalidation state again on the next restart.  It would be a waste of time
59   // and resources, but otherwise not particularly harmful.
60   WeakHandle<AckHandler> drop_ack_handler_;
61 
62   DISALLOW_COPY_AND_ASSIGN(DroppedInvalidationTracker);
63 };
64 
65 }  // namespace syncer
66 
67 #endif  // SYNC_NOTIFIER_DROPPED_INVALIDATION_TRACKER_H_
68