blob: a4bf9ce319d6d0fc92e74182186f610b908e35df [file] [log] [blame]
[email protected]d5793862013-01-24 20:38:171// Copyright 2013 The Chromium Authors. All rights reserved.
[email protected]6add02a2013-01-05 01:15:512// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
[email protected]d5793862013-01-24 20:38:175#ifndef SYNC_SYNCABLE_SYNCABLE_DELETE_JOURNAL_H_
6#define SYNC_SYNCABLE_SYNCABLE_DELETE_JOURNAL_H_
[email protected]6add02a2013-01-05 01:15:517
8#include <set>
9
10#include "base/gtest_prod_util.h"
11#include "base/synchronization/lock.h"
[email protected]8c6b5192013-02-01 01:44:0612#include "sync/base/sync_export.h"
[email protected]6add02a2013-01-05 01:15:5113#include "sync/syncable/metahandle_set.h"
14#include "sync/syncable/syncable-inl.h"
15
16namespace syncer {
17namespace syncable {
18
19class BaseTransaction;
20struct EntryKernel;
21
22typedef std::set<const EntryKernel*, LessField<IdField, ID> > JournalIndex;
23
24// DeleteJournal manages deleted entries that are not in sync directory until
25// it's safe to drop them after the deletion is confirmed with native models.
26// DeleteJournal is thread-safe and can be accessed on any thread. Has to hold
27// a valid transaction object when calling methods of DeleteJournal, thus each
28// method requires a non-null |trans| parameter.
[email protected]8c6b5192013-02-01 01:44:0629class SYNC_EXPORT_PRIVATE DeleteJournal {
[email protected]6add02a2013-01-05 01:15:5130 public:
31 FRIEND_TEST_ALL_PREFIXES(SyncableDirectoryTest, ManageDeleteJournals);
32
33 // Initialize |delete_journals_| using |intitial_journal|, whose content is
34 // destroyed during initialization.
35 explicit DeleteJournal(JournalIndex* initial_journal);
36 ~DeleteJournal();
37
38 // For testing only.
39 size_t GetDeleteJournalSize(BaseTransaction* trans) const;
40
41 // Add/remove |entry| to/from |delete_journals_| according to its
42 // SERVER_IS_DEL field and |was_deleted|. Called on sync thread.
43 void UpdateDeleteJournalForServerDelete(BaseTransaction* trans,
44 bool was_deleted,
45 const EntryKernel& entry);
46
47 // Return entries of specified type in |delete_journals_|. This should be
48 // called ONCE in model association. |deleted_entries| can be used to
49 // detect deleted sync data that's not persisted in native model to
50 // prevent back-from-dead problem. |deleted_entries| are only valid during
51 // lifetime of |trans|. |type| is added to |passive_delete_journal_types_| to
52 // enable periodically saving/clearing of delete journals of |type| because
53 // new journals added later are not needed until next model association.
54 // Can be called on any thread.
55 void GetDeleteJournals(BaseTransaction* trans, ModelType type,
56 EntryKernelSet* deleted_entries);
57
58 // Purge entries of specified type in |delete_journals_| if their handles are
59 // in |to_purge|. This should be called after model association and
60 // |to_purge| should contain handles of the entries whose deletions are
61 // confirmed in native model. Can be called on any thread.
62 void PurgeDeleteJournals(BaseTransaction* trans,
63 const MetahandleSet& to_purge);
64
65 // Move entries in |delete_journals_| whose types are in
66 // |passive_delete_journal_types_| to |journal_entries|. Move handles in
67 // |delete_journals_to_purge_| to |journals_to_purge|. Called on sync thread.
68 void TakeSnapshotAndClear(BaseTransaction* trans,
69 EntryKernelSet* journal_entries,
70 MetahandleSet* journals_to_purge);
71
72 // Add |entries| to |delete_journals_| regardless of their SERVER_IS_DEL
73 // value. This is used to:
74 // * restore delete journals from snapshot if snapshot failed to save.
75 // * batch add entries of a data type with unrecoverable error to delete
76 // journal before purging them.
77 // Called on sync thread.
78 void AddJournalBatch(BaseTransaction* trans, const EntryKernelSet& entries);
79
80 // Return true if delete journals of |type| are maintained.
81 static bool IsDeleteJournalEnabled(ModelType type);
82
83 private:
84 // Contains deleted entries that may not be persisted in native models. And
85 // in case of unrecoverable error, all purged entries are moved here for
86 // bookkeeping to prevent back-from-dead entries that are deleted elsewhere
87 // when sync's down.
88 JournalIndex delete_journals_;
89
90 // Contains meta handles of deleted entries that have been persisted or
91 // undeleted, thus can be removed from database.
92 MetahandleSet delete_journals_to_purge_;
93
94 // Delete journals of these types can be cleared from memory after being
95 // saved to database.
96 ModelTypeSet passive_delete_journal_types_;
97
98 DISALLOW_COPY_AND_ASSIGN(DeleteJournal);
99};
100
101} // namespace syncable
102} // namespace syncer
103
[email protected]d5793862013-01-24 20:38:17104#endif // SYNC_SYNCABLE_SYNCABLE_DELETE_JOURNAL_H_