1 // Copyright 2014 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 COMPONENTS_HISTORY_CORE_BROWSER_HISTORY_TYPES_H_ 6 #define COMPONENTS_HISTORY_CORE_BROWSER_HISTORY_TYPES_H_ 7 8 #include <deque> 9 #include <map> 10 #include <set> 11 #include <string> 12 #include <vector> 13 14 #include "base/basictypes.h" 15 #include "base/containers/stack_container.h" 16 #include "base/memory/ref_counted_memory.h" 17 #include "base/memory/scoped_vector.h" 18 #include "base/strings/string16.h" 19 #include "base/time/time.h" 20 #include "components/favicon_base/favicon_types.h" 21 #include "components/history/core/browser/url_row.h" 22 #include "components/history/core/common/thumbnail_score.h" 23 #include "ui/base/page_transition_types.h" 24 #include "ui/gfx/size.h" 25 #include "url/gurl.h" 26 27 class PageUsageData; 28 29 // TODO(sdefresne): remove, http://crbug.com/371816 30 namespace content { 31 class WebContents; 32 } 33 34 namespace history { 35 36 // Forward declaration for friend statements. 37 class HistoryBackend; 38 class URLDatabase; 39 40 // Container for a list of URLs. 41 typedef std::vector<GURL> RedirectList; 42 43 typedef int64 FaviconBitmapID; // Identifier for a bitmap in a favicon. 44 typedef int64 SegmentID; // URL segments for the most visited view. 45 typedef int64 IconMappingID; // For page url and icon mapping. 46 47 // Identifier for a context to scope page ids. (ContextIDs are used in 48 // comparisons only and are never dereferenced.) 49 // NB: The use of WebContents here is temporary; when the dependency on content 50 // is broken, some other type will take its place. 51 typedef content::WebContents* ContextID; 52 53 // The enumeration of all possible sources of visits is listed below. 54 // The source will be propagated along with a URL or a visit item 55 // and eventually be stored in the history database, 56 // visit_source table specifically. 57 // Different from page transition types, they describe the origins of visits. 58 // (Warning): Please don't change any existing values while it is ok to add 59 // new values when needed. 60 enum VisitSource { 61 SOURCE_SYNCED = 0, // Synchronized from somewhere else. 62 SOURCE_BROWSED = 1, // User browsed. 63 SOURCE_EXTENSION = 2, // Added by an extension. 64 SOURCE_FIREFOX_IMPORTED = 3, 65 SOURCE_IE_IMPORTED = 4, 66 SOURCE_SAFARI_IMPORTED = 5, 67 }; 68 69 typedef int64 VisitID; 70 // Structure to hold the mapping between each visit's id and its source. 71 typedef std::map<VisitID, VisitSource> VisitSourceMap; 72 73 // VisitRow ------------------------------------------------------------------- 74 75 // Holds all information associated with a specific visit. A visit holds time 76 // and referrer information for one time a URL is visited. 77 class VisitRow { 78 public: 79 VisitRow(); 80 VisitRow(URLID arg_url_id, 81 base::Time arg_visit_time, 82 VisitID arg_referring_visit, 83 ui::PageTransition arg_transition, 84 SegmentID arg_segment_id); 85 ~VisitRow(); 86 87 // ID of this row (visit ID, used a a referrer for other visits). 88 VisitID visit_id; 89 90 // Row ID into the URL table of the URL that this page is. 91 URLID url_id; 92 93 base::Time visit_time; 94 95 // Indicates another visit that was the referring page for this one. 96 // 0 indicates no referrer. 97 VisitID referring_visit; 98 99 // A combination of bits from PageTransition. 100 ui::PageTransition transition; 101 102 // The segment id (see visitsegment_database.*). 103 // If 0, the segment id is null in the table. 104 SegmentID segment_id; 105 106 // Record how much time a user has this visit starting from the user 107 // opened this visit to the user closed or ended this visit. 108 // This includes both active and inactive time as long as 109 // the visit was present. 110 base::TimeDelta visit_duration; 111 112 // Compares two visits based on dates, for sorting. 113 bool operator<(const VisitRow& other) { 114 return visit_time < other.visit_time; 115 } 116 117 // We allow the implicit copy constuctor and operator=. 118 }; 119 120 // We pass around vectors of visits a lot 121 typedef std::vector<VisitRow> VisitVector; 122 123 // The basic information associated with a visit (timestamp, type of visit), 124 // used by HistoryBackend::AddVisits() to create new visits for a URL. 125 typedef std::pair<base::Time, ui::PageTransition> VisitInfo; 126 127 // PageVisit ------------------------------------------------------------------ 128 129 // Represents a simplified version of a visit for external users. Normally, 130 // views are only interested in the time, and not the other information 131 // associated with a VisitRow. 132 struct PageVisit { 133 URLID page_id; 134 base::Time visit_time; 135 }; 136 137 // QueryResults ---------------------------------------------------------------- 138 139 // Encapsulates the results of a history query. It supports an ordered list of 140 // URLResult objects, plus an efficient way of looking up the index of each time 141 // a given URL appears in those results. 142 class QueryResults { 143 public: 144 typedef std::vector<URLResult*> URLResultVector; 145 146 QueryResults(); 147 ~QueryResults(); 148 149 // Indicates the first time that the query includes results for (queries are 150 // clipped at the beginning, so it will always include to the end of the time 151 // queried). 152 // 153 // If the number of results was clipped as a result of the max count, this 154 // will be the time of the first query returned. If there were fewer results 155 // than we were allowed to return, this represents the first date considered 156 // in the query (this will be before the first result if there was time 157 // queried with no results). 158 // 159 // TODO(brettw): bug 1203054: This field is not currently set properly! Do 160 // not use until the bug is fixed. first_time_searched()161 base::Time first_time_searched() const { return first_time_searched_; } set_first_time_searched(base::Time t)162 void set_first_time_searched(base::Time t) { first_time_searched_ = t; } 163 // Note: If you need end_time_searched, it can be added. 164 set_reached_beginning(bool reached)165 void set_reached_beginning(bool reached) { reached_beginning_ = reached; } reached_beginning()166 bool reached_beginning() { return reached_beginning_; } 167 size()168 size_t size() const { return results_.size(); } empty()169 bool empty() const { return results_.empty(); } 170 back()171 URLResult& back() { return *results_.back(); } back()172 const URLResult& back() const { return *results_.back(); } 173 174 URLResult& operator[](size_t i) { return *results_[i]; } 175 const URLResult& operator[](size_t i) const { return *results_[i]; } 176 begin()177 URLResultVector::const_iterator begin() const { return results_.begin(); } end()178 URLResultVector::const_iterator end() const { return results_.end(); } rbegin()179 URLResultVector::const_reverse_iterator rbegin() const { 180 return results_.rbegin(); 181 } rend()182 URLResultVector::const_reverse_iterator rend() const { 183 return results_.rend(); 184 } 185 186 // Returns a pointer to the beginning of an array of all matching indices 187 // for entries with the given URL. The array will be |*num_matches| long. 188 // |num_matches| can be NULL if the caller is not interested in the number of 189 // results (commonly it will only be interested in the first one and can test 190 // the pointer for NULL). 191 // 192 // When there is no match, it will return NULL and |*num_matches| will be 0. 193 const size_t* MatchesForURL(const GURL& url, size_t* num_matches) const; 194 195 // Swaps the current result with another. This allows ownership to be 196 // efficiently transferred without copying. 197 void Swap(QueryResults* other); 198 199 // Adds the given result to the map, using swap() on the members to avoid 200 // copying (there are a lot of strings and vectors). This means the parameter 201 // object will be cleared after this call. 202 void AppendURLBySwapping(URLResult* result); 203 204 // Removes all instances of the given URL from the result set. 205 void DeleteURL(const GURL& url); 206 207 // Deletes the given range of items in the result set. 208 void DeleteRange(size_t begin, size_t end); 209 210 private: 211 // Maps the given URL to a list of indices into results_ which identify each 212 // time an entry with that URL appears. Normally, each URL will have one or 213 // very few indices after it, so we optimize this to use statically allocated 214 // memory when possible. 215 typedef std::map<GURL, base::StackVector<size_t, 4> > URLToResultIndices; 216 217 // Inserts an entry into the |url_to_results_| map saying that the given URL 218 // is at the given index in the results_. 219 void AddURLUsageAtIndex(const GURL& url, size_t index); 220 221 // Adds |delta| to each index in url_to_results_ in the range [begin,end] 222 // (this is inclusive). This is used when inserting or deleting. 223 void AdjustResultMap(size_t begin, size_t end, ptrdiff_t delta); 224 225 base::Time first_time_searched_; 226 227 // Whether the query reaches the beginning of the database. 228 bool reached_beginning_; 229 230 // The ordered list of results. The pointers inside this are owned by this 231 // QueryResults object. 232 ScopedVector<URLResult> results_; 233 234 // Maps URLs to entries in results_. 235 URLToResultIndices url_to_results_; 236 237 DISALLOW_COPY_AND_ASSIGN(QueryResults); 238 }; 239 240 // QueryOptions ---------------------------------------------------------------- 241 242 struct QueryOptions { 243 QueryOptions(); 244 245 // The time range to search for matches in. The beginning is inclusive and 246 // the ending is exclusive. Either one (or both) may be null. 247 // 248 // This will match only the one recent visit of a URL. For text search 249 // queries, if the URL was visited in the given time period, but has also 250 // been visited more recently than that, it will not be returned. When the 251 // text query is empty, this will return the most recent visit within the 252 // time range. 253 base::Time begin_time; 254 base::Time end_time; 255 256 // Sets the query time to the last |days_ago| days to the present time. 257 void SetRecentDayRange(int days_ago); 258 259 // The maximum number of results to return. The results will be sorted with 260 // the most recent first, so older results may not be returned if there is not 261 // enough room. When 0, this will return everything (the default). 262 int max_count; 263 264 enum DuplicateHandling { 265 // Omit visits for which there is a more recent visit to the same URL. 266 // Each URL in the results will appear only once. 267 REMOVE_ALL_DUPLICATES, 268 269 // Omit visits for which there is a more recent visit to the same URL on 270 // the same day. Each URL will appear no more than once per day, where the 271 // day is defined by the local timezone. 272 REMOVE_DUPLICATES_PER_DAY, 273 274 // Return all visits without deduping. 275 KEEP_ALL_DUPLICATES 276 }; 277 278 // Allows the caller to specify how duplicate URLs in the result set should 279 // be handled. The default is REMOVE_DUPLICATES. 280 DuplicateHandling duplicate_policy; 281 282 // Helpers to get the effective parameters values, since a value of 0 means 283 // "unspecified". 284 int EffectiveMaxCount() const; 285 int64 EffectiveBeginTime() const; 286 int64 EffectiveEndTime() const; 287 }; 288 289 // QueryURLResult ------------------------------------------------------------- 290 291 // QueryURLResult encapsulates the result of a call to HistoryBackend::QueryURL. 292 struct QueryURLResult { 293 QueryURLResult(); 294 ~QueryURLResult(); 295 296 // Indicates whether the call to HistoryBackend::QueryURL was successfull 297 // or not. If false, then both |row| and |visits| fields are undefined. 298 bool success; 299 URLRow row; 300 VisitVector visits; 301 }; 302 303 // VisibleVisitCountToHostResult ---------------------------------------------- 304 305 // VisibleVisitCountToHostResult encapsulates the result of a call to 306 // HistoryBackend::GetVisibleVisitCountToHost. 307 struct VisibleVisitCountToHostResult { 308 // Indicates whether the call to HistoryBackend::GetVisibleVisitCountToHost 309 // was successfull or not. If false, then both |count| and |first_visit| are 310 // undefined. 311 bool success; 312 int count; 313 base::Time first_visit; 314 }; 315 316 // MostVisitedURL -------------------------------------------------------------- 317 318 // Holds the per-URL information of the most visited query. 319 struct MostVisitedURL { 320 MostVisitedURL(); 321 MostVisitedURL(const GURL& url, const base::string16& title); 322 MostVisitedURL(const GURL& url, 323 const base::string16& title, 324 const base::Time& last_forced_time); 325 ~MostVisitedURL(); 326 327 GURL url; 328 base::string16 title; 329 330 // If this is a URL for which we want to force a thumbnail, records the last 331 // time it was forced so we can evict it when more recent URLs are requested. 332 // If it's not a forced thumbnail, keep a time of 0. 333 base::Time last_forced_time; 334 335 RedirectList redirects; 336 337 bool operator==(const MostVisitedURL& other) { 338 return url == other.url; 339 } 340 }; 341 342 // FilteredURL ----------------------------------------------------------------- 343 344 // Holds the per-URL information of the filterd url query. 345 struct FilteredURL { 346 struct ExtendedInfo { 347 ExtendedInfo(); 348 // The absolute number of visits. 349 unsigned int total_visits; 350 // The number of visits, as seen by the Most Visited NTP pane. 351 unsigned int visits; 352 // The total number of seconds that the page was open. 353 int64 duration_opened; 354 // The time when the page was last visited. 355 base::Time last_visit_time; 356 }; 357 358 FilteredURL(); 359 explicit FilteredURL(const PageUsageData& data); 360 ~FilteredURL(); 361 362 GURL url; 363 base::string16 title; 364 double score; 365 ExtendedInfo extended_info; 366 }; 367 368 // Navigation ----------------------------------------------------------------- 369 370 // Marshalling structure for AddPage. 371 struct HistoryAddPageArgs { 372 // The default constructor is equivalent to: 373 // 374 // HistoryAddPageArgs( 375 // GURL(), base::Time(), NULL, 0, GURL(), 376 // history::RedirectList(), ui::PAGE_TRANSITION_LINK, 377 // SOURCE_BROWSED, false) 378 HistoryAddPageArgs(); 379 HistoryAddPageArgs(const GURL& url, 380 base::Time time, 381 ContextID context_id, 382 int32 page_id, 383 const GURL& referrer, 384 const history::RedirectList& redirects, 385 ui::PageTransition transition, 386 VisitSource source, 387 bool did_replace_entry); 388 ~HistoryAddPageArgs(); 389 390 GURL url; 391 base::Time time; 392 393 ContextID context_id; 394 int32 page_id; 395 396 GURL referrer; 397 history::RedirectList redirects; 398 ui::PageTransition transition; 399 VisitSource visit_source; 400 bool did_replace_entry; 401 }; 402 403 // TopSites ------------------------------------------------------------------- 404 405 typedef std::vector<MostVisitedURL> MostVisitedURLList; 406 typedef std::vector<FilteredURL> FilteredURLList; 407 408 // Used by TopSites to store the thumbnails. 409 struct Images { 410 Images(); 411 ~Images(); 412 413 scoped_refptr<base::RefCountedMemory> thumbnail; 414 ThumbnailScore thumbnail_score; 415 416 // TODO(brettw): this will eventually store the favicon. 417 // scoped_refptr<base::RefCountedBytes> favicon; 418 }; 419 420 struct MostVisitedURLWithRank { 421 MostVisitedURL url; 422 int rank; 423 }; 424 425 typedef std::vector<MostVisitedURLWithRank> MostVisitedURLWithRankList; 426 427 struct TopSitesDelta { 428 TopSitesDelta(); 429 ~TopSitesDelta(); 430 431 MostVisitedURLList deleted; 432 MostVisitedURLWithRankList added; 433 MostVisitedURLWithRankList moved; 434 }; 435 436 typedef std::map<GURL, scoped_refptr<base::RefCountedBytes> > URLToThumbnailMap; 437 438 // Used when migrating most visited thumbnails out of history and into topsites. 439 struct ThumbnailMigration { 440 ThumbnailMigration(); 441 ~ThumbnailMigration(); 442 443 MostVisitedURLList most_visited; 444 URLToThumbnailMap url_to_thumbnail_map; 445 }; 446 447 typedef std::map<GURL, Images> URLToImagesMap; 448 449 class MostVisitedThumbnails 450 : public base::RefCountedThreadSafe<MostVisitedThumbnails> { 451 public: 452 MostVisitedThumbnails(); 453 454 MostVisitedURLList most_visited; 455 URLToImagesMap url_to_images_map; 456 457 private: 458 friend class base::RefCountedThreadSafe<MostVisitedThumbnails>; 459 virtual ~MostVisitedThumbnails(); 460 461 DISALLOW_COPY_AND_ASSIGN(MostVisitedThumbnails); 462 }; 463 464 // Favicons ------------------------------------------------------------------- 465 466 // Used for the mapping between the page and icon. 467 struct IconMapping { 468 IconMapping(); 469 ~IconMapping(); 470 471 // The unique id of the mapping. 472 IconMappingID mapping_id; 473 474 // The url of a web page. 475 GURL page_url; 476 477 // The unique id of the icon. 478 favicon_base::FaviconID icon_id; 479 480 // The url of the icon. 481 GURL icon_url; 482 483 // The type of icon. 484 favicon_base::IconType icon_type; 485 }; 486 487 // Defines a favicon bitmap and its associated pixel size. 488 struct FaviconBitmapIDSize { 489 FaviconBitmapIDSize(); 490 ~FaviconBitmapIDSize(); 491 492 // The unique id of the favicon bitmap. 493 FaviconBitmapID bitmap_id; 494 495 // The pixel dimensions of the associated bitmap. 496 gfx::Size pixel_size; 497 }; 498 499 // Defines a favicon bitmap stored in the history backend. 500 struct FaviconBitmap { 501 FaviconBitmap(); 502 ~FaviconBitmap(); 503 504 // The unique id of the bitmap. 505 FaviconBitmapID bitmap_id; 506 507 // The id of the favicon to which the bitmap belongs to. 508 favicon_base::FaviconID icon_id; 509 510 // Time at which |bitmap_data| was last updated. 511 base::Time last_updated; 512 513 // The bits of the bitmap. 514 scoped_refptr<base::RefCountedMemory> bitmap_data; 515 516 // The pixel dimensions of bitmap_data. 517 gfx::Size pixel_size; 518 }; 519 520 // Abbreviated information about a visit. 521 struct BriefVisitInfo { 522 URLID url_id; 523 base::Time time; 524 ui::PageTransition transition; 525 }; 526 527 // An observer of VisitDatabase. 528 class VisitDatabaseObserver { 529 public: 530 virtual ~VisitDatabaseObserver(); 531 virtual void OnAddVisit(const BriefVisitInfo& info) = 0; 532 }; 533 534 struct ExpireHistoryArgs { 535 ExpireHistoryArgs(); 536 ~ExpireHistoryArgs(); 537 538 // Sets |begin_time| and |end_time| to the beginning and end of the day (in 539 // local time) on which |time| occurs. 540 void SetTimeRangeForOneDay(base::Time time); 541 542 std::set<GURL> urls; 543 base::Time begin_time; 544 base::Time end_time; 545 }; 546 547 } // namespace history 548 549 #endif // COMPONENTS_HISTORY_CORE_BROWSER_HISTORY_TYPES_H_ 550