Left: | ||
Right: |
OLD | NEW |
---|---|
(Empty) | |
1 # coding: utf-8 | |
2 | |
3 # This file is part of the Adblock Plus web scripts, | |
4 # Copyright (C) 2006-2015 Eyeo GmbH | |
5 # | |
6 # Adblock Plus is free software: you can redistribute it and/or modify | |
7 # it under the terms of the GNU General Public License version 3 as | |
8 # published by the Free Software Foundation. | |
9 # | |
10 # Adblock Plus is distributed in the hope that it will be useful, | |
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
13 # GNU General Public License for more details. | |
14 # | |
15 # You should have received a copy of the GNU General Public License | |
16 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | |
17 | |
18 import json | |
19 import random | |
20 import time | |
21 from urlparse import parse_qs | |
22 | |
23 from sitescripts.notifications.parser import load_notifications | |
24 from sitescripts.web import url_handler | |
25 | |
26 def _assign_groups(notifications): | |
27 groups = [] | |
28 selection = random.random() | |
29 base = 0 | |
30 for notification in (x for x in notifications if "variants" in x): | |
Sebastian Noack
2015/04/20 14:44:39
Nit: Just continue the loop instead creating a gen
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
31 group = {"id": notification["id"], "variant": 0} | |
32 groups.append(group) | |
33 for i, variant in enumerate(notification["variants"]): | |
34 if group["variant"] != 0: | |
35 break | |
Sebastian Noack
2015/04/20 14:44:39
Please move the break below where you set variant
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
36 sample_size = variant["sample"] | |
37 if sample_size > 0 and base <= selection <= base + sample_size: | |
Sebastian Noack
2015/04/20 14:44:39
Nit: The logic of adding base + sample_size is dup
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
38 group["variant"] = i + 1 | |
39 base += sample_size | |
40 return groups | |
41 | |
42 def _create_response(notifications, groups): | |
43 response = { | |
44 "version": time.strftime("%Y%m%d%H%M", time.gmtime()) | |
45 } | |
46 for group in groups: | |
47 group_id = group["id"] | |
48 variant = group["variant"] | |
49 response["version"] += "-%s/%s" % (group_id, variant) | |
50 if variant > 0: | |
51 notification = next(x for x in notifications if x["id"] == group_id) | |
52 notification = notification.copy() | |
Sebastian Noack
2015/04/20 14:44:39
Note that this will be a shadow copy. To create de
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
53 notification.update(notification["variants"][variant - 1]) | |
54 for key_to_remove in ("sample", "variants"): | |
55 notification.pop(key_to_remove, None) | |
Sebastian Noack
2015/04/20 14:44:39
I don't mind, but if you prefer to merge the dicts
Felix Dahlke
2015/04/23 22:15:18
I know I specifically asked for a nicer way - but
| |
56 response["notifications"] = [notification] | |
57 if "notifications" not in response: | |
58 response["notifications"] = [x for x in notifications | |
59 if "variants" not in x] | |
60 return json.dumps(response, ensure_ascii=False, indent=2, | |
61 separators=(",", ": "), sort_keys=True) | |
62 | |
63 @url_handler("/notification.json") | |
64 def notification(environ, start_response): | |
65 params = parse_qs(environ.get("QUERY_STRING", "")) | |
66 version = params.get("lastVersion", [""])[0] | |
67 current_groups = dict(x.split("/") for x in version.split("-")[1:] | |
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
68 if "/" in x) | |
69 notifications = load_notifications() | |
70 groups = [] | |
71 for notification in (x for x in notifications if "variants" in x): | |
Sebastian Noack
2015/04/20 14:44:39
See above.
Felix Dahlke
2015/04/23 22:15:18
Done.
| |
72 group_id = notification["id"] | |
73 if group_id in current_groups: | |
74 groups.append({"id": group_id, "variant": int(current_groups[group_id])}) | |
75 if not groups: | |
76 groups = _assign_groups(notifications) | |
77 response = _create_response(notifications, groups) | |
78 start_response("200 OK", [("Content-Type", "application/json")]) | |
Sebastian Noack
2015/04/20 14:44:39
Please send response charset.
Felix Dahlke
2015/04/23 22:15:18
UTF-8 is default for JSON. However, as discussed w
| |
79 return response.encode("utf-8") | |
OLD | NEW |