Server cache for 1 minute.
This commit is contained in:
parent
2b40bec6dc
commit
21bec1cbfd
143
server.js
143
server.js
|
@ -7,9 +7,36 @@ var badge = require('./badge.js');
|
||||||
var svg2img = require('./svg-to-img.js');
|
var svg2img = require('./svg-to-img.js');
|
||||||
var serverStartTime = new Date((new Date()).toGMTString());
|
var serverStartTime = new Date((new Date()).toGMTString());
|
||||||
|
|
||||||
|
// Cache
|
||||||
|
|
||||||
|
var cacheTimeout = 60000; // 1 minute.
|
||||||
|
var cacheFromIndex = Object.create(null);
|
||||||
|
|
||||||
|
function cache(f) {
|
||||||
|
return function getRequest(data, match, end, ask) {
|
||||||
|
var cacheIndex = match[0] + '?label=' + data.label;
|
||||||
|
// Should we return the data right away?
|
||||||
|
var cached = cacheFromIndex[cacheIndex];
|
||||||
|
if (cached != null) {
|
||||||
|
badge(cached.badgeData, makeSend(cached.format, ask.res, end));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
f(data, match, function sendBadge(format, badgeData) {
|
||||||
|
cacheFromIndex[cacheIndex] = { format: format, badgeData: badgeData };
|
||||||
|
setTimeout(function clearCache() {
|
||||||
|
delete cacheFromIndex[cacheIndex];
|
||||||
|
}, cacheTimeout);
|
||||||
|
badge(badgeData, makeSend(format, ask.res, end));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vendors.
|
||||||
|
|
||||||
// Travis integration
|
// Travis integration
|
||||||
camp.route(/^\/travis(-ci)?\/([^\/]+\/[^\/]+)(?:\/(.+))?\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/travis(-ci)?\/([^\/]+\/[^\/]+)(?:\/(.+))?\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[2];
|
var userRepo = match[2];
|
||||||
var branch = match[3];
|
var branch = match[3];
|
||||||
var format = match[4];
|
var format = match[4];
|
||||||
|
@ -29,12 +56,12 @@ function(data, match, end, ask) {
|
||||||
.match(/filename="(.+)\.png"/);
|
.match(/filename="(.+)\.png"/);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'not found';
|
badgeData.text[1] = 'not found';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!statusMatch) {
|
if (!statusMatch) {
|
||||||
badgeData.text[1] = 'unknown';
|
badgeData.text[1] = 'unknown';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var state = statusMatch[1];
|
var state = statusMatch[1];
|
||||||
|
@ -44,18 +71,18 @@ function(data, match, end, ask) {
|
||||||
} else if (state === 'failing') {
|
} else if (state === 'failing') {
|
||||||
badgeData.colorscheme = 'red';
|
badgeData.colorscheme = 'red';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.on('error', function(e) {
|
req.on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.end();
|
req.end();
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Gittip integration.
|
// Gittip integration.
|
||||||
camp.route(/^\/gittip\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/gittip\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var user = match[1]; // eg, `JSFiddle`.
|
var user = match[1]; // eg, `JSFiddle`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var apiUrl = 'https://www.gittip.com/' + user + '/public.json';
|
var apiUrl = 'https://www.gittip.com/' + user + '/public.json';
|
||||||
|
@ -77,7 +104,7 @@ function(data, match, end, ask) {
|
||||||
var money = parseInt(data.receiving);
|
var money = parseInt(data.receiving);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = '$' + metric(money) + '/week';
|
badgeData.text[1] = '$' + metric(money) + '/week';
|
||||||
|
@ -90,17 +117,17 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'green';
|
badgeData.colorscheme = 'green';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Packagist integration.
|
// Packagist integration.
|
||||||
camp.route(/^\/packagist\/dm\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/packagist\/dm\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[1]; // eg, `doctrine/orm`.
|
var userRepo = match[1]; // eg, `doctrine/orm`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var apiUrl = 'https://packagist.org/packages/' + userRepo + '.json';
|
var apiUrl = 'https://packagist.org/packages/' + userRepo + '.json';
|
||||||
|
@ -116,7 +143,7 @@ function(data, match, end, ask) {
|
||||||
var monthly = data.package.downloads.monthly;
|
var monthly = data.package.downloads.monthly;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = metric(monthly) + '/month';
|
badgeData.text[1] = metric(monthly) + '/month';
|
||||||
|
@ -131,17 +158,17 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'brightgreen';
|
badgeData.colorscheme = 'brightgreen';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// NPM integration.
|
// NPM integration.
|
||||||
camp.route(/^\/npm\/dm\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/npm\/dm\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var user = match[1]; // eg, `localeval`.
|
var user = match[1]; // eg, `localeval`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var apiUrl = 'http://isaacs.iriscouch.com/downloads/_design/app/_view/pkg?group_level=2&start_key=["' + user + '"]&end_key=["' + user + '",{}]';
|
var apiUrl = 'http://isaacs.iriscouch.com/downloads/_design/app/_view/pkg?group_level=2&start_key=["' + user + '"]&end_key=["' + user + '",{}]';
|
||||||
|
@ -169,7 +196,7 @@ function(data, match, end, ask) {
|
||||||
}
|
}
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = metric(monthly) + '/month';
|
badgeData.text[1] = metric(monthly) + '/month';
|
||||||
|
@ -184,17 +211,17 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'brightgreen';
|
badgeData.colorscheme = 'brightgreen';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// NPM version integration.
|
// NPM version integration.
|
||||||
camp.route(/^\/npm\/v\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/npm\/v\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var repo = match[1]; // eg, `localeval`.
|
var repo = match[1]; // eg, `localeval`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var apiUrl = 'https://registry.npmjs.org/' + repo + '/latest';
|
var apiUrl = 'https://registry.npmjs.org/' + repo + '/latest';
|
||||||
|
@ -210,7 +237,7 @@ function(data, match, end, ask) {
|
||||||
var version = data.version;
|
var version = data.version;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = 'v' + version;
|
badgeData.text[1] = 'v' + version;
|
||||||
|
@ -219,17 +246,17 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'blue';
|
badgeData.colorscheme = 'blue';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Gem version integration.
|
// Gem version integration.
|
||||||
camp.route(/^\/gem\/v\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/gem\/v\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var repo = match[1]; // eg, `localeval`.
|
var repo = match[1]; // eg, `localeval`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var apiUrl = 'https://rubygems.org/api/v1/gems/' + repo + '.json';
|
var apiUrl = 'https://rubygems.org/api/v1/gems/' + repo + '.json';
|
||||||
|
@ -245,7 +272,7 @@ function(data, match, end, ask) {
|
||||||
var version = data.version;
|
var version = data.version;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = 'v' + version;
|
badgeData.text[1] = 'v' + version;
|
||||||
|
@ -254,17 +281,17 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'blue';
|
badgeData.colorscheme = 'blue';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// PyPI integration.
|
// PyPI integration.
|
||||||
camp.route(/^\/pypi\/([^\/]+)\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/pypi\/([^\/]+)\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var info = match[1];
|
var info = match[1];
|
||||||
var egg = match[2]; // eg, `gevent`.
|
var egg = match[2]; // eg, `gevent`.
|
||||||
var format = match[3];
|
var format = match[3];
|
||||||
|
@ -280,7 +307,7 @@ function(data, match, end, ask) {
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (info === 'dm') {
|
if (info === 'dm') {
|
||||||
|
@ -289,7 +316,7 @@ function(data, match, end, ask) {
|
||||||
var monthly = data.info.downloads.last_month;
|
var monthly = data.info.downloads.last_month;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = metric(monthly) + '/month';
|
badgeData.text[1] = metric(monthly) + '/month';
|
||||||
|
@ -304,13 +331,13 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'brightgreen';
|
badgeData.colorscheme = 'brightgreen';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
} else if (info === 'v') {
|
} else if (info === 'v') {
|
||||||
try {
|
try {
|
||||||
var version = data.info.version;
|
var version = data.info.version;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = 'v' + version;
|
badgeData.text[1] = 'v' + version;
|
||||||
|
@ -319,18 +346,18 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'blue';
|
badgeData.colorscheme = 'blue';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Coveralls integration.
|
// Coveralls integration.
|
||||||
camp.route(/^\/coveralls\/([^\/]+\/[^\/]+)(?:\/(.+))?\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/coveralls\/([^\/]+\/[^\/]+)(?:\/(.+))?\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[1]; // eg, `jekyll/jekyll`.
|
var userRepo = match[1]; // eg, `jekyll/jekyll`.
|
||||||
var branch = match[2];
|
var branch = match[2];
|
||||||
var format = match[3];
|
var format = match[3];
|
||||||
|
@ -345,7 +372,7 @@ function(data, match, end, ask) {
|
||||||
var buffer = res.headers.location;
|
var buffer = res.headers.location;
|
||||||
if (!buffer) {
|
if (!buffer) {
|
||||||
badgeData.text[1] = 'invalid';
|
badgeData.text[1] = 'invalid';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
|
@ -354,12 +381,12 @@ function(data, match, end, ask) {
|
||||||
if (percentage !== percentage) {
|
if (percentage !== percentage) {
|
||||||
// It is NaN, treat it as unknown.
|
// It is NaN, treat it as unknown.
|
||||||
badgeData.text[1] = 'unknown';
|
badgeData.text[1] = 'unknown';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'malformed';
|
badgeData.text[1] = 'malformed';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
badgeData.text[1] = score + '%';
|
badgeData.text[1] = score + '%';
|
||||||
|
@ -370,16 +397,16 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'green';
|
badgeData.colorscheme = 'green';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
}).on('error', function(e) {
|
}).on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Code Climate integration
|
// Code Climate integration
|
||||||
camp.route(/^\/codeclimate\/(.+)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/codeclimate\/(.+)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[1]; // eg, `github/kabisaict/flow`.
|
var userRepo = match[1]; // eg, `github/kabisaict/flow`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var options = {
|
var options = {
|
||||||
|
@ -395,12 +422,12 @@ function(data, match, end, ask) {
|
||||||
.match(/filename="code_climate-(.+)\.png"/);
|
.match(/filename="code_climate-(.+)\.png"/);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'not found';
|
badgeData.text[1] = 'not found';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!statusMatch) {
|
if (!statusMatch) {
|
||||||
badgeData.text[1] = 'unknown';
|
badgeData.text[1] = 'unknown';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var state = statusMatch[1].replace('-', '.');
|
var state = statusMatch[1].replace('-', '.');
|
||||||
|
@ -417,18 +444,18 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'red';
|
badgeData.colorscheme = 'red';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.on('error', function(e) {
|
req.on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.end();
|
req.end();
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Code Climate integration
|
// Code Climate integration
|
||||||
camp.route(/^\/gemnasium\/(.+)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/gemnasium\/(.+)\.(svg|png|gif|jpg)$/,
|
||||||
function(data, match, end, ask) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[1]; // eg, `jekyll/jekyll`.
|
var userRepo = match[1]; // eg, `jekyll/jekyll`.
|
||||||
var format = match[2];
|
var format = match[2];
|
||||||
var options = {
|
var options = {
|
||||||
|
@ -444,12 +471,12 @@ function(data, match, end, ask) {
|
||||||
.match(/filename="(.+)\.png"/);
|
.match(/filename="(.+)\.png"/);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
badgeData.text[1] = 'not found';
|
badgeData.text[1] = 'not found';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!statusMatch) {
|
if (!statusMatch) {
|
||||||
badgeData.text[1] = 'unknown';
|
badgeData.text[1] = 'unknown';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Either `dev-yellow` or `yellow`.
|
// Either `dev-yellow` or `yellow`.
|
||||||
|
@ -471,14 +498,14 @@ function(data, match, end, ask) {
|
||||||
} else {
|
} else {
|
||||||
badgeData.text[1] = 'undefined';
|
badgeData.text[1] = 'undefined';
|
||||||
}
|
}
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.on('error', function(e) {
|
req.on('error', function(e) {
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = 'inaccessible';
|
||||||
badge(badgeData, makeSend(format, ask.res, end));
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
req.end();
|
req.end();
|
||||||
});
|
}));
|
||||||
|
|
||||||
// Any badge.
|
// Any badge.
|
||||||
camp.route(/^\/:(([^-]|--)+)-(([^-]|--)+)-(([^-]|--)+)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/:(([^-]|--)+)-(([^-]|--)+)-(([^-]|--)+)\.(svg|png|gif|jpg)$/,
|
||||||
|
|
Loading…
Reference in New Issue
Block a user