diff options
Diffstat (limited to 'chrome/browser/webdata')
-rw-r--r-- | chrome/browser/webdata/web_data_service.h | 12 | ||||
-rw-r--r-- | chrome/browser/webdata/web_database.cc | 105 | ||||
-rw-r--r-- | chrome/browser/webdata/web_database.h | 18 | ||||
-rw-r--r-- | chrome/browser/webdata/web_database_unittest.cc | 96 | ||||
-rw-r--r-- | chrome/browser/webdata/web_database_win.cc | 72 |
5 files changed, 139 insertions, 164 deletions
diff --git a/chrome/browser/webdata/web_data_service.h b/chrome/browser/webdata/web_data_service.h index 3002140..053644b 100644 --- a/chrome/browser/webdata/web_data_service.h +++ b/chrome/browser/webdata/web_data_service.h @@ -5,6 +5,8 @@ #ifndef CHROME_BROWSER_WEBDATA_WEB_DATA_SERVICE_H__ #define CHROME_BROWSER_WEBDATA_WEB_DATA_SERVICE_H__ +#include <map> + #include "base/basictypes.h" #include "base/lock.h" #include "base/message_loop.h" @@ -12,12 +14,10 @@ #include "base/thread.h" #include "chrome/browser/webdata/web_database.h" #include "chrome/common/scoped_vector.h" -#include <map> +#include "webkit/glue/autofill_form.h" -struct AutofillForm::Element; struct IE7PasswordInfo; struct PasswordForm; -class AutofillForm; class GURL; class ShutdownTask; class TemplateURL; @@ -383,7 +383,7 @@ class WebDataService : public base::RefCountedThreadSafe<WebDataService> { friend class WebDataRequest; // This is invoked by the unit test; path is the path of the Web Data file. - bool WebDataService::InitWithPath(const std::wstring& path); + bool InitWithPath(const std::wstring& path); // Invoked by request implementations when a request has been processed. void RequestCompleted(Handle h); @@ -400,13 +400,13 @@ class WebDataService : public base::RefCountedThreadSafe<WebDataService> { friend class ShutdownTask; typedef GenericRequest2<std::vector<const TemplateURL*>, - std::vector<TemplateURL*>> SetKeywordsRequest; + std::vector<TemplateURL*> > SetKeywordsRequest; // Initialize the database with the provided path. void InitializeDatabase(const std::wstring& path); // Commit any pending transaction and deletes the database. - void WebDataService::ShutdownDatabase(); + void ShutdownDatabase(); // Commit the current transaction and creates a new one. void Commit(); diff --git a/chrome/browser/webdata/web_database.cc b/chrome/browser/webdata/web_database.cc index f17efd1..ced6eb8 100644 --- a/chrome/browser/webdata/web_database.cc +++ b/chrome/browser/webdata/web_database.cc @@ -2,19 +2,18 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. +#include "chrome/browser/webdata/web_database.h" + #include <algorithm> #include <limits> #include <vector> -#include "chrome/browser/webdata/web_database.h" - #include "base/gfx/png_decoder.h" #include "base/gfx/png_encoder.h" #include "base/string_util.h" #include "base/time.h" #include "base/values.h" #include "chrome/browser/history/history_database.h" -#include "chrome/browser/ie7_password.h" #include "chrome/browser/template_url.h" #include "chrome/browser/encryptor.h" #include "chrome/common/l10n_util.h" @@ -542,7 +541,7 @@ bool WebDatabase::GetKeywords(std::vector<TemplateURL*>* urls) { s.column_string16(3, &tmp); if (!tmp.empty()) - template_url->SetFavIconURL(GURL(tmp)); + template_url->SetFavIconURL(GURL(WideToUTF8(tmp))); s.column_string16(4, &tmp); template_url->SetURL(tmp, 0, 0); @@ -551,7 +550,7 @@ bool WebDatabase::GetKeywords(std::vector<TemplateURL*>* urls) { s.column_string16(6, &tmp); if (!tmp.empty()) - template_url->set_originating_url(GURL(tmp)); + template_url->set_originating_url(GURL(WideToUTF8(tmp))); template_url->set_date_created(Time::FromTimeT(s.column_int64(7))); @@ -614,40 +613,6 @@ int WebDatabase::GetBuitinKeywordVersion() { return version; } -// Return a new GURL like url, but without any "#foo" bit on the end. -static GURL GURLWithoutRef(const GURL& url) { - url_canon::Replacements<char> replacements; - replacements.ClearRef(); - return url.ReplaceComponents(replacements); -} - -// Convert a list of GUIDs from the in-memory form to the form we keep in -// the database (tab-separated string). -static std::string SerializeGUIDs(const std::vector<std::string>& guids) { - std::string result; - for (size_t i = 0; i < guids.size(); ++i) { - if (!result.empty()) - result.push_back('\t'); - const std::string& guid = guids[i]; - for (size_t j = 0; j < guid.size(); ++j) { - char ch = guid[j]; - // If we have any embedded tabs in the GUID (a pathological case), - // we normalize them to spaces. - if (ch == '\t') - ch = ' '; - result.push_back(ch); - } - } - return result; -} - -// The partner of SerializeGUIDs. Converts a serialized GUIDs string -// back to a vector. -static void DeserializeGUIDs(const std::string& str, - std::vector<std::string>* guids) { - SplitString(str, '\t', guids); -} - bool WebDatabase::AddLogin(const PasswordForm& form) { SQLStatement s; std::string encrypted_password; @@ -684,27 +649,6 @@ bool WebDatabase::AddLogin(const PasswordForm& form) { return true; } -bool WebDatabase::AddIE7Login(const IE7PasswordInfo& info) { - SQLStatement s; - if (s.prepare(db_, - "INSERT OR REPLACE INTO ie7_logins " - "(url_hash, password_value, date_created) " - "VALUES (?, ?, ?)") != SQLITE_OK) { - NOTREACHED() << "Statement prepare failed"; - return false; - } - - s.bind_wstring(0, info.url_hash); - s.bind_blob(1, &info.encrypted_data.front(), - static_cast<int>(info.encrypted_data.size())); - s.bind_int64(2, info.date_created.ToTimeT()); - if (s.step() != SQLITE_DONE) { - NOTREACHED(); - return false; - } - return true; -} - bool WebDatabase::UpdateLogin(const PasswordForm& form) { SQLStatement s; std::string encrypted_password; @@ -769,24 +713,6 @@ bool WebDatabase::RemoveLogin(const PasswordForm& form) { return true; } -bool WebDatabase::RemoveIE7Login(const IE7PasswordInfo& info) { - SQLStatement s; - // Remove a login by UNIQUE-constrained fields. - if (s.prepare(db_, - "DELETE FROM ie7_logins WHERE " - "url_hash = ?") != SQLITE_OK) { - NOTREACHED() << "Statement prepare failed"; - return false; - } - s.bind_wstring(0, info.url_hash); - - if (s.step() != SQLITE_DONE) { - NOTREACHED(); - return false; - } - return true; -} - bool WebDatabase::RemoveLoginsCreatedBetween(const Time delete_begin, const Time delete_end) { SQLStatement s1; @@ -871,29 +797,6 @@ bool WebDatabase::GetLogins(const PasswordForm& form, return result == SQLITE_DONE; } -bool WebDatabase::GetIE7Login(const IE7PasswordInfo& info, - IE7PasswordInfo* result) { - DCHECK(result); - SQLStatement s; - if (s.prepare(db_, - "SELECT password_value, date_created FROM ie7_logins " - "WHERE url_hash == ? ") != SQLITE_OK) { - NOTREACHED() << "Statement prepare failed"; - return false; - } - - s.bind_wstring(0, info.url_hash); - - int64 query_result = s.step(); - if (query_result == SQLITE_ROW) { - s.column_blob_as_vector(0, &result->encrypted_data); - result->date_created = Time::FromTimeT(s.column_int64(1)); - result->url_hash = info.url_hash; - s.step(); - } - return query_result == SQLITE_DONE; -} - bool WebDatabase::GetAllLogins(std::vector<PasswordForm*>* forms, bool include_blacklisted) { DCHECK(forms); diff --git a/chrome/browser/webdata/web_database.h b/chrome/browser/webdata/web_database.h index 4e47168..19059ee 100644 --- a/chrome/browser/webdata/web_database.h +++ b/chrome/browser/webdata/web_database.h @@ -19,7 +19,9 @@ namespace base { class Time; } struct PasswordForm; +#if defined(OS_WIN) struct IE7PasswordInfo; +#endif //////////////////////////////////////////////////////////////////////////////// // @@ -79,18 +81,23 @@ class WebDatabase { // Adds |form| to the list of remembered password forms. bool AddLogin(const PasswordForm& form); +#if defined(OS_WIN) // Adds |info| to the list of imported passwords from ie7/ie8. bool AddIE7Login(const IE7PasswordInfo& info); + // Removes |info| from the list of imported passwords from ie7/ie8. + bool RemoveIE7Login(const IE7PasswordInfo& info); + + // Return the ie7/ie8 login matching |info|. + bool GetIE7Login(const IE7PasswordInfo& info, IE7PasswordInfo* result); +#endif + // Updates remembered password form. bool UpdateLogin(const PasswordForm& form); // Removes |form| from the list of remembered password forms. bool RemoveLogin(const PasswordForm& form); - // Removes |info| from the list of imported passwords from ie7/ie8. - bool RemoveIE7Login(const IE7PasswordInfo& info); - // Removes all logins created from |delete_begin| onwards (inclusive) and // before |delete_end|. You may use a null Time value to do an unbounded // delete in either direction. @@ -102,9 +109,6 @@ class WebDatabase { // including blacklisted matches. bool GetLogins(const PasswordForm& form, std::vector<PasswordForm*>* forms); - // Return the ie7/ie8 login matching |info|. - bool GetIE7Login(const IE7PasswordInfo& info, IE7PasswordInfo* result); - // Loads the complete list of password forms into the specified vector |forms| // if include_blacklisted is true, otherwise only loads those which are // actually autofillable; i.e haven't been blacklisted by the user selecting @@ -205,7 +209,7 @@ class WebDatabase { int transaction_nesting_; MetaTableHelper meta_table_; - DISALLOW_EVIL_CONSTRUCTORS(WebDatabase); + DISALLOW_COPY_AND_ASSIGN(WebDatabase); }; #endif // CHROME_BROWSER_WEBDATA_WEB_DATABASE_H__ diff --git a/chrome/browser/webdata/web_database_unittest.cc b/chrome/browser/webdata/web_database_unittest.cc index 1fe4ce4..349b803 100644 --- a/chrome/browser/webdata/web_database_unittest.cc +++ b/chrome/browser/webdata/web_database_unittest.cc @@ -2,11 +2,10 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include <windows.h> - #include "base/file_util.h" #include "base/path_service.h" #include "base/string_util.h" +#include "base/time.h" #include "base/values.h" #include "chrome/browser/template_url.h" #include "chrome/browser/webdata/web_database.h" @@ -24,19 +23,16 @@ class WebDatabaseTest : public testing::Test { protected: virtual void SetUp() { - wchar_t b[32]; - _itow_s(static_cast<int>(GetTickCount()), b, arraysize(b), 10); - PathService::Get(chrome::DIR_TEST_DATA, &file_); file_ += FilePath::kSeparators[0]; file_ += L"TestWebDatabase"; - file_ += b; + file_ += Int64ToWString(base::Time::Now().ToInternalValue()); file_ += L".db"; - DeleteFile(file_.c_str()); + file_util::Delete(file_, false); } virtual void TearDown() { - DeleteFile(file_.c_str()); + file_util::Delete(file_, false); } static int GetKeyCount(const DictionaryValue& d) { @@ -111,7 +107,7 @@ TEST_F(WebDatabaseTest, Keywords) { std::vector<TemplateURL*> template_urls; EXPECT_TRUE(db.GetKeywords(&template_urls)); - EXPECT_EQ(1, template_urls.size()); + EXPECT_EQ(1U, template_urls.size()); const TemplateURL* restored_url = template_urls.front(); EXPECT_EQ(template_url.short_name(), restored_url->short_name()); @@ -132,7 +128,7 @@ TEST_F(WebDatabaseTest, Keywords) { EXPECT_EQ(32, restored_url->usage_count()); - ASSERT_EQ(1, restored_url->input_encodings().size()); + ASSERT_EQ(1U, restored_url->input_encodings().size()); EXPECT_EQ("UTF-8", restored_url->input_encodings()[0]); EXPECT_EQ(10, restored_url->prepopulate_id()); @@ -142,7 +138,7 @@ TEST_F(WebDatabaseTest, Keywords) { template_urls.clear(); EXPECT_TRUE(db.GetKeywords(&template_urls)); - EXPECT_EQ(0, template_urls.size()); + EXPECT_EQ(0U, template_urls.size()); delete restored_url; } @@ -192,7 +188,7 @@ TEST_F(WebDatabaseTest, UpdateKeyword) { std::vector<TemplateURL*> template_urls; EXPECT_TRUE(db.GetKeywords(&template_urls)); - EXPECT_EQ(1, template_urls.size()); + EXPECT_EQ(1U, template_urls.size()); const TemplateURL* restored_url = template_urls.front(); EXPECT_EQ(template_url.short_name(), restored_url->short_name()); @@ -211,7 +207,7 @@ TEST_F(WebDatabaseTest, UpdateKeyword) { EXPECT_TRUE(originating_url2 == restored_url->originating_url()); - ASSERT_EQ(1, restored_url->input_encodings().size()); + ASSERT_EQ(1U, restored_url->input_encodings().size()); ASSERT_EQ("Shift_JIS", restored_url->input_encodings()[0]); EXPECT_EQ(template_url.suggestions_url()->url(), @@ -240,7 +236,7 @@ TEST_F(WebDatabaseTest, KeywordWithNoFavicon) { std::vector<TemplateURL*> template_urls; EXPECT_TRUE(db.GetKeywords(&template_urls)); - EXPECT_EQ(1, template_urls.size()); + EXPECT_EQ(1U, template_urls.size()); const TemplateURL* restored_url = template_urls.front(); EXPECT_EQ(template_url.short_name(), restored_url->short_name()); @@ -260,12 +256,12 @@ TEST_F(WebDatabaseTest, Logins) { // Verify the database is empty. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); // Example password form. PasswordForm form; - form.origin = GURL(L"http://www.google.com/accounts/LoginAuth"); - form.action = GURL(L"http://www.google.com/accounts/Login"); + form.origin = GURL("http://www.google.com/accounts/LoginAuth"); + form.action = GURL("http://www.google.com/accounts/Login"); form.username_element = L"Email"; form.username_value = L"test@gmail.com"; form.password_element = L"Passwd"; @@ -279,34 +275,34 @@ TEST_F(WebDatabaseTest, Logins) { // Add it and make sure it is there. EXPECT_TRUE(db.AddLogin(form)); EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // Match against an exact copy. EXPECT_TRUE(db.GetLogins(form, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // The example site changes... PasswordForm form2(form); - form2.origin = GURL(L"http://www.google.com/new/accounts/LoginAuth"); + form2.origin = GURL("http://www.google.com/new/accounts/LoginAuth"); form2.submit_element = L"reallySignIn"; // Match against an inexact copy EXPECT_TRUE(db.GetLogins(form2, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // Uh oh, the site changed origin & action URL's all at once! PasswordForm form3(form2); - form3.action = GURL(L"http://www.google.com/new/accounts/Login"); + form3.action = GURL("http://www.google.com/new/accounts/Login"); // signon_realm is the same, should match. EXPECT_TRUE(db.GetLogins(form3, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); @@ -317,32 +313,32 @@ TEST_F(WebDatabaseTest, Logins) { // We have only an http record, so no match for this. EXPECT_TRUE(db.GetLogins(form4, &result)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); // Let's imagine the user logs into the secure site. EXPECT_TRUE(db.AddLogin(form4)); EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(2, result.size()); + EXPECT_EQ(2U, result.size()); delete result[0]; delete result[1]; result.clear(); // Now the match works EXPECT_TRUE(db.GetLogins(form4, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // The user chose to forget the original but not the new. EXPECT_TRUE(db.RemoveLogin(form)); EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // The old form wont match the new site (http vs https). EXPECT_TRUE(db.GetLogins(form, &result)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); // The user's request for the HTTPS site is intercepted // by an attacker who presents an invalid SSL cert. @@ -351,7 +347,7 @@ TEST_F(WebDatabaseTest, Logins) { // It will match in this case. EXPECT_TRUE(db.GetLogins(form5, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); @@ -365,12 +361,12 @@ TEST_F(WebDatabaseTest, Logins) { EXPECT_TRUE(db.UpdateLogin(form6)); // matches EXPECT_TRUE(db.GetLogins(form5, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); delete result[0]; result.clear(); // Only one record. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); // password element was updated. EXPECT_EQ(form6.password_value, result[0]->password_value); // Preferred login. @@ -381,7 +377,7 @@ TEST_F(WebDatabaseTest, Logins) { // Make sure everything can disappear. EXPECT_TRUE(db.RemoveLogin(form4)); EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); } TEST_F(WebDatabaseTest, Autofill) { @@ -434,7 +430,7 @@ TEST_F(WebDatabaseTest, Autofill) { // no matter what they start with. The order that the names occur in the list // should be decreasing order by count. EXPECT_TRUE(db.GetFormValuesForElementName(L"Name", std::wstring(), &v, 6)); - EXPECT_EQ(3, v.size()); + EXPECT_EQ(3U, v.size()); if (v.size() == 3) { EXPECT_EQ(L"Clark Kent", v[0]); EXPECT_EQ(L"Clark Sutter", v[1]); @@ -444,7 +440,7 @@ TEST_F(WebDatabaseTest, Autofill) { // If we query again limiting the list size to 1, we should only get the most // frequent entry. EXPECT_TRUE(db.GetFormValuesForElementName(L"Name", L"", &v, 1)); - EXPECT_EQ(1, v.size()); + EXPECT_EQ(1U, v.size()); if (v.size() == 1) { EXPECT_EQ(L"Clark Kent", v[0]); } @@ -452,7 +448,7 @@ TEST_F(WebDatabaseTest, Autofill) { // Querying for suggestions given a prefix is case-insensitive, so the prefix // "cLa" shoud get suggestions for both Clarks. EXPECT_TRUE(db.GetFormValuesForElementName(L"Name", L"cLa", &v, 6)); - EXPECT_EQ(2, v.size()); + EXPECT_EQ(2U, v.size()); if (v.size() == 2) { EXPECT_EQ(L"Clark Kent", v[0]); EXPECT_EQ(L"Clark Sutter", v[1]); @@ -467,7 +463,7 @@ TEST_F(WebDatabaseTest, Autofill) { EXPECT_EQ(0, count); EXPECT_TRUE(db.GetFormValuesForElementName(L"Name", L"", &v, 6)); - EXPECT_EQ(0, v.size()); + EXPECT_EQ(0U, v.size()); } static bool AddTimestampedLogin(WebDatabase* db, std::string url, @@ -500,7 +496,7 @@ TEST_F(WebDatabaseTest, ClearPrivateData_SavedPasswords) { // Verify the database is empty. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); Time now = Time::Now(); TimeDelta one_day = TimeDelta::FromDays(1); @@ -514,7 +510,7 @@ TEST_F(WebDatabaseTest, ClearPrivateData_SavedPasswords) { // Verify inserts worked. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(4, result.size()); + EXPECT_EQ(4U, result.size()); ClearResults(&result); // Delete everything from today's date and on. @@ -522,7 +518,7 @@ TEST_F(WebDatabaseTest, ClearPrivateData_SavedPasswords) { // Should have deleted half of what we inserted. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(2, result.size()); + EXPECT_EQ(2U, result.size()); ClearResults(&result); // Delete with 0 date (should delete all). @@ -530,7 +526,7 @@ TEST_F(WebDatabaseTest, ClearPrivateData_SavedPasswords) { // Verify nothing is left. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(0, result.size()); + EXPECT_EQ(0U, result.size()); } TEST_F(WebDatabaseTest, BlacklistedLogins) { @@ -541,12 +537,12 @@ TEST_F(WebDatabaseTest, BlacklistedLogins) { // Verify the database is empty. EXPECT_TRUE(db.GetAllLogins(&result, true)); - ASSERT_EQ(0, result.size()); + ASSERT_EQ(0U, result.size()); // Save a form as blacklisted. PasswordForm form; - form.origin = GURL(L"http://www.google.com/accounts/LoginAuth"); - form.action = GURL(L"http://www.google.com/accounts/Login"); + form.origin = GURL("http://www.google.com/accounts/LoginAuth"); + form.action = GURL("http://www.google.com/accounts/Login"); form.username_element = L"Email"; form.password_element = L"Passwd"; form.submit_element = L"signIn"; @@ -559,16 +555,16 @@ TEST_F(WebDatabaseTest, BlacklistedLogins) { // Get all non-blacklisted logins (should be none). EXPECT_TRUE(db.GetAllLogins(&result, false)); - ASSERT_EQ(0, result.size()); + ASSERT_EQ(0U, result.size()); // GetLogins should give the blacklisted result. EXPECT_TRUE(db.GetLogins(form, &result)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); ClearResults(&result); // So should GetAll including blacklisted. EXPECT_TRUE(db.GetAllLogins(&result, true)); - EXPECT_EQ(1, result.size()); + EXPECT_EQ(1U, result.size()); ClearResults(&result); } @@ -599,7 +595,7 @@ TEST_F(WebDatabaseTest, WebAppImages) { // Web app should initially have no images. std::vector<SkBitmap> images; ASSERT_TRUE(db.GetWebAppImages(url, &images)); - ASSERT_EQ(0, images.size()); + ASSERT_EQ(0U, images.size()); // Add an image. SkBitmap image; @@ -610,7 +606,7 @@ TEST_F(WebDatabaseTest, WebAppImages) { // Make sure we get the image back. ASSERT_TRUE(db.GetWebAppImages(url, &images)); - ASSERT_EQ(1, images.size()); + ASSERT_EQ(1U, images.size()); ASSERT_EQ(16, images[0].width()); ASSERT_EQ(16, images[0].height()); @@ -623,7 +619,7 @@ TEST_F(WebDatabaseTest, WebAppImages) { ASSERT_TRUE(db.SetWebAppImage(url, image)); images.clear(); ASSERT_TRUE(db.GetWebAppImages(url, &images)); - ASSERT_EQ(1, images.size()); + ASSERT_EQ(1U, images.size()); ASSERT_EQ(16, images[0].width()); ASSERT_EQ(16, images[0].height()); images[0].lockPixels(); @@ -642,7 +638,7 @@ TEST_F(WebDatabaseTest, WebAppImages) { // Make sure we get both images back. images.clear(); ASSERT_TRUE(db.GetWebAppImages(url, &images)); - ASSERT_EQ(2, images.size()); + ASSERT_EQ(2U, images.size()); if (images[0].width() == 16) { ASSERT_EQ(16, images[0].width()); ASSERT_EQ(16, images[0].height()); diff --git a/chrome/browser/webdata/web_database_win.cc b/chrome/browser/webdata/web_database_win.cc new file mode 100644 index 0000000..f5793d4 --- /dev/null +++ b/chrome/browser/webdata/web_database_win.cc @@ -0,0 +1,72 @@ +// Copyright (c) 2008 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. + +#include "chrome/browser/webdata/web_database.h" + +#include "base/logging.h" +#include "base/time.h" +#include "chrome/browser/ie7_password.h" +#include "chrome/common/sqlite_utils.h" + +bool WebDatabase::AddIE7Login(const IE7PasswordInfo& info) { + SQLStatement s; + if (s.prepare(db_, + "INSERT OR REPLACE INTO ie7_logins " + "(url_hash, password_value, date_created) " + "VALUES (?, ?, ?)") != SQLITE_OK) { + NOTREACHED() << "Statement prepare failed"; + return false; + } + + s.bind_wstring(0, info.url_hash); + s.bind_blob(1, &info.encrypted_data.front(), + static_cast<int>(info.encrypted_data.size())); + s.bind_int64(2, info.date_created.ToTimeT()); + if (s.step() != SQLITE_DONE) { + NOTREACHED(); + return false; + } + return true; +} + +bool WebDatabase::RemoveIE7Login(const IE7PasswordInfo& info) { + SQLStatement s; + // Remove a login by UNIQUE-constrained fields. + if (s.prepare(db_, + "DELETE FROM ie7_logins WHERE " + "url_hash = ?") != SQLITE_OK) { + NOTREACHED() << "Statement prepare failed"; + return false; + } + s.bind_wstring(0, info.url_hash); + + if (s.step() != SQLITE_DONE) { + NOTREACHED(); + return false; + } + return true; +} + +bool WebDatabase::GetIE7Login(const IE7PasswordInfo& info, + IE7PasswordInfo* result) { + DCHECK(result); + SQLStatement s; + if (s.prepare(db_, + "SELECT password_value, date_created FROM ie7_logins " + "WHERE url_hash == ? ") != SQLITE_OK) { + NOTREACHED() << "Statement prepare failed"; + return false; + } + + s.bind_wstring(0, info.url_hash); + + int64 query_result = s.step(); + if (query_result == SQLITE_ROW) { + s.column_blob_as_vector(0, &result->encrypted_data); + result->date_created = base::Time::FromTimeT(s.column_int64(1)); + result->url_hash = info.url_hash; + s.step(); + } + return query_result == SQLITE_DONE; +} |