Using Request for gittip vendor.
This commit is contained in:
parent
f8ee5dff63
commit
293b99d967
|
@ -21,6 +21,7 @@
|
||||||
"canvas": "~1.1.2",
|
"canvas": "~1.1.2",
|
||||||
"phantomjs": "~1.9.2-6",
|
"phantomjs": "~1.9.2-6",
|
||||||
"es6-promise": "~0.1.1",
|
"es6-promise": "~0.1.1",
|
||||||
|
"request": "~2.34.0",
|
||||||
"camp": "~13.11.9"
|
"camp": "~13.11.9"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
|
52
server.js
52
server.js
|
@ -4,6 +4,7 @@ var camp = require('camp').start({
|
||||||
});
|
});
|
||||||
var https = require('https');
|
var https = require('https');
|
||||||
var http = require('http');
|
var http = require('http');
|
||||||
|
var request = require('request');
|
||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var badge = require('./badge.js');
|
var badge = require('./badge.js');
|
||||||
var svg2img = require('./svg-to-img.js');
|
var svg2img = require('./svg-to-img.js');
|
||||||
|
@ -137,39 +138,30 @@ cache(function(data, match, sendBadge) {
|
||||||
var apiUrl = 'https://www.gittip.com/' + user + '/public.json';
|
var apiUrl = 'https://www.gittip.com/' + user + '/public.json';
|
||||||
var label = getLabel('tips', data);
|
var label = getLabel('tips', data);
|
||||||
var badgeData = {text:[label, 'n/a'], colorscheme:'lightgrey'};
|
var badgeData = {text:[label, 'n/a'], colorscheme:'lightgrey'};
|
||||||
var redirectCount = 0;
|
request(apiUrl, function dealWithData(err, res, buffer) {
|
||||||
https.get(apiUrl, function dealWithData(res) {
|
if (err != null) {
|
||||||
// Is it a redirection?
|
badgeData.text[1] = 'inaccessible';
|
||||||
if (res.statusCode === 302 && res.headers.location && redirectCount++ < 1) {
|
sendBadge(format, badgeData);
|
||||||
https.get('https://www.gittip.com/' + res.headers.location, dealWithData);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var buffer = '';
|
try {
|
||||||
res.on('data', function(chunk) { buffer += ''+chunk; });
|
var data = JSON.parse(buffer);
|
||||||
res.on('end', function(chunk) {
|
var money = parseInt(data.receiving);
|
||||||
if (chunk) { buffer += ''+chunk; }
|
} catch(e) {
|
||||||
try {
|
badgeData.text[1] = 'invalid';
|
||||||
var data = JSON.parse(buffer);
|
|
||||||
var money = parseInt(data.receiving);
|
|
||||||
} catch(e) {
|
|
||||||
badgeData.text[1] = 'invalid';
|
|
||||||
sendBadge(format, badgeData);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
badgeData.text[1] = '$' + metric(money) + '/week';
|
|
||||||
if (money === 0) {
|
|
||||||
badgeData.colorscheme = 'red';
|
|
||||||
} else if (money < 10) {
|
|
||||||
badgeData.colorscheme = 'yellow';
|
|
||||||
} else if (money < 100) {
|
|
||||||
badgeData.colorscheme = 'green';
|
|
||||||
} else {
|
|
||||||
badgeData.colorscheme = 'brightgreen';
|
|
||||||
}
|
|
||||||
sendBadge(format, badgeData);
|
sendBadge(format, badgeData);
|
||||||
});
|
return;
|
||||||
}).on('error', function(e) {
|
}
|
||||||
badgeData.text[1] = 'inaccessible';
|
badgeData.text[1] = '$' + metric(money) + '/week';
|
||||||
|
if (money === 0) {
|
||||||
|
badgeData.colorscheme = 'red';
|
||||||
|
} else if (money < 10) {
|
||||||
|
badgeData.colorscheme = 'yellow';
|
||||||
|
} else if (money < 100) {
|
||||||
|
badgeData.colorscheme = 'green';
|
||||||
|
} else {
|
||||||
|
badgeData.colorscheme = 'brightgreen';
|
||||||
|
}
|
||||||
sendBadge(format, badgeData);
|
sendBadge(format, badgeData);
|
||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
Loading…
Reference in New Issue
Block a user