2015-07-29 17:34:44 -07:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var BitcoinNode = require('..').Node;
|
|
|
|
var chainlib = require('chainlib');
|
2015-08-04 13:34:53 -07:00
|
|
|
var socketio = require('socket.io');
|
2015-07-29 17:34:44 -07:00
|
|
|
var log = chainlib.log;
|
|
|
|
log.debug = function() {};
|
|
|
|
|
|
|
|
var configuration = {
|
2015-08-05 05:15:13 -07:00
|
|
|
datadir: process.env.BITCORENODE_DIR || '~/.bitcoin',
|
|
|
|
network: process.env.BITCORENODE_NETWORK || 'livenet',
|
2015-08-04 13:34:53 -07:00
|
|
|
port: 3000
|
2015-07-29 17:34:44 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
var node = new BitcoinNode(configuration);
|
|
|
|
|
|
|
|
var count = 0;
|
2015-08-11 14:16:04 -07:00
|
|
|
var interval = false;
|
|
|
|
|
|
|
|
function logSyncStatus() {
|
|
|
|
log.info('Sync Status: Tip:', node.chain.tip.hash, 'Height:', node.chain.tip.__height, 'Rate:', count/10, 'blocks per second');
|
|
|
|
}
|
|
|
|
|
|
|
|
node.on('synced', function() {
|
|
|
|
// Stop logging of sync status
|
|
|
|
clearInterval(interval);
|
|
|
|
interval = false;
|
|
|
|
logSyncStatus();
|
|
|
|
});
|
2015-07-29 17:34:44 -07:00
|
|
|
|
|
|
|
node.on('ready', function() {
|
|
|
|
|
2015-08-04 13:34:53 -07:00
|
|
|
var io = socketio(configuration.port);
|
|
|
|
|
2015-07-29 17:34:44 -07:00
|
|
|
io.on('connection', function(socket) {
|
|
|
|
|
|
|
|
var bus = node.openBus();
|
|
|
|
|
|
|
|
var methods = node.getAllAPIMethods();
|
|
|
|
var methodsMap = {};
|
|
|
|
|
|
|
|
methods.forEach(function(data) {
|
|
|
|
var name = data[0];
|
|
|
|
var instance = data[1];
|
|
|
|
var method = data[2];
|
2015-08-03 13:35:38 -07:00
|
|
|
var args = data[3];
|
|
|
|
methodsMap[name] = {
|
|
|
|
fn: function() {
|
|
|
|
return method.apply(instance, arguments);
|
|
|
|
},
|
|
|
|
args: args
|
2015-07-29 17:34:44 -07:00
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2015-08-03 13:35:38 -07:00
|
|
|
socket.on('message', function(message, socketCallback) {
|
2015-08-04 14:04:25 -07:00
|
|
|
if (methodsMap[message.method]) {
|
2015-08-03 13:35:38 -07:00
|
|
|
var params = message.params;
|
|
|
|
|
|
|
|
if(!params || !params.length) {
|
|
|
|
params = [];
|
|
|
|
}
|
|
|
|
|
2015-08-04 14:04:25 -07:00
|
|
|
if(params.length !== methodsMap[message.method].args) {
|
2015-08-03 13:35:38 -07:00
|
|
|
return socketCallback({
|
2015-08-05 05:15:13 -07:00
|
|
|
error: {
|
|
|
|
message: 'Expected ' + methodsMap[message.method].args + ' parameters'
|
|
|
|
}
|
2015-08-03 13:35:38 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
var callback = function(err, result) {
|
|
|
|
var response = {};
|
|
|
|
if(err) {
|
2015-08-04 14:04:25 -07:00
|
|
|
response.error = {
|
|
|
|
message: err.toString()
|
|
|
|
};
|
2015-08-03 13:35:38 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if(result) {
|
2015-08-14 10:41:56 -07:00
|
|
|
response.result = result;
|
2015-08-03 13:35:38 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
socketCallback(response);
|
|
|
|
};
|
|
|
|
|
|
|
|
params = params.concat(callback);
|
2015-08-04 14:04:25 -07:00
|
|
|
methodsMap[message.method].fn.apply(this, params);
|
2015-08-03 13:35:38 -07:00
|
|
|
} else {
|
|
|
|
socketCallback({
|
2015-08-05 05:15:13 -07:00
|
|
|
error: {
|
|
|
|
message: 'Method Not Found'
|
|
|
|
}
|
2015-08-03 13:35:38 -07:00
|
|
|
});
|
2015-07-29 17:34:44 -07:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
socket.on('subscribe', function(name, params) {
|
|
|
|
bus.subscribe(name, params);
|
|
|
|
});
|
|
|
|
|
|
|
|
socket.on('unsubscribe', function(name, params) {
|
|
|
|
bus.unsubscribe(name, params);
|
|
|
|
});
|
|
|
|
|
|
|
|
var events = node.getAllPublishEvents();
|
|
|
|
|
|
|
|
events.forEach(function(event) {
|
2015-08-04 13:34:53 -07:00
|
|
|
bus.on(event.name, function() {
|
2015-08-03 13:35:38 -07:00
|
|
|
if(socket.connected) {
|
2015-08-04 13:34:53 -07:00
|
|
|
var results = [];
|
|
|
|
|
|
|
|
for(var i = 0; i < arguments.length; i++) {
|
2015-08-14 10:41:56 -07:00
|
|
|
results.push(arguments[i]);
|
2015-08-04 13:34:53 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
var params = [event.name].concat(results);
|
|
|
|
socket.emit.apply(socket, params);
|
2015-08-03 13:35:38 -07:00
|
|
|
}
|
2015-07-29 17:34:44 -07:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
socket.on('disconnect', function() {
|
|
|
|
bus.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
node.on('error', function(err) {
|
|
|
|
log.error(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
node.chain.on('addblock', function(block) {
|
|
|
|
count++;
|
2015-08-11 14:16:04 -07:00
|
|
|
// Initialize logging if not already instantiated
|
|
|
|
if (!interval) {
|
|
|
|
interval = setInterval(function() {
|
|
|
|
logSyncStatus();
|
|
|
|
count = 0;
|
|
|
|
}, 10000);
|
|
|
|
}
|
2015-07-29 17:34:44 -07:00
|
|
|
});
|
2015-08-20 14:50:14 -07:00
|
|
|
|
|
|
|
process.stdin.resume();//so the program will not close instantly
|
|
|
|
|
|
|
|
function exitHandler(options, err) {
|
|
|
|
if (err) {
|
|
|
|
log.error('uncaught exception:', err);
|
|
|
|
if(err.stack) {
|
|
|
|
console.log(err.stack);
|
|
|
|
}
|
|
|
|
process.exit(-1);
|
|
|
|
}
|
|
|
|
if (options.sigint) {
|
|
|
|
log.info('Stopping Services');
|
|
|
|
node.stop(function(err) {
|
|
|
|
if(err) {
|
|
|
|
log.error('Failed to stop services: ' + err);
|
|
|
|
return process.exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
log.info('Halted');
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//catches ctrl+c event
|
|
|
|
process.on('SIGINT', exitHandler.bind(null, {sigint:true}));
|
|
|
|
|
|
|
|
//catches uncaught exceptions
|
|
|
|
process.on('uncaughtException', exitHandler.bind(null, {exit:true}));
|