summaryrefslogtreecommitdiffstats
path: root/chrome/browser/webdata
diff options
context:
space:
mode:
authorphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-16 11:12:13 +0000
committerphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-16 11:12:13 +0000
commit400d807b0c567a1df1087694627737174a13c8ad (patch)
tree49250804cbf635a2bb460937ac930d92dcf1b361 /chrome/browser/webdata
parent97f756b5dcf7d1a6ffb4ea4e961ccb5fb12aeae2 (diff)
downloadchromium_src-400d807b0c567a1df1087694627737174a13c8ad.zip
chromium_src-400d807b0c567a1df1087694627737174a13c8ad.tar.gz
chromium_src-400d807b0c567a1df1087694627737174a13c8ad.tar.bz2
Porting in browser/webdata and template_url.
Review URL: http://codereview.chromium.org/14419 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@7052 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/webdata')
-rw-r--r--chrome/browser/webdata/web_data_service.h12
-rw-r--r--chrome/browser/webdata/web_database.cc105
-rw-r--r--chrome/browser/webdata/web_database.h18
-rw-r--r--chrome/browser/webdata/web_database_unittest.cc96
-rw-r--r--chrome/browser/webdata/web_database_win.cc72
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;
+}