Add apm support
This commit is contained in:
parent
6d008dd942
commit
16c930cc1d
80
server.js
80
server.js
|
@ -2613,6 +2613,86 @@ cache(function(data, match, sendBadge, request) {
|
|||
});
|
||||
}));
|
||||
|
||||
// apm download integration.
|
||||
camp.route(/^\/apm\/dm\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||
cache(function(data, match, sendBadge, request) {
|
||||
var repo = match[1]; // eg, `vim-mode`.
|
||||
var format = match[2];
|
||||
var apiUrl = 'https://atom.io/api/packages/' + repo;
|
||||
var badgeData = getBadgeData('downloads', data);
|
||||
request(apiUrl, function(err, res, buffer) {
|
||||
if (err != null) {
|
||||
badgeData.text[1] = 'inaccessible';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
try {
|
||||
var dls = JSON.parse(buffer).downloads;
|
||||
} catch(e) {
|
||||
badgeData.text[1] = 'invalid';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
badgeData.text[1] = metric(dls) + ' total';
|
||||
badgeData.colorscheme = 'green';
|
||||
sendBadge(format, badgeData);
|
||||
});
|
||||
}));
|
||||
|
||||
// apm version integration.
|
||||
camp.route(/^\/apm\/v\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||
cache(function(data, match, sendBadge, request) {
|
||||
var repo = match[1]; // eg, `vim-mode`.
|
||||
var format = match[2];
|
||||
var apiUrl = 'https://atom.io/api/packages/' + repo;
|
||||
var badgeData = getBadgeData('apm', data);
|
||||
request(apiUrl, function(err, res, buffer) {
|
||||
if (err != null) {
|
||||
badgeData.text[1] = 'inaccessible';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
try {
|
||||
var releases = JSON.parse(buffer).releases;
|
||||
var version = releases.latest;
|
||||
} catch(e) {
|
||||
badgeData.text[1] = 'invalid';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
badgeData.text[1] = 'v' + version;
|
||||
badgeData.colorscheme = 'green';
|
||||
sendBadge(format, badgeData);
|
||||
});
|
||||
}));
|
||||
|
||||
// apm license integration.
|
||||
camp.route(/^\/apm\/l\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||
cache(function(data, match, sendBadge, request) {
|
||||
var repo = match[1]; // eg, `vim-mode`.
|
||||
var format = match[2];
|
||||
var apiUrl = 'https://atom.io/api/packages/' + repo;
|
||||
var badgeData = getBadgeData('license', data);
|
||||
request(apiUrl, function(err, res, buffer) {
|
||||
if (err != null) {
|
||||
badgeData.text[1] = 'inaccessible';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
try {
|
||||
var metadata = JSON.parse(buffer).metadata;
|
||||
var license = metadata.license;
|
||||
} catch(e) {
|
||||
badgeData.text[1] = 'invalid';
|
||||
sendBadge(format, badgeData);
|
||||
return;
|
||||
}
|
||||
badgeData.text[1] = license;
|
||||
badgeData.colorscheme = 'red';
|
||||
sendBadge(format, badgeData);
|
||||
});
|
||||
}));
|
||||
|
||||
// Any badge.
|
||||
camp.route(/^\/(:|badge\/)(([^-]|--)+)-(([^-]|--)+)-(([^-]|--)+)\.(svg|png|gif|jpg)$/,
|
||||
function(data, match, end, ask) {
|
||||
|
|
12
try.html
12
try.html
|
@ -244,6 +244,10 @@ When that is implemented, change the placeholder to
|
|||
<td><img src='/sourceforge/dt/sevenzip.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/sourceforge/dt/sevenzip.svg</code></td>
|
||||
</tr>
|
||||
<tr><th data-keywords='atom'> apm: </th>
|
||||
<td><img src='/apm/dm/vim-mode.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/apm/dm/vim-mode.svg</code></td>
|
||||
</tr>
|
||||
</tbody></table>
|
||||
<h3> Version </h3>
|
||||
<table class='badge'><tbody>
|
||||
|
@ -339,6 +343,10 @@ When that is implemented, change the placeholder to
|
|||
<td><img src='/wordpress/v/akismet.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/wordpress/v/akismet.svg</code></td>
|
||||
</tr>
|
||||
<tr><th data-keywords='atom'> apm: </th>
|
||||
<td><img src='/apm/v/vim-mode.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/apm/v/vim-mode.svg</code></td>
|
||||
</tr>
|
||||
</tbody></table>
|
||||
|
||||
<h3> Miscellaneous </h3>
|
||||
|
@ -395,6 +403,10 @@ When that is implemented, change the placeholder to
|
|||
<td><img src='/npm/l/express.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/npm/l/express.svg</code></td>
|
||||
</tr>
|
||||
<tr><th data-keywords='atom'> apm: </th>
|
||||
<td><img src='/apm/l/vim-mode.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/apm/l/vim-mode.svg</code></td>
|
||||
</tr>
|
||||
<tr><th> PyPI: </th>
|
||||
<td><img src='/pypi/l/Django.svg' alt=''/></td>
|
||||
<td><code>https://img.shields.io/pypi/l/Django.svg</code></td>
|
||||
|
|
Loading…
Reference in New Issue
Block a user