Home | History | Annotate | Download | only in password_manager
      1 // Copyright (c) 2006-2008 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 #include "chrome/browser/password_manager/encryptor.h"
      6 
      7 #include <windows.h>
      8 #include <wincrypt.h>
      9 #include "base/utf_string_conversions.h"
     10 
     11 #pragma comment(lib, "crypt32.lib")
     12 
     13 bool Encryptor::EncryptString16(const string16& plaintext,
     14                                 std::string* ciphertext) {
     15   return EncryptString(UTF16ToUTF8(plaintext), ciphertext);
     16 }
     17 
     18 bool Encryptor::DecryptString16(const std::string& ciphertext,
     19                                 string16* plaintext) {
     20   std::string utf8;
     21   if (!DecryptString(ciphertext, &utf8))
     22     return false;
     23 
     24   *plaintext = UTF8ToUTF16(utf8);
     25   return true;
     26 }
     27 
     28 bool Encryptor::EncryptString(const std::string& plaintext,
     29                               std::string* ciphertext) {
     30   DATA_BLOB input;
     31   input.pbData = const_cast<BYTE*>(
     32       reinterpret_cast<const BYTE*>(plaintext.data()));
     33   input.cbData = static_cast<DWORD>(plaintext.length());
     34 
     35   DATA_BLOB output;
     36   BOOL result = CryptProtectData(&input, L"", NULL, NULL, NULL,
     37                                  0, &output);
     38   if (!result)
     39     return false;
     40 
     41   // this does a copy
     42   ciphertext->assign(reinterpret_cast<std::string::value_type*>(output.pbData),
     43                      output.cbData);
     44 
     45   LocalFree(output.pbData);
     46   return true;
     47 }
     48 
     49 bool Encryptor::DecryptString(const std::string& ciphertext,
     50                               std::string* plaintext) {
     51   DATA_BLOB input;
     52   input.pbData = const_cast<BYTE*>(
     53       reinterpret_cast<const BYTE*>(ciphertext.data()));
     54   input.cbData = static_cast<DWORD>(ciphertext.length());
     55 
     56   DATA_BLOB output;
     57   BOOL result = CryptUnprotectData(&input, NULL, NULL, NULL, NULL,
     58                                    0, &output);
     59   if (!result)
     60     return false;
     61 
     62   plaintext->assign(reinterpret_cast<char*>(output.pbData), output.cbData);
     63   LocalFree(output.pbData);
     64   return true;
     65 }
     66