diff options
author | makefu <github@syntax-fehler.de> | 2011-08-24 17:53:11 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2011-08-24 17:53:11 +0200 |
commit | 9a2947575515fe070fb63e640007f4d4ed952f85 (patch) | |
tree | 63d2085927916eaa955e37255ee04cb54930d0a1 /gold/scex/tracer/index.js | |
parent | bc901adc1441d6f11c53dacb5bbca7acdcf03361 (diff) | |
parent | 7c18a3d4e5897adb4ddd141aed261ce63daf1a10 (diff) |
Merge branch 'master' of github.com:krebscode/painload
Diffstat (limited to 'gold/scex/tracer/index.js')
-rw-r--r-- | gold/scex/tracer/index.js | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/gold/scex/tracer/index.js b/gold/scex/tracer/index.js new file mode 100644 index 00000000..e0c706e7 --- /dev/null +++ b/gold/scex/tracer/index.js @@ -0,0 +1,58 @@ +var http = require('http'); +var slurp = require('./slurp'); + +var options = { + host: 'scexchange.bitparking.com', + port: 8080, + path: '/api/t2' +}; + +var last_id = 0; +var last_price = 0; +function t2 () { + http.get(options, function(res) { + slurp(res, function (data) { + try { + data = JSON.parse(data); + } catch (exn) { + return console.error('[1;31m' + exn.stack + '[m'); + }; + data + .sort(function (a, b) { + return a.id - b.id; + }) + .forEach(function (x) { + if (x.id > last_id) { + last_id = x.id; + + x.date = new Date(Number(x.date) * 1000); + + var price = x.price.toString(); + while (price.length < 'x.xxxxxxxx'.length) { + price += 0; + } + if (x.price > last_price) { + price = '[32m' + price + '[m' + } + if (x.price < last_price) { + price = '[31m' + price + '[m' + } + last_price = x.price; + + var c = ({ buy: '[32m', sell: '[31m' })[x.type]; + var m = ''; + m += x.id + m += ' ' + JSON.parse(JSON.stringify(x.date)) + m += ' ' + price + m += ' ' + c + x.amount + '[m' + console.log(m); + + }; + }); + }); + }).on('error', function(e) { + console.log("Got error: " + e.message); + }); +}; + +setInterval(t2, 1000); |