summaryrefslogtreecommitdiffstats
path: root/webkit/database
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/database')
-rw-r--r--webkit/database/database_tracker.cc46
-rw-r--r--webkit/database/database_tracker.h3
2 files changed, 48 insertions, 1 deletions
diff --git a/webkit/database/database_tracker.cc b/webkit/database/database_tracker.cc
index 01c3052..0d68633 100644
--- a/webkit/database/database_tracker.cc
+++ b/webkit/database/database_tracker.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// 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.
@@ -14,8 +14,11 @@
#include "base/file_path.h"
#include "base/file_util.h"
#include "base/string_util.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebSecurityOrigin.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebString.h"
#include "webkit/database/databases_table.h"
#include "webkit/database/quota_table.h"
+#include "webkit/glue/webkit_glue.h"
namespace webkit_database {
@@ -331,4 +334,45 @@ int64 DatabaseTracker::UpdateCachedDatabaseFileSize(
return new_size;
}
+// static
+void DatabaseTracker::ClearLocalState(const FilePath& profile_path,
+ const char* url_scheme_to_be_skipped) {
+ FilePath db_dir = profile_path.Append(FilePath(kDatabaseDirectoryName));
+ FilePath db_tracker = db_dir.Append(FilePath(kTrackerDatabaseFileName));
+ if (file_util::DirectoryExists(db_dir) &&
+ file_util::PathExists(db_tracker)) {
+ scoped_ptr<sql::Connection> db_(new sql::Connection);
+ if (!db_->Open(db_tracker) ||
+ !db_->DoesTableExist("Databases")) {
+ db_->Close();
+ file_util::Delete(db_dir, true);
+ return;
+ } else {
+ sql::Statement delete_statement(db_->GetCachedStatement(
+ SQL_FROM_HERE, "DELETE FROM Databases WHERE origin NOT LIKE ?"));
+ std::string filter(url_scheme_to_be_skipped);
+ filter += "_%";
+ delete_statement.BindString(0, filter);
+ if (!delete_statement.Run()) {
+ db_->Close();
+ file_util::Delete(db_dir, true);
+ return;
+ }
+ }
+ }
+ file_util::FileEnumerator file_enumerator(db_dir, false,
+ file_util::FileEnumerator::DIRECTORIES);
+ for (FilePath file_path = file_enumerator.Next(); !file_path.empty();
+ file_path = file_enumerator.Next()) {
+ if (file_path.BaseName() != kTrackerDatabaseFileName) {
+ scoped_ptr<WebKit::WebSecurityOrigin> web_security_origin(
+ WebKit::WebSecurityOrigin::createFromDatabaseIdentifier(
+ webkit_glue::FilePathToWebString(file_path.BaseName())));
+ if (!EqualsASCII(web_security_origin->protocol(),
+ url_scheme_to_be_skipped))
+ file_util::Delete(file_path, true);
+ }
+ }
+}
+
} // namespace webkit_database
diff --git a/webkit/database/database_tracker.h b/webkit/database/database_tracker.h
index f3f6041..4375a35 100644
--- a/webkit/database/database_tracker.h
+++ b/webkit/database/database_tracker.h
@@ -116,6 +116,9 @@ class DatabaseTracker
const string16& database_name);
bool DeleteOrigin(const string16& origin_identifier);
+ static void ClearLocalState(const FilePath& profile_path,
+ const char* url_scheme_to_be_skipped);
+
private:
// Need this here to allow RefCountedThreadSafe to call ~DatabaseTracker().
friend class base::RefCountedThreadSafe<DatabaseTracker>;