// Copyright (c) 2012 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. #ifndef COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_H_ #define COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_H_ #include <map> #include "base/memory/scoped_ptr.h" #include "components/webdata/common/web_database_table.h" #include "components/webdata/common/webdata_export.h" #include "sql/connection.h" #include "sql/init_status.h" #include "sql/meta_table.h" namespace base { class FilePath; } // This class manages a SQLite database that stores various web page meta data. class WEBDATA_EXPORT WebDatabase { public: enum State { COMMIT_NOT_NEEDED, COMMIT_NEEDED }; // Exposed publicly so the keyword table can access it. static const int kCurrentVersionNumber; WebDatabase(); virtual ~WebDatabase(); // Adds a database table. Ownership remains with the caller, which // must ensure that the lifetime of |table| exceeds this object's // lifetime. Must only be called before Init. void AddTable(WebDatabaseTable* table); // Retrieves a table based on its |key|. WebDatabaseTable* GetTable(WebDatabaseTable::TypeKey key); // Initialize the database given a name. The name defines where the SQLite // file is. If this returns an error code, no other method should be called. // // Before calling this method, you must call AddTable for any // WebDatabaseTable objects that are supposed to participate in // managing the database. sql::InitStatus Init(const base::FilePath& db_name); // Transactions management void BeginTransaction(); void CommitTransaction(); // Exposed for testing only. sql::Connection* GetSQLConnection(); private: // Used by |Init()| to migration database schema from older versions to // current version. sql::InitStatus MigrateOldVersionsAsNeeded(); sql::Connection db_; sql::MetaTable meta_table_; // Map of all the different tables that have been added to this // object. Non-owning. typedef std::map<WebDatabaseTable::TypeKey, WebDatabaseTable*> TableMap; TableMap tables_; DISALLOW_COPY_AND_ASSIGN(WebDatabase); }; #endif // COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_H_