1 // Copyright 2012 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.
5 #ifndef SYNC_INTERNAL_API_PUBLIC_BASE_TRANSACTION_H_
6 #define SYNC_INTERNAL_API_PUBLIC_BASE_TRANSACTION_H_
8 #include "sync/base/sync_export.h"
9 #include "sync/internal_api/public/base/model_type.h"
10 #include "sync/internal_api/public/user_share.h"
11 #include "sync/util/cryptographer.h"
16 class BaseTransaction
;
20 // Sync API's BaseTransaction, ReadTransaction, and WriteTransaction allow for
21 // batching of several read and/or write operations. The read and write
22 // operations are performed by creating ReadNode and WriteNode instances using
23 // the transaction. These transaction classes wrap identically named classes in
24 // syncable, and are used in a similar way. Unlike syncable::BaseTransaction,
25 // whose construction requires an explicit syncable::Directory, a sync
26 // API BaseTransaction is created from a UserShare object.
28 // Note, these transactions are not atomic. Individual operations can
29 // fail. There is no built-in rollback or undo mechanism.
30 class SYNC_EXPORT BaseTransaction
{
32 // Provide access to the underlying syncable objects from BaseNode.
33 virtual syncable::BaseTransaction
* GetWrappedTrans() const = 0;
34 Cryptographer
* GetCryptographer() const;
35 ModelTypeSet
GetEncryptedTypes() const;
37 syncable::Directory
* GetDirectory() const {
41 return user_share_
->directory
.get();
45 UserShare
* GetUserShare() const {
50 explicit BaseTransaction(UserShare
* share
);
51 virtual ~BaseTransaction();
53 BaseTransaction() : user_share_(NULL
) { }
56 UserShare
* user_share_
;
58 DISALLOW_COPY_AND_ASSIGN(BaseTransaction
);
63 #endif // SYNC_INTERNAL_API_PUBLIC_BASE_TRANSACTION_H_