Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1358)

Side by Side Diff: chrome/browser/sync/engine/nigori_util.h

Issue 8468023: Move encryption related files from util folder to encryption folder. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: For review. Created 9 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 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 // Various utility methods for nigori-based multi-type encryption.
6
7 #ifndef CHROME_BROWSER_SYNC_ENGINE_NIGORI_UTIL_H_
8 #define CHROME_BROWSER_SYNC_ENGINE_NIGORI_UTIL_H_
9 #pragma once
10
11 #include "base/compiler_specific.h"
12 #include "chrome/browser/sync/protocol/nigori_specifics.pb.h"
13 #include "chrome/browser/sync/syncable/model_type.h"
14
15 namespace browser_sync {
16 class Cryptographer;
17 }
18
19 namespace sync_pb {
20 class EntitySpecifics;
21 }
22
23 namespace syncable {
24
25 const char kEncryptedString[] = "encrypted";
26
27 class BaseTransaction;
28 class Entry;
29 class ReadTransaction;
30 class WriteTransaction;
31
32 // Check if our unsyced changes are encrypted if they need to be based on
33 // |encrypted_types|.
34 // Returns: true if all unsynced data that should be encrypted is.
35 // false if some unsynced changes need to be encrypted.
36 // This method is similar to ProcessUnsyncedChangesForEncryption but does not
37 // modify the data and does not care if data is unnecessarily encrypted.
38 bool VerifyUnsyncedChangesAreEncrypted(
39 BaseTransaction* const trans,
40 const ModelTypeSet& encrypted_types);
41
42 // Processes all unsynced changes and ensures they are appropriately encrypted
43 // or unencrypted, based on |encrypted_types|.
44 bool ProcessUnsyncedChangesForEncryption(
45 WriteTransaction* const trans,
46 browser_sync::Cryptographer* cryptographer);
47
48 // Returns true if the entry requires encryption but is not encrypted, false
49 // otherwise. Note: this does not check that already encrypted entries are
50 // encrypted with the proper key.
51 bool EntryNeedsEncryption(const ModelTypeSet& encrypted_types,
52 const Entry& entry);
53
54 // Same as EntryNeedsEncryption, but looks at specifics.
55 bool SpecificsNeedsEncryption(const ModelTypeSet& encrypted_types,
56 const sync_pb::EntitySpecifics& specifics);
57
58 // Verifies all data of type |type| is encrypted appropriately.
59 bool VerifyDataTypeEncryptionForTest(
60 BaseTransaction* const trans,
61 browser_sync::Cryptographer* cryptographer,
62 ModelType type,
63 bool is_encrypted) WARN_UNUSED_RESULT;
64
65 } // namespace syncable
66
67 #endif // CHROME_BROWSER_SYNC_ENGINE_NIGORI_UTIL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698