Left: | ||
Right: |
OLD | NEW |
---|---|
(Empty) | |
1 /* | |
2 * This file is part of Adblock Plus <http://adblockplus.org/>, | |
3 * Copyright (C) 2006-2013 Eyeo GmbH | |
4 * | |
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 | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * Adblock Plus is distributed in the hope that it will be useful, | |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 * GNU General Public License for more details. | |
13 * | |
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/>. | |
16 */ | |
17 | |
18 let {Prefs} = require("prefs"); | |
19 let updateUrl = (_appInfo.developmentBuild ? Prefs.update_url_devbuild : Prefs.u pdate_url_release); | |
20 updateUrl = updateUrl.replace(/%NAME%/g, encodeURIComponent(_appInfo.name)) | |
21 .replace(/%ID%/g, encodeURIComponent(_appInfo.id)) | |
22 .replace(/%VERSION%/g, encodeURIComponent(_appInfo.version) ) | |
23 .replace(/%APP%/g, encodeURIComponent(_appInfo.platform)); | |
24 | |
25 const HOURS_TO_MILLIS = 60 * 60 * 1000; | |
Felix Dahlke
2013/06/05 15:47:36
Would call that "MILLIS_PER_HOUR" but it really do
Wladimir Palant
2013/06/05 18:58:21
It's a multiplication factor :)
| |
26 const MIN_CHECK_INTERVAL = 18 * HOURS_TO_MILLIS; | |
27 const MAX_CHECK_INTERVAL = 30 * HOURS_TO_MILLIS; | |
28 | |
29 const TYPE_AUTOMATIC = 0; | |
30 const TYPE_MANUAL = 1; | |
31 | |
32 let checkForUpdates = exports.checkForUpdates = function checkForUpdates(forceCh eck, callback) | |
33 { | |
34 let now = Date.now(); | |
35 if (!forceCheck && now < Prefs.next_update_check) | |
36 { | |
37 if (Prefs.next_update_check - now > MAX_CHECK_INTERVAL) | |
Felix Dahlke
2013/06/05 15:47:36
I'm wondering what could cause this. If it's just
Wladimir Palant
2013/06/05 18:58:21
Clocks can be off a lot - and sometimes they are c
| |
38 Prefs.next_update_check = now + MAX_CHECK_INTERVAL; | |
39 | |
40 window.setTimeout(checkForUpdates, Prefs.next_update_check - now); | |
41 return; | |
42 } | |
43 | |
44 Prefs.next_update_check = now + MIN_CHECK_INTERVAL + | |
45 Math.random() * (MAX_CHECK_INTERVAL - MIN_CHECK_INTERVAL); | |
46 if (!forceCheck) | |
47 window.setTimeout(checkForUpdates, Prefs.next_update_check - now); | |
48 | |
49 let url = updateUrl.replace(/%TYPE%/g, forceCheck ? TYPE_MANUAL : TYPE_AUTOMAT IC); | |
50 let request = new XMLHttpRequest(); | |
51 request.open("GET", url); | |
52 request.addEventListener("load", function() | |
53 { | |
54 try | |
55 { | |
56 let data = JSON.parse(request.responseText); | |
57 let updateInfo = null; | |
58 if (_appInfo.name in data) | |
59 updateInfo = data[_appInfo.name]; | |
60 else if (_appInfo.name + "/" + _appInfo.platform in data) | |
61 updateInfo = data[_appInfo.name + "/" + _appInfo.platform]; | |
62 | |
63 if (updateInfo && "version" in updateInfo && "url" in updateInfo && | |
64 Services.vc.compare(updateInfo.version, _appInfo.version) > 0) | |
65 { | |
66 if (updateInfo.url.indexOf("https://") != 0) | |
67 throw new Error("Invalid update URL, HTTPS is mandatory for updates"); | |
Felix Dahlke
2013/06/05 15:47:36
Should we really hard code that? What's the proble
Wladimir Palant
2013/06/05 18:58:21
Yes, we should make very sure that we secure updat
| |
68 _triggerEvent("updateAvailable", updateInfo.url); | |
69 } | |
70 if (callback) | |
71 callback(null); | |
72 } | |
73 catch (e) | |
74 { | |
75 Cu.reportError(e); | |
76 if (callback) | |
77 callback(e); | |
78 } | |
79 }, false); | |
80 | |
81 request.addEventListener("error", function() | |
82 { | |
83 let e = new Error("Update check failed (channel status " + request.channel.s tatus + ")"); | |
84 Cu.reportError(e); | |
85 if (callback) | |
86 callback(e); | |
87 }, false); | |
88 | |
89 request.send(null); | |
90 } | |
91 | |
92 window.setTimeout(checkForUpdates, 0.1 * HOURS_TO_MILLIS); | |
OLD | NEW |