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.
5 #ifndef COMPONENTS_SUGGESTIONS_BLACKLIST_STORE_H_
6 #define COMPONENTS_SUGGESTIONS_BLACKLIST_STORE_H_
8 #include "base/macros.h"
9 #include "components/suggestions/proto/suggestions.pb.h"
14 namespace user_prefs
{
15 class PrefRegistrySyncable
;
16 } // namespace user_prefs
18 namespace suggestions
{
20 // A helper class for reading, writing and modifying a small blacklist stored
21 // in the Profile preferences. It also handles SuggestionsProfile
22 // filtering based on the stored blacklist.
23 class BlacklistStore
{
25 explicit BlacklistStore(PrefService
* profile_prefs
);
26 virtual ~BlacklistStore();
28 // Returns true if successful or |url| was already in the blacklist.
29 virtual bool BlacklistUrl(const GURL
& url
);
31 // Sets |url| to the first URL from the blacklist. Returns false if the
32 // blacklist is empty.
33 virtual bool GetFirstUrlFromBlacklist(GURL
* url
);
35 // Removes |url| from the stored blacklist. Returns true if successful or if
36 // |url| is not in the blacklist.
37 virtual bool RemoveUrl(const GURL
& url
);
39 // Applies the blacklist to |suggestions|.
40 virtual void FilterSuggestions(SuggestionsProfile
* suggestions
);
42 // Register BlacklistStore related prefs in the Profile prefs.
43 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable
* registry
);
46 // Test seam. For simplicity of mock creation.
49 // Loads the blacklist data from the Profile preferences into
50 // |blacklist|. If there is a problem with loading, the pref value is
51 // cleared, false is returned and |blacklist| is cleared. If successful,
52 // |blacklist| will contain the loaded data and true is returned.
53 bool LoadBlacklist(SuggestionsBlacklist
* blacklist
);
55 // Stores the provided |blacklist| to the Profile preferences, using
56 // a base64 encoding of its protobuf serialization.
57 bool StoreBlacklist(const SuggestionsBlacklist
& blacklist
);
59 // Clears any blacklist data from the profile's preferences.
60 void ClearBlacklist();
63 // The pref service used to persist the suggestions blacklist.
64 PrefService
* pref_service_
;
66 DISALLOW_COPY_AND_ASSIGN(BlacklistStore
);
69 } // namespace suggestions
71 #endif // COMPONENTS_SUGGESTIONS_BLACKLIST_STORE_H_