Left: | ||
Right: |
OLD | NEW |
---|---|
1 /* | 1 /* |
2 * This file is part of Adblock Plus <http://adblockplus.org/>, | 2 * This file is part of Adblock Plus <http://adblockplus.org/>, |
3 * Copyright (C) 2006-2014 Eyeo GmbH | 3 * Copyright (C) 2006-2014 Eyeo GmbH |
4 * | 4 * |
5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
8 * | 8 * |
9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
12 * GNU General Public License for more details. | 12 * GNU General Public License for more details. |
13 * | 13 * |
14 * You should have received a copy of the GNU General Public License | 14 * You should have received a copy of the GNU General Public License |
15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
16 */ | 16 */ |
17 | 17 |
18 #ifndef ADBLOCK_PLUS_REFERRER_MAPPING_H | 18 #ifndef ADBLOCK_PLUS_REFERRER_MAPPING_H |
19 #define ADBLOCK_PLUS_REFERRER_MAPPING_H | 19 #define ADBLOCK_PLUS_REFERRER_MAPPING_H |
20 | 20 |
21 #include <list> | 21 #include <list> |
22 #include <map> | 22 #include <map> |
23 #include <string> | 23 #include <string> |
24 #include <vector> | 24 #include <vector> |
25 | 25 |
26 namespace AdblockPlus | 26 namespace AdblockPlus |
27 { | 27 { |
28 /** | |
29 * Stores a mapping between URLs and their referrers. | |
30 * This can be used to build a chain of referrers for any URL | |
31 * (see `BuildReferrerChain()`), which approximates the frame structure. | |
32 */ | |
28 class ReferrerMapping | 33 class ReferrerMapping |
29 { | 34 { |
30 public: | 35 public: |
36 /** | |
37 * Constructor. | |
38 * @param maxCachedUrls Number of URL mappings to store. The higher the | |
39 * better - clients typically cache requests, and a single cached | |
40 * request will break the referrer chain. | |
41 */ | |
31 ReferrerMapping(const int maxCachedUrls = 5000); | 42 ReferrerMapping(const int maxCachedUrls = 5000); |
43 | |
44 /** | |
45 * Adds a new mapping from URL to referrer. | |
Wladimir Palant
2014/08/29 18:42:27
"Records the referrer for a URL"?
Felix Dahlke
2014/09/01 17:00:15
Done.
| |
46 * @param url Request URL. | |
47 * @param referrer Request referrer. | |
48 */ | |
32 void Add(const std::string& url, const std::string& referrer); | 49 void Add(const std::string& url, const std::string& referrer); |
50 | |
51 /** | |
52 * Builds the referrer chain for the supplied URL. | |
Wladimir Palant
2014/08/29 18:42:27
"Reconstructs the URLs of parent frames for a docu
| |
53 * @param url URL to build the chain for. | |
54 * @return List of URLs, starting with `url`. | |
55 */ | |
33 std::vector<std::string> BuildReferrerChain(const std::string& url) const; | 56 std::vector<std::string> BuildReferrerChain(const std::string& url) const; |
34 | 57 |
35 private: | 58 private: |
36 const int maxCachedUrls; | 59 const int maxCachedUrls; |
37 std::map<std::string, std::string> mapping; | 60 std::map<std::string, std::string> mapping; |
38 std::list<std::string> cachedUrls; | 61 std::list<std::string> cachedUrls; |
39 }; | 62 }; |
40 } | 63 } |
41 | 64 |
42 #endif | 65 #endif |
OLD | NEW |