summaryrefslogtreecommitdiffstats
path: root/chrome/utility
diff options
context:
space:
mode:
authordavidben@chromium.org <davidben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-06 20:48:43 +0000
committerdavidben@chromium.org <davidben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-06 20:48:43 +0000
commit7e03b959542582d8e6664670bd3194b77418d6a0 (patch)
tree5c5c8168d2b4809707d96b8e33fa7e78ad12c584 /chrome/utility
parent4237bc177e77a9f2408758d6677ea1d9b420ed26 (diff)
downloadchromium_src-7e03b959542582d8e6664670bd3194b77418d6a0.zip
chromium_src-7e03b959542582d8e6664670bd3194b77418d6a0.tar.gz
chromium_src-7e03b959542582d8e6664670bd3194b77418d6a0.tar.bz2
Fix various bits of error-handling in NSSDecryptor.
String may be empty. Base64-decode may fail. BUG=none Review URL: https://codereview.chromium.org/427303004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@287851 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/utility')
-rw-r--r--chrome/utility/importer/firefox_importer_unittest.cc6
-rw-r--r--chrome/utility/importer/nss_decryptor.cc9
2 files changed, 13 insertions, 2 deletions
diff --git a/chrome/utility/importer/firefox_importer_unittest.cc b/chrome/utility/importer/firefox_importer_unittest.cc
index 0ad20e1..48154db 100644
--- a/chrome/utility/importer/firefox_importer_unittest.cc
+++ b/chrome/utility/importer/firefox_importer_unittest.cc
@@ -45,6 +45,12 @@ TEST(FirefoxImporterTest, MAYBE_NSS(Firefox3NSS3Decryptor)) {
EXPECT_EQ(base::WideToUTF16(L"\x4E2D"),
decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECLW"
"qqiccfQHWBAie74hxnULxlw=="));
+
+ // Test empty string edge case.
+ EXPECT_EQ(base::string16(), decryptor_proxy.Decrypt(std::string()));
+
+ // Test invalid base64.
+ EXPECT_EQ(base::string16(), decryptor_proxy.Decrypt("Not! Valid! Base64!"));
}
// The following test verifies proper detection of authentication scheme in
diff --git a/chrome/utility/importer/nss_decryptor.cc b/chrome/utility/importer/nss_decryptor.cc
index 77a10a0..656b73f 100644
--- a/chrome/utility/importer/nss_decryptor.cc
+++ b/chrome/utility/importer/nss_decryptor.cc
@@ -66,12 +66,16 @@ base::string16 NSSDecryptor::Decrypt(const std::string& crypt) const {
if (!is_nss_initialized_)
return base::string16();
+ if (crypt.empty())
+ return base::string16();
+
// The old style password is encoded in base64. They are identified
// by a leading '~'. Otherwise, we should decrypt the text.
std::string plain;
if (crypt[0] != '~') {
std::string decoded_data;
- base::Base64Decode(crypt, &decoded_data);
+ if (!base::Base64Decode(crypt, &decoded_data))
+ return base::string16();
PK11SlotInfo* slot = GetKeySlotForDB();
SECStatus result = PK11_Authenticate(slot, PR_TRUE, NULL);
if (result != SECSuccess) {
@@ -98,7 +102,8 @@ base::string16 NSSDecryptor::Decrypt(const std::string& crypt) const {
FreeSlot(slot);
} else {
// Deletes the leading '~' before decoding.
- base::Base64Decode(crypt.substr(1), &plain);
+ if (!base::Base64Decode(crypt.substr(1), &plain))
+ return base::string16();
}
return base::UTF8ToUTF16(plain);