update gem downloads badge

This commit is contained in:
bogdanRada 2014-07-14 11:17:46 +03:00
parent 393bb4768d
commit d42a7162de
2 changed files with 38 additions and 27 deletions

View File

@ -140,6 +140,8 @@ function cache(f) {
return function getRequest(data, match, end, ask) {
// Cache management - no cache, so it won't be cached by GitHub's CDN.
ask.res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate');
ask.res.setHeader("Pragma", "no-cache"); // HTTP 1.0.
ask.res.setHeader("Expires", -1); // Proxies.
incrMonthlyAnalytics(analytics.vendorMonthly);
if (data.style === 'flat') {
try {
@ -588,8 +590,35 @@ cache(function(data, match, sendBadge) {
});
}));
// Gem download count integration.
camp.route(/^\/gem\/dc\/(.*)\.(svg|png|gif|jpg)$/,
// Gem download count for latest version.
camp.route(/^\/gem\/dtv\/(.*)\.(svg|png|gif|jpg)$/,
cache(function(data, match, sendBadge) {
var repo= match[1];
var format = match[2];
var apiUrl = 'https://rubygems.org/api/v1/gems/' + repo + '.json';
var badgeData = getBadgeData('downloads', data);
request(apiUrl, { headers: { 'Accept': 'application/atom+json,application/json' } }, function(err, res, buffer) {
if (err != null) {
badgeData.text[1] = 'inaccessible';
sendBadge(format, badgeData);
}
try {
var data = JSON.parse(buffer);
var downloads = data.version_downloads;
badgeData.text[1] = metric(downloads);
badgeData.text[1] = badgeData.text[1] + ' latest version';
badgeData.colorscheme = downloadCountColor(downloads);
sendBadge(format, badgeData);
} catch(e) {
badgeData.text[1] = 'invalid';
sendBadge(format, badgeData);
}
});
}));
// Gem total download count
camp.route(/^\/gem\/dt\/(.*)\.(svg|png|gif|jpg)$/,
cache(function(data, match, sendBadge) {
var site = match[1];
var repo = site.split('/')[0];
@ -604,18 +633,9 @@ cache(function(data, match, sendBadge) {
}
try {
var data = JSON.parse(buffer);
var downloads = 0;
if (typeof (downloads_type) !== "undefined" && downloads_type === "total") {
downloads = data.downloads;
}
else{
downloads = data.version_downloads;
}
badgeData.text[1] = number_with_delimiter(downloads);
if (typeof(downloads_type) !== "undefined" && downloads_type === "total" )
{
badgeData.text[1] = badgeData.text[1] + ' total';
}
var downloads = data.downloads;
badgeData.text[1] = metric(downloads);
badgeData.text[1] = badgeData.text[1] + ' total';
badgeData.colorscheme = downloadCountColor(downloads);
sendBadge(format, badgeData);
} catch(e) {
@ -1447,15 +1467,6 @@ function metric(n) {
return ''+n;
}
function number_with_delimiter (number, delimiter) {
var number = number + '', delimiter = delimiter || ',';
var split = number.split('.');
split[0] = split[0].replace(
/(\d)(?=(\d\d\d)+(?!\d))/g,
'$1' + delimiter
);
return split.join('.');
};
function coveragePercentageColor(percentage) {
if (percentage < 80) {

View File

@ -168,12 +168,12 @@ I made the GitHub Badge Service.
<h3> Downloads </h3>
<table><tbody>
<tr><th> Gem </th>
<td><img src='/gem/dc/rails.svg' alt=''/></td>
<td><code>http://img.shields.io/gem/dc/rails.svg</code></td>
<td><img src='/gem/dtv/rails.svg' alt=''/></td>
<td><code>http://img.shields.io/gem/dtv/rails.svg</code></td>
</tr>
<tr><th> Gem </th>
<td><img src='/gem/dc/rails/total.svg' alt=''/></td>
<td><code>http://img.shields.io/gem/dc/rails/total.svg</code></td>
<td><img src='/gem/dt/rails.svg' alt=''/></td>
<td><code>http://img.shields.io/gem/dt/rails.svg</code></td>
</tr>
<tr><th> npm: </th>
<td><img src='/npm/dm/localeval.svg' alt=''/></td>