summaryrefslogtreecommitdiffstats
path: root/components/webdata/encryptor/encryptor.h
diff options
context:
space:
mode:
authorjoi@chromium.org <joi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-03-24 20:57:36 +0000
committerjoi@chromium.org <joi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-03-24 20:57:36 +0000
commitda84fa41175555742aeb4eeffcab85fff8605af2 (patch)
tree5fa476437051157a50163293e365c7fff6972100 /components/webdata/encryptor/encryptor.h
parent69bc58184150e7a08456e5bd21573d8458e538a5 (diff)
downloadchromium_src-da84fa41175555742aeb4eeffcab85fff8605af2.zip
chromium_src-da84fa41175555742aeb4eeffcab85fff8605af2.tar.gz
chromium_src-da84fa41175555742aeb4eeffcab85fff8605af2.tar.bz2
Move Encryptor to //components/webdata/encryptor.
Used by //components/autofill, //chrome/browser and (soon) //components/webdata itself. Looking at [ git blame ], dhollowa@ and thestig@ seemed like the most likely candidates for the OWNERS. Let me know if you disagree. This seems small enough not to warrant a dynamic lib, and it doesn't have any singletons or such that would require it to be one (since it is used by multiple other components in the components build), so I made it a static library. TBR=ben@chromium.org BUG=181277 Review URL: https://codereview.chromium.org/12902030 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@190292 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'components/webdata/encryptor/encryptor.h')
-rw-r--r--components/webdata/encryptor/encryptor.h51
1 files changed, 51 insertions, 0 deletions
diff --git a/components/webdata/encryptor/encryptor.h b/components/webdata/encryptor/encryptor.h
new file mode 100644
index 0000000..94ce108
--- /dev/null
+++ b/components/webdata/encryptor/encryptor.h
@@ -0,0 +1,51 @@
+// Copyright (c) 2010 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.
+
+#ifndef COMPONENTS_WEBDATA_ENCRYPTOR_ENCRYPTOR_H_
+#define COMPONENTS_WEBDATA_ENCRYPTOR_ENCRYPTOR_H_
+
+#include <string>
+
+#include "base/string16.h"
+
+// The Encryptor class gives access to simple encryption and decryption of
+// strings. Note that on Mac, access to the system Keychain is required and
+// these calls can block the current thread to collect user input.
+class Encryptor {
+ public:
+ // Encrypt a string16. The output (second argument) is
+ // really an array of bytes, but we're passing it back
+ // as a std::string
+ static bool EncryptString16(const string16& plaintext,
+ std::string* ciphertext);
+
+ // Decrypt an array of bytes obtained with EncryptString16
+ // back into a string16. Note that the input (first argument)
+ // is a std::string, so you need to first get your (binary)
+ // data into a string.
+ static bool DecryptString16(const std::string& ciphertext,
+ string16* plaintext);
+
+ // Encrypt a string.
+ static bool EncryptString(const std::string& plaintext,
+ std::string* ciphertext);
+
+ // Decrypt an array of bytes obtained with EnctryptString
+ // back into a string. Note that the input (first argument)
+ // is a std::string, so you need to first get your (binary)
+ // data into a string.
+ static bool DecryptString(const std::string& ciphertext,
+ std::string* plaintext);
+
+#if defined(OS_MACOSX)
+ // For unit testing purposes we instruct the Encryptor to use a mock Keychain
+ // on the Mac. The default is to use the real Keychain.
+ static void UseMockKeychain(bool use_mock);
+#endif
+
+ private:
+ DISALLOW_IMPLICIT_CONSTRUCTORS(Encryptor);
+};
+
+#endif // COMPONENTS_WEBDATA_ENCRYPTOR_ENCRYPTOR_H_