1f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// Copyright 2014 The Chromium Authors. All rights reserved.
2f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
3f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// found in the LICENSE file.
4f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
55f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)#ifndef COMPONENTS_SUGGESTIONS_SUGGESTIONS_STORE_H_
65f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)#define COMPONENTS_SUGGESTIONS_SUGGESTIONS_STORE_H_
7f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
8f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)#include "base/macros.h"
95f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)#include "components/suggestions/proto/suggestions.pb.h"
10f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
11f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)class PrefService;
12f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
13f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)namespace user_prefs {
14f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)class PrefRegistrySyncable;
15f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)}  // namespace user_prefs
16f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
17f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)namespace suggestions {
18f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
19f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// A helper class for reading and writing the suggestions to the profile's
20f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)// preference file.
21f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)class SuggestionsStore {
22f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles) public:
23f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  explicit SuggestionsStore(PrefService* profile_prefs);
24f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  virtual ~SuggestionsStore();
25f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
26f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // Loads the suggestion data from the profile's preferences into
27f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // |suggestions|. If there is a problem with loading, the pref value is
28f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // cleared, false is returned and |suggestions| is cleared. If successful,
29f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // |suggestions| will contain the loaded data and true is returned.
30f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  virtual bool LoadSuggestions(SuggestionsProfile* suggestions);
31f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
32f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // Stores the provided |suggestions| to the profile's preferences, using
33f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // a base64 encoding of its protobuf serialization.
34f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  virtual bool StoreSuggestions(const SuggestionsProfile& suggestions);
35f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
36f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // Clears any suggestion data from the profile's preferences.
37f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  virtual void ClearSuggestions();
38f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
39f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // Register SuggestionsStore related prefs in the Profile prefs.
40f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
41f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
42f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles) protected:
43f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // Test seam. For simplicity of mock creation.
44f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  SuggestionsStore() {}
45f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
46f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles) private:
47f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  // The pref service used to persist the suggestions data.
48f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  PrefService* pref_service_;
49f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
50f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)  DISALLOW_COPY_AND_ASSIGN(SuggestionsStore);
516e8cce623b6e4fe0c9e4af605d675dd9d0338c38Torne (Richard Coles)
526e8cce623b6e4fe0c9e4af605d675dd9d0338c38Torne (Richard Coles)  // Filters expired suggestions.
536e8cce623b6e4fe0c9e4af605d675dd9d0338c38Torne (Richard Coles)  void FilterExpiredSuggestions(SuggestionsProfile* suggestions);
54f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)};
55f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
56f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)}  // namespace suggestions
57f8ee788a64d60abd8f2d742a5fdedde054ecd910Torne (Richard Coles)
585f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)#endif  // COMPONENTS_SUGGESTIONS_SUGGESTIONS_STORE_H_
59