#!/usr/bin/env node var async = require('async'); var fs = require('fs'); var ExpressApp = require('./lib/expressapp'); var WsApp = require('./lib/wsapp'); var config = require('./config'); var sticky = require('sticky-session'); var log = require('npmlog'); log.debug = log.verbose; log.disableColor(); var port = process.env.BWS_PORT || config.port || 3232; var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; var clusterInstances = config.clusterInstances || numCPUs; var serverModule = config.https ? require('https') : require('http'); var serverOpts = {}; if (config.https) { serverOpts.key = fs.readFileSync(config.privateKeyFile || './ssl/privatekey.pem'); serverOpts.cert = fs.readFileSync(config.certificateFile || './ssl/certificate.pem'); if (config.ciphers) { serverOpts.ciphers = config.ciphers; serverOpts.honorCipherOrder = true; }; // This sets the intermediate CA certs only if they have all been designated in the config.js if (config.CAinter1 && config.CAinter2 && config.CAroot) { serverOpts.ca = [fs.readFileSync(config.CAinter1), fs.readFileSync(config.CAinter2), fs.readFileSync(config.CAroot) ]; }; } var start = function(cb) { var expressApp = new ExpressApp(); var wsApp = new WsApp(); function doStart(cb) { var server = config.https ? serverModule.createServer(serverOpts, expressApp.app) : serverModule.Server(expressApp.app); server.on('connection', function(socket) { socket.setTimeout(30 * 1000); }) async.parallel([ function(done) { expressApp.start(config, done); }, function(done) { wsApp.start(server, config, done); }, ], function(err) { if (err) { log.error('Could not start BWS instance', err); } if (cb) return cb(err); }); return server; }; if (config.cluster) { var server = sticky(clusterInstances, function() { return doStart(); }); return cb(null, server); } else { var server = doStart(function(err) { return cb(err, server); }); } }; if (config.cluster && !config.lockOpts.lockerServer) throw 'When running in cluster mode, locker server need to be configured'; if (config.cluster && !config.messageBrokerOpts.messageBrokerServer) throw 'When running in cluster mode, message broker server need to be configured'; start(function(err, server) { if (err) { console.log('Could not start BWS:', err); process.exit(0); } server.listen(port, function(err) { if (err) console.log('ERROR: ', err); log.info('Bitcore Wallet Service running on port ' + port); }); });