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

Unified Diff: chrome/browser/sync/util/data_encryption.cc

Issue 194065: Initial commit of sync engine code to browser/sync.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Fixes to gtest include path, reverted syncapi. Created 11 years, 3 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/sync/util/data_encryption.cc
===================================================================
--- chrome/browser/sync/util/data_encryption.cc (revision 0)
+++ chrome/browser/sync/util/data_encryption.cc (revision 0)
@@ -0,0 +1,51 @@
+// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+//
+// NOTE: this file is Winodws specific.
+
+#include "chrome/browser/sync/util/data_encryption.h"
+
+#include <windows.h>
+#include <wincrypt.h>
+
+#include <cstddef>
+#include <string>
+#include <vector>
+
+using std::string;
+using std::vector;
+
+vector<uint8> EncryptData(const string& data) {
+ DATA_BLOB unencrypted_data, encrypted_data;
+ unencrypted_data.pbData = (BYTE*)(data.data());
+ unencrypted_data.cbData = data.size();
+
+ if (!CryptProtectData(&unencrypted_data, L"", NULL, NULL, NULL, 0,
+ &encrypted_data))
+ LOG(ERROR) << "Encryption fails: " << data;
+
+ vector<uint8> result(encrypted_data.pbData,
+ encrypted_data.pbData + encrypted_data.cbData);
+ LocalFree(encrypted_data.pbData);
+ return result;
+}
+
+bool DecryptData(const vector<uint8>& in_data, string* out_data) {
+ DATA_BLOB encrypted_data, decrypted_data;
+ encrypted_data.pbData =
+ (in_data.empty() ? NULL : const_cast<BYTE*>(&in_data[0]));
+ encrypted_data.cbData = in_data.size();
+ LPWSTR descrip = L"";
+
+ if (!CryptUnprotectData(&encrypted_data, &descrip, NULL, NULL, NULL, 0,
+ &decrypted_data)) {
+ LOG(ERROR) << "Decryption fails: ";
+ return false;
+ } else {
+ out_data->assign(reinterpret_cast<const char*>(decrypted_data.pbData),
+ decrypted_data.cbData);
+ LocalFree(decrypted_data.pbData);
+ return true;
+ }
+}
Property changes on: chrome\browser\sync\util\data_encryption.cc
___________________________________________________________________
Added: svn:eol-style
+ LF

Powered by Google App Engine
This is Rietveld 408576698