| OLD | NEW |
| (Empty) |
| 1 // Copyright 2014 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 COMPONENTS_INVALIDATION_INVALIDATION_H_ | |
| 6 #define COMPONENTS_INVALIDATION_INVALIDATION_H_ | |
| 7 | |
| 8 #include <string> | |
| 9 | |
| 10 #include "base/basictypes.h" | |
| 11 #include "base/memory/scoped_ptr.h" | |
| 12 #include "base/memory/weak_ptr.h" | |
| 13 #include "base/sequenced_task_runner.h" | |
| 14 #include "base/values.h" | |
| 15 #include "components/invalidation/ack_handle.h" | |
| 16 #include "components/invalidation/invalidation_export.h" | |
| 17 #include "google/cacheinvalidation/include/types.h" | |
| 18 | |
| 19 namespace syncer { | |
| 20 | |
| 21 class DroppedInvalidationTracker; | |
| 22 class AckHandler; | |
| 23 | |
| 24 // Represents a local invalidation, and is roughly analogous to | |
| 25 // invalidation::Invalidation. Unlike invalidation::Invalidation, this class | |
| 26 // supports "local" ack-tracking and simple serialization to pref values. | |
| 27 class INVALIDATION_EXPORT Invalidation { | |
| 28 public: | |
| 29 // Factory functions. | |
| 30 static Invalidation Init(const invalidation::ObjectId& id, | |
| 31 int64 version, | |
| 32 const std::string& payload); | |
| 33 static Invalidation InitUnknownVersion(const invalidation::ObjectId& id); | |
| 34 static Invalidation InitFromDroppedInvalidation(const Invalidation& dropped); | |
| 35 static scoped_ptr<Invalidation> InitFromValue( | |
| 36 const base::DictionaryValue& value); | |
| 37 | |
| 38 ~Invalidation(); | |
| 39 | |
| 40 // Compares two invalidations. The comparison ignores ack-tracking state. | |
| 41 bool Equals(const Invalidation& other) const; | |
| 42 | |
| 43 invalidation::ObjectId object_id() const; | |
| 44 bool is_unknown_version() const; | |
| 45 | |
| 46 // Safe to call only if is_unknown_version() returns false. | |
| 47 int64 version() const; | |
| 48 | |
| 49 // Safe to call only if is_unknown_version() returns false. | |
| 50 const std::string& payload() const; | |
| 51 | |
| 52 const AckHandle& ack_handle() const; | |
| 53 | |
| 54 // Sets the AckHandler to be used to track this Invalidation. | |
| 55 // | |
| 56 // This should be set by the class that generates the invalidation. Clients | |
| 57 // of the Invalidations API should not need to call this. | |
| 58 // | |
| 59 // Note that some sources of invalidations do not support ack tracking, and do | |
| 60 // not set the ack_handler. This will be hidden from users of this class. | |
| 61 void SetAckHandler( | |
| 62 base::WeakPtr<AckHandler> handler, | |
| 63 scoped_refptr<base::SequencedTaskRunner> handler_task_runner); | |
| 64 | |
| 65 // Returns whether or not this instance supports ack tracking. This will | |
| 66 // depend on whether or not the source of invaliadations supports | |
| 67 // invalidations. | |
| 68 // | |
| 69 // Clients can safely ignore this flag. They can assume that all | |
| 70 // invalidations support ack tracking. If they're wrong, then invalidations | |
| 71 // will be less reliable, but their behavior will be no less correct. | |
| 72 bool SupportsAcknowledgement() const; | |
| 73 | |
| 74 // Acknowledges the receipt of this invalidation. | |
| 75 // | |
| 76 // Clients should call this on a received invalidation when they have fully | |
| 77 // processed the invalidation and persisted the results to disk. Once this | |
| 78 // function is called, the invalidations system is under no obligation to | |
| 79 // re-deliver this invalidation in the event of a crash or restart. | |
| 80 void Acknowledge() const; | |
| 81 | |
| 82 // Informs the ack tracker that this invalidation will not be serviced. | |
| 83 // | |
| 84 // If a client's buffer reaches its limit and it is forced to start dropping | |
| 85 // invalidations, it should call this function before dropping its | |
| 86 // invalidations in order to allow the ack tracker to drop the invalidation, | |
| 87 // too. | |
| 88 // | |
| 89 // To indicate recovery from a drop event, the client should call | |
| 90 // Acknowledge() on the most recently dropped inavlidation. | |
| 91 void Drop(); | |
| 92 | |
| 93 scoped_ptr<base::DictionaryValue> ToValue() const; | |
| 94 std::string ToString() const; | |
| 95 | |
| 96 private: | |
| 97 Invalidation(const invalidation::ObjectId& id, | |
| 98 bool is_unknown_version, | |
| 99 int64 version, | |
| 100 const std::string& payload, | |
| 101 AckHandle ack_handle); | |
| 102 | |
| 103 // The ObjectId to which this invalidation belongs. | |
| 104 invalidation::ObjectId id_; | |
| 105 | |
| 106 // This flag is set to true if this is an unknown version invalidation. | |
| 107 bool is_unknown_version_; | |
| 108 | |
| 109 // The version number of this invalidation. Should not be accessed if this is | |
| 110 // an unkown version invalidation. | |
| 111 int64 version_; | |
| 112 | |
| 113 // The payaload associated with this invalidation. Should not be accessed if | |
| 114 // this is an unknown version invalidation. | |
| 115 std::string payload_; | |
| 116 | |
| 117 // A locally generated unique ID used to manage local acknowledgements. | |
| 118 AckHandle ack_handle_; | |
| 119 | |
| 120 // The acknowledgement tracking handler and its thread. | |
| 121 base::WeakPtr<AckHandler> ack_handler_; | |
| 122 scoped_refptr<base::SequencedTaskRunner> ack_handler_task_runner_; | |
| 123 }; | |
| 124 | |
| 125 } // namespace syncer | |
| 126 | |
| 127 #endif // COMPONENTS_INVALIDATION_INVALIDATION_H_ | |
| OLD | NEW |