// Copyright 2013 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_AUTOFILL_CORE_BROWSER_AUTOFILL_DATA_MODEL_H_ #define COMPONENTS_AUTOFILL_CORE_BROWSER_AUTOFILL_DATA_MODEL_H_ #include #include #include "base/strings/string16.h" #include "base/time/time.h" #include "components/autofill/core/browser/form_group.h" namespace autofill { class AutofillType; // This class is an interface for the primary data models that back Autofill. // The information in objects of this class is managed by the // PersonalDataManager. class AutofillDataModel : public FormGroup { public: AutofillDataModel(const std::string& guid, const std::string& origin); ~AutofillDataModel() override; // Returns true if the data in this model was entered directly by the user, // rather than automatically aggregated. bool IsVerified() const; std::string guid() const { return guid_; } void set_guid(const std::string& guid) { guid_ = guid; } std::string origin() const { return origin_; } void set_origin(const std::string& origin) { origin_ = origin; } size_t use_count() const { return use_count_; } void set_use_count(size_t count) { use_count_ = count; } const base::Time& use_date() const { return use_date_; } void set_use_date(const base::Time& time) { use_date_ = time; } const base::Time& modification_date() const { return modification_date_; } // This should only be called from database code. void set_modification_date(const base::Time& time) { modification_date_ = time; } // Compares two data models according to their frecency score. The score uses // a combination of frequency and recency to determine the relevance of the // profile. |comparison_time_| allows consistent sorting throughout the // comparisons. bool CompareFrecency(const AutofillDataModel* other, base::Time comparison_time) const; protected: // Called to update |use_count_| and |use_date_| when this data model is // the subject of user interaction (usually, when it's used to fill a form). void RecordUse(); private: // A globally unique ID for this object. std::string guid_; // The origin of this data. This should be // (a) a web URL for the domain of the form from which the data was // automatically aggregated, e.g. https://www.example.com/register, // (b) some other non-empty string, which cannot be interpreted as a web // URL, identifying the origin for non-aggregated data, or // (c) an empty string, indicating that the origin for this data is unknown. std::string origin_; // The number of times this model has been used. size_t use_count_; // The last time the model was used. base::Time use_date_; // The last time data in the model was modified. base::Time modification_date_; // Returns a score based on both the recency (relative to |time|) and // frequency for the model. The score is a negative number where a higher // value is more relevant. |time| is passed as a parameter to ensure // consistent results. double GetFrecencyScore(base::Time time) const; }; } // namespace autofill #endif // COMPONENTS_AUTOFILL_CORE_BROWSER_AUTOFILL_DATA_MODEL_H_