Fixed Package Control downloads support
This commit is contained in:
parent
6ac1ee40d8
commit
f35c86d5dc
56
server.js
56
server.js
|
@ -1211,16 +1211,13 @@ cache(function(data, match, sendBadge, request) {
|
||||||
}));
|
}));
|
||||||
|
|
||||||
// Package Control integration.
|
// Package Control integration.
|
||||||
camp.route(/^\/packagecontrol\/(.*)\.(svg|png|gif|jpg|json)$/,
|
camp.route(/^\/packagecontrol\/(dm|dw|dd|dt)\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||||
cache(function(data, match, sendBadge, request) {
|
cache(function(data, match, sendBadge, request) {
|
||||||
var userRepo = match[1]; // eg, `Package%20Control`.
|
var info = match[1]; // either `dm`, `dw`, `dd` or dt`.
|
||||||
var format = match[2];
|
var userRepo = match[2]; // eg, `Package%20Control`.
|
||||||
|
var format = match[3];
|
||||||
var apiUrl = 'https://packagecontrol.io/packages/' + userRepo + '.json';
|
var apiUrl = 'https://packagecontrol.io/packages/' + userRepo + '.json';
|
||||||
var badgeData = getBadgeData('downloads', data);
|
var badgeData = getBadgeData('downloads', data);
|
||||||
if (userRepo.substr(-14) === '/:package_name') {
|
|
||||||
badgeData.text[1] = 'invalid';
|
|
||||||
return sendBadge(format, badgeData);
|
|
||||||
}
|
|
||||||
request(apiUrl, function(err, res, buffer) {
|
request(apiUrl, function(err, res, buffer) {
|
||||||
if (err != null) {
|
if (err != null) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
|
@ -1228,10 +1225,47 @@ cache(function(data, match, sendBadge, request) {
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
|
var downloads = 0;
|
||||||
var downloads = data.package.installs.total;
|
switch (info.charAt(1)) {
|
||||||
badgeData.text[1] = metric(downloads) + ' total';
|
case 'm':
|
||||||
|
// daily downloads are separated by Operating System
|
||||||
|
var platforms = data.installs.daily.data;
|
||||||
|
platforms.forEach(function(platform) {
|
||||||
|
// loop through the first 30 days or 1 month
|
||||||
|
for (var i = 0; i < 30; i++) {
|
||||||
|
// add the downloads for that day for that platform
|
||||||
|
downloads += platform.totals[i];
|
||||||
|
}
|
||||||
|
});
|
||||||
|
badgeData.text[1] = metric(downloads) + '/month';
|
||||||
|
break;
|
||||||
|
case 'w':
|
||||||
|
// daily downloads are separated by Operating System
|
||||||
|
var platforms = data.installs.daily.data;
|
||||||
|
platforms.forEach(function(platform) {
|
||||||
|
// loop through the first 7 days or 1 week
|
||||||
|
for (var i = 0; i < 7; i++) {
|
||||||
|
// add the downloads for that day for that platform
|
||||||
|
downloads += platform.totals[i];
|
||||||
|
}
|
||||||
|
});
|
||||||
|
badgeData.text[1] = metric(downloads) + '/week';
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
// daily downloads are separated by Operating System
|
||||||
|
var platforms = data.installs.daily.data;
|
||||||
|
platforms.forEach(function(platform) {
|
||||||
|
// use the downloads from yesterday
|
||||||
|
downloads += platform.totals[1];
|
||||||
|
});
|
||||||
|
badgeData.text[1] = metric(downloads) + '/day';
|
||||||
|
break;
|
||||||
|
case 't':
|
||||||
|
// all-time downloads are already compiled
|
||||||
|
downloads = data.installs.total;
|
||||||
|
badgeData.text[1] = metric(downloads) + ' total';
|
||||||
|
break;
|
||||||
|
}
|
||||||
badgeData.colorscheme = downloadCountColor(downloads);
|
badgeData.colorscheme = downloadCountColor(downloads);
|
||||||
sendBadge(format, badgeData);
|
sendBadge(format, badgeData);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user