summaryrefslogtreecommitdiffstats
path: root/gold/scex
diff options
context:
space:
mode:
authormakefu <github@syntax-fehler.de>2011-08-24 17:53:11 +0200
committermakefu <github@syntax-fehler.de>2011-08-24 17:53:11 +0200
commitf23d4436239ca9d2528b2ddfc7b6859a253d22e7 (patch)
treef28ec3fd84186b9725ec271a16513c5d80f73293 /gold/scex
parent14786b561f054a8ffac26eb4f3f66921a1e37e53 (diff)
parentc66cb75478976f4bbafb7eb6ecbfda502a4bbef2 (diff)
Merge branch 'master' of github.com:krebscode/painload
Diffstat (limited to 'gold/scex')
-rwxr-xr-xgold/scex/ticker2
-rwxr-xr-xgold/scex/ticker_text.sh4
-rw-r--r--gold/scex/tracer/index.js58
-rw-r--r--gold/scex/tracer/slurp.js38
4 files changed, 102 insertions, 0 deletions
diff --git a/gold/scex/ticker b/gold/scex/ticker
new file mode 100755
index 00000000..a95d5910
--- /dev/null
+++ b/gold/scex/ticker
@@ -0,0 +1,2 @@
+#! /bin/sh
+exec curl -ksS http://scexchange.bitparking.com:8080/api/ticker
diff --git a/gold/scex/ticker_text.sh b/gold/scex/ticker_text.sh
new file mode 100755
index 00000000..fbaff55b
--- /dev/null
+++ b/gold/scex/ticker_text.sh
@@ -0,0 +1,4 @@
+#! /bin/sh
+set -euf
+cd $(dirname `readlink -f $0`)
+./ticker | ../json/render/ticker
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('' + exn.stack + '');
+ };
+ 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 = '' + price + ''
+ }
+ if (x.price < last_price) {
+ price = '' + price + ''
+ }
+ last_price = x.price;
+
+ var c = ({ buy: '', sell: '' })[x.type];
+ var m = '';
+ m += x.id
+ m += ' ' + JSON.parse(JSON.stringify(x.date))
+ m += ' ' + price
+ m += ' ' + c + x.amount + ''
+ console.log(m);
+
+ };
+ });
+ });
+ }).on('error', function(e) {
+ console.log("Got error: " + e.message);
+ });
+};
+
+setInterval(t2, 1000);
diff --git a/gold/scex/tracer/slurp.js b/gold/scex/tracer/slurp.js
new file mode 100644
index 00000000..70319743
--- /dev/null
+++ b/gold/scex/tracer/slurp.js
@@ -0,0 +1,38 @@
+module.exports = (function () {
+
+ function join_buffers (buffers, length) {
+ var buffer = new Buffer(length);
+ var targetStart = 0;
+ buffers.forEach(function (x) {
+ x.copy(buffer, targetStart);
+ targetStart += x.length;
+ });
+ return buffer;
+ };
+
+ function finish_it (req, buffers, length, callback) {
+ req.content = join_buffers(buffers, length);
+ return callback(req.content);
+ };
+
+ function nop () {};
+
+ return function (req, callback) {
+ if (req.hasOwnProperty('content')) {
+ return callback(req.content);
+ };
+ var content = [];
+ var length = 0;
+ var end_handler = finish_it;
+ req.on('data', function (data) {
+ content.push(data);
+ length += data.length;
+ });
+ [ 'end', 'close' ].forEach(function (event) {
+ req.on(event, function () {
+ finish_it(req, content, length, callback);
+ end_handler = nop;
+ });
+ });
+ };
+})();