Home | History | Annotate | Download | only in history
      1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef CHROME_BROWSER_HISTORY_TOP_SITES_DATABASE_H_
      6 #define CHROME_BROWSER_HISTORY_TOP_SITES_DATABASE_H_
      7 #pragma once
      8 
      9 #include <map>
     10 #include <string>
     11 
     12 #include "app/sql/meta_table.h"
     13 #include "base/memory/ref_counted.h"
     14 #include "chrome/browser/history/history_types.h"
     15 #include "chrome/browser/history/url_database.h"  // For DBCloseScoper.
     16 
     17 class FilePath;
     18 class RefCountedMemory;
     19 class SkBitmap;
     20 
     21 namespace app {
     22 class Connection;
     23 }
     24 
     25 namespace history {
     26 
     27 class TopSitesDatabase {
     28  public:
     29   TopSitesDatabase();
     30   ~TopSitesDatabase();
     31 
     32   // Must be called after creation but before any other methods are called.
     33   // Returns true on success. If false, no other functions should be called.
     34   bool Init(const FilePath& db_name);
     35 
     36   // Returns true if migration of top sites from history may be needed. A value
     37   // of true means either migration is definitely needed (the top sites file is
     38   // old) or doesn't exist (as would happen for a new user).
     39   bool may_need_history_migration() const {
     40     return may_need_history_migration_;
     41   }
     42 
     43   // Thumbnails ----------------------------------------------------------------
     44 
     45   // Returns a list of all URLs currently in the table.
     46   // WARNING: clears both input arguments.
     47   void GetPageThumbnails(MostVisitedURLList* urls,
     48                          std::map<GURL, Images>* thumbnails);
     49 
     50   // Set a thumbnail for a URL. |url_rank| is the position of the URL
     51   // in the list of TopURLs, zero-based.
     52   // If the URL is not in the table, add it. If it is, replace its
     53   // thumbnail and rank. Shift the ranks of other URLs if necessary.
     54   void SetPageThumbnail(const MostVisitedURL& url,
     55                         int new_rank,
     56                         const Images& thumbnail);
     57 
     58   // Sets the rank for a given URL. The URL must be in the database.
     59   // Use SetPageThumbnail if it's not.
     60   void UpdatePageRank(const MostVisitedURL& url, int new_rank);
     61 
     62   // Get a thumbnail for a given page. Returns true iff we have the thumbnail.
     63   bool GetPageThumbnail(const GURL& url, Images* thumbnail);
     64 
     65   // Remove the record for this URL. Returns true iff removed successfully.
     66   bool RemoveURL(const MostVisitedURL& url);
     67 
     68  private:
     69   // Creates the thumbnail table, returning true if the table already exists
     70   // or was successfully created.
     71   bool InitThumbnailTable();
     72 
     73   // Adds a new URL to the database.
     74   void AddPageThumbnail(const MostVisitedURL& url,
     75                         int new_rank,
     76                         const Images& thumbnail);
     77 
     78   // Sets the page rank. Should be called within an open transaction.
     79   void UpdatePageRankNoTransaction(const MostVisitedURL& url, int new_rank);
     80 
     81   // Updates thumbnail of a URL that's already in the database.
     82   void UpdatePageThumbnail(const MostVisitedURL& url,
     83                            const Images& thumbnail);
     84 
     85   // Returns the URL's current rank or -1 if it is not present.
     86   int GetURLRank(const MostVisitedURL& url);
     87 
     88   // Returns the number of URLs (rows) in the database.
     89   int GetRowCount();
     90 
     91   sql::Connection* CreateDB(const FilePath& db_name);
     92 
     93   // Encodes redirects into a string.
     94   static std::string GetRedirects(const MostVisitedURL& url);
     95 
     96   // Decodes redirects from a string and sets them for the url.
     97   static void SetRedirects(const std::string& redirects, MostVisitedURL* url);
     98 
     99   scoped_ptr<sql::Connection> db_;
    100   sql::MetaTable meta_table_;
    101 
    102   // See description above class.
    103   bool may_need_history_migration_;
    104 
    105   DISALLOW_COPY_AND_ASSIGN(TopSitesDatabase);
    106 };
    107 
    108 }  // namespace history
    109 
    110 #endif  // CHROME_BROWSER_HISTORY_TOP_SITES_DATABASE_H_
    111