bitcore-node-zcash/lib/scaffold/start.js

152 lines
3.8 KiB
JavaScript
Raw Normal View History

'use strict';
var path = require('path');
var socketio = require('socket.io');
var BitcoreNode = require('../node');
var index = require('../');
var bitcore = require('bitcore');
var _ = bitcore.deps._;
2015-08-31 10:37:11 -07:00
var $ = bitcore.util.preconditions;
var log = index.log;
log.debug = function() {};
var count = 0;
var interval = false;
function start(options) {
/* jshint maxstatements: 100 */
2015-08-31 06:00:00 -07:00
var services = [];
var configPath = options.path;
var config = options.config;
2015-08-31 06:00:00 -07:00
if (config.services) {
for (var i = 0; i < config.services.length; i++) {
2015-08-31 10:37:11 -07:00
var service = {};
if(typeof config.services[i] === 'object') {
$.checkState(config.services[i].name, 'Service name must be specified in config');
service.name = config.services[i].name;
service.config = config.services[i].config || {};
} else {
service.name = config.services[i];
service.config = {};
}
try {
2015-08-31 06:00:00 -07:00
// first try in the built-in bitcore-node services directory
2015-08-31 10:37:11 -07:00
service.module = require(path.resolve(__dirname, '../services/' + service.name));
} catch(e) {
// check if the package.json specifies a specific file to use
2015-08-31 10:37:11 -07:00
var servicePackage = require(service.name + '/package.json');
var serviceModule = service.name;
2015-08-31 06:00:00 -07:00
if (servicePackage.bitcoreNode) {
2015-08-31 10:37:11 -07:00
serviceModule = service.name + '/' + servicePackage.bitcoreNode;
}
2015-08-31 10:37:11 -07:00
service.module = require(serviceModule);
}
2015-08-31 06:00:00 -07:00
// check that the service supports expected methods
2015-08-31 10:37:11 -07:00
if (!service.module.prototype ||
!service.module.dependencies ||
!service.module.prototype.start ||
!service.module.prototype.stop) {
throw new Error(
2015-08-31 10:37:11 -07:00
'Could not load service "' + service.name + '" as it does not support necessary methods.'
);
}
2015-08-27 13:09:27 -07:00
2015-08-31 10:37:11 -07:00
service.dependencies = service.module.dependencies;
services.push(service);
}
}
var fullConfig = _.clone(config);
// expand to the full path
fullConfig.datadir = path.resolve(configPath, config.datadir);
2015-08-31 06:00:00 -07:00
// load the services
fullConfig.services = services;
var node = new BitcoreNode(fullConfig);
function logSyncStatus() {
log.info(
2015-08-31 06:00:00 -07:00
'Sync Status: Tip:', node.services.db.tip.hash,
'Height:', node.services.db.tip.__height,
'Rate:', count/10, 'blocks per second'
);
}
node.on('synced', function() {
// Stop logging of sync status
clearInterval(interval);
interval = false;
logSyncStatus();
});
node.on('ready', function() {
log.info('Bitcore Node ready');
});
node.on('error', function(err) {
log.error(err);
});
2015-08-31 06:00:00 -07:00
node.on('ready', function() {
2015-08-31 06:00:00 -07:00
node.services.db.on('addblock', function(block) {
2015-08-31 06:00:00 -07:00
count++;
// Initialize logging if not already instantiated
if (!interval) {
interval = setInterval(function() {
logSyncStatus();
count = 0;
}, 10000);
}
});
});
node.on('stopping', function() {
clearInterval(interval);
});
function exitHandler(options, err) {
if (err) {
log.error('uncaught exception:', err);
if(err.stack) {
console.log(err.stack);
}
node.stop(function(err) {
if(err) {
log.error('Failed to stop services: ' + err);
}
process.exit(-1);
});
}
if (options.sigint) {
node.stop(function(err) {
if(err) {
log.error('Failed to stop services: ' + err);
return process.exit(1);
}
log.info('Halted');
process.exit(0);
});
}
}
//catches uncaught exceptions
process.on('uncaughtException', exitHandler.bind(null, {exit:true}));
//catches ctrl+c event
process.on('SIGINT', exitHandler.bind(null, {sigint:true}));
2015-08-25 10:57:54 -07:00
return node;
}
module.exports = start;