Add hex.pm support
This commit is contained in:
parent
f7ee1cb71a
commit
cfe4abd495
21
index.html
21
index.html
|
@ -131,6 +131,10 @@ I made the GitHub Badge Service.
|
|||
<td><img src='//img.shields.io/pypi/l/Django.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/pypi/l/Django.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hex.pm: </th>
|
||||
<td><img src='//img.shields.io/hexpm/l/poolboy.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hexpm/l/poolboy.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> CocoaPods: </th>
|
||||
<td><img src='//img.shields.io/cocoapods/l/AFNetworking.svg' alt='' /></td>
|
||||
<td><code>http://img.shields.io/cocoapods/l/AFNetworking.svg</code></td>
|
||||
|
@ -227,6 +231,18 @@ I made the GitHub Badge Service.
|
|||
<td><img src='//img.shields.io/pypi/dd/Django.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/pypi/dd/Django.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hex.pm: </th>
|
||||
<td><img src='//img.shields.io/hexpm/dw/plug.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hexpm/dw/plug.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hex.pm: </th>
|
||||
<td><img src='//img.shields.io/hexpm/dd/plug.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hexpm/dd/plug.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hex.pm: </th>
|
||||
<td><img src='//img.shields.io/hexpm/dt/plug.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hexpm/dt/plug.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Packagist: </th>
|
||||
<td><img src='//img.shields.io/packagist/dm/doctrine/orm.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/packagist/dm/doctrine/orm.svg</code></td>
|
||||
|
@ -253,6 +269,11 @@ I made the GitHub Badge Service.
|
|||
<tr><th> Gem: </th>
|
||||
<td><img src='//img.shields.io/gem/v/formatador.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/gem/v/formatador.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hex.pm: </th>
|
||||
<td><img src='//img.shields.io/hexpm/v/plug.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hexpm/v/plug.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> Hackage: </th>
|
||||
<td><img src='//img.shields.io/hackage/v/lens.svg' alt=''/></td>
|
||||
<td><code>http://img.shields.io/hackage/v/lens.svg</code></td>
|
||||
|
|
61
server.js
61
server.js
|
@ -754,6 +754,67 @@ cache(function(data, match, sendBadge) {
|
|||
});
|
||||
}));
|
||||
|
||||
// Hex.pm integration.
|
||||
camp.route(/^\/hexpm\/([^\/]+)\/(.*)\.(svg|png|gif|jpg)$/,
|
||||
cache(function(data, match, sendBadge) {
|
||||
var info = match[1];
|
||||
var repo = match[2]; // eg, `httpotion`.
|
||||
var format = match[3];
|
||||
var apiUrl = 'https://hex.pm/api/packages/' + repo;
|
||||
var badgeData = getBadgeData('hexpm', data);
|
||||
request(apiUrl, function(err, res, buffer) {
|
||||
if (err != null) {
|
||||
badgeData.text[1] = 'inaccessible';
|
||||
sendBadge(format, badgeData);
|
||||
}
|
||||
try {
|
||||
var data = JSON.parse(buffer);
|
||||
if (info.charAt(0) === 'd') {
|
||||
badgeData.text[0] = getLabel('downloads', data);
|
||||
switch (info.charAt(1)) {
|
||||
case 'w':
|
||||
var downloads = data.downloads.week;
|
||||
badgeData.text[1] = metric(downloads) + '/week';
|
||||
break;
|
||||
case 'd':
|
||||
var downloads = data.downloads.day;
|
||||
badgeData.text[1] = metric(downloads) + '/day';
|
||||
break;
|
||||
case 't':
|
||||
var downloads = data.downloads.all;
|
||||
badgeData.text[1] = metric(downloads) + ' total';
|
||||
break;
|
||||
}
|
||||
badgeData.colorscheme = downloadCountColor(downloads);
|
||||
sendBadge(format, badgeData);
|
||||
} else if (info === 'v') {
|
||||
var version = data.releases[0].version;
|
||||
badgeData.text[1] = 'v' + version;
|
||||
if (version[0] === '0' || /dev/.test(version)) {
|
||||
badgeData.colorscheme = 'orange';
|
||||
} else {
|
||||
badgeData.colorscheme = 'blue';
|
||||
}
|
||||
sendBadge(format, badgeData);
|
||||
} else if (info == 'l') {
|
||||
var license = (data.meta.licenses || []).join(', ');
|
||||
badgeData.text[0] = 'license';
|
||||
if ((data.meta.licenses || []).length > 1) badgeData.text[0] += 's';
|
||||
if(license == '') {
|
||||
badgeData.text[1] = 'Unknown';
|
||||
} else {
|
||||
badgeData.text[1] = license;
|
||||
badgeData.colorscheme = 'red';
|
||||
}
|
||||
sendBadge(format, badgeData);
|
||||
}
|
||||
} catch(e) {
|
||||
badgeData.text[1] = 'invalid';
|
||||
sendBadge(format, badgeData);
|
||||
}
|
||||
});
|
||||
}));
|
||||
|
||||
// Coveralls integration.
|
||||
camp.route(/^\/coveralls\/([^\/]+\/[^\/]+)(?:\/(.+))?\.(svg|png|gif|jpg)$/,
|
||||
cache(function(data, match, sendBadge) {
|
||||
|
|
Loading…
Reference in New Issue
Block a user