@abcpros/bitcore-wallet-service
Version:
A service for Mutisig HD Bitcoin Wallets
85 lines (69 loc) • 2.4 kB
text/typescript
import * as fs from 'fs';
import 'source-map-support/register';
import logger from './lib/logger';
import { ExpressApp } from './lib/expressapp';
const config = require('./config');
const port = process.env.BWS_PORT || config.port || 3232;
const cluster = require('cluster');
const serverModule = config.https ? require('https') : require('http');
const serverOpts: {
key?: Buffer;
cert?: Buffer;
ciphers?: string[];
honorCipherOrder?: boolean;
ca?: Buffer[];
} = {};
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)
];
}
}
if (config.cluster && !config.messageBrokerOpts.messageBrokerServer)
throw new Error('When running in cluster mode, message broker server need to be configured');
const expressApp = new ExpressApp();
function startInstance() {
const server = config.https
? serverModule.createServer(serverOpts, expressApp.app)
: serverModule.Server(expressApp.app);
expressApp.start(config, err => {
if (err) {
logger.error('Could not start BWS instance', err);
return;
}
server.listen(port);
const instanceInfo = cluster.worker ? ' [Instance:' + cluster.worker.id + ']' : '';
logger.info('BWS running ' + instanceInfo);
return;
});
}
if (config.cluster && cluster.isMaster) {
// Count the machine's CPUs
const instances = config.clusterInstances || require('os').cpus().length;
logger.info('Starting ' + instances + ' instances');
// Create a worker for each CPU
for (let i = 0; i < instances; i += 1) {
cluster.fork();
}
// Listen for dying workers
cluster.on('exit', worker => {
// Replace the dead worker,
logger.error('Worker ' + worker.id + ' died :(');
cluster.fork();
});
// Code to run if we're in a worker process
} else {
logger.info('Listening on port: ' + port);
startInstance();
}