1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-12-22 19:07:54 +01:00
unleash.unleash/lib/server-impl.js
ivaosthu ccaab0c47b fix: LogProvider as option injected to unleash.
Instead of instructing users to do static calls
in to Unleash, she should instead be allwed to
specify the log provider as an option to Unleash.

This commit introduces the "getLogger" option,
a function responsible for creating a logger.
2020-02-20 08:34:24 +01:00

84 lines
2.0 KiB
JavaScript

'use strict';
const { EventEmitter } = require('events');
const migrator = require('../migrator');
const getApp = require('./app');
const { startMonitoring } = require('./metrics');
const { createStores } = require('./db');
const { createOptions } = require('./options');
const StateService = require('./state-service');
const User = require('./user');
const AuthenticationRequired = require('./authentication-required');
async function createApp(options) {
// Database dependecies (statefull)
const logger = options.getLogger('server-impl.js');
const stores = createStores(options);
const eventBus = new EventEmitter();
const config = Object.assign(
{
stores,
eventBus,
logFactory: options.getLogger, // TODO: remove in v4.x
},
options
);
const app = getApp(config);
startMonitoring(
options.serverMetrics,
eventBus,
stores.eventStore,
stores.clientMetricsStore
);
const stateService = new StateService(config);
config.stateService = stateService;
if (config.importFile) {
await stateService.importFile({
file: config.importFile,
dropBeforeImport: config.dropBeforeImport,
userName: 'import',
});
}
const server = app.listen(options.listen, () =>
logger.info('Unleash has started.', server.address())
);
return new Promise((resolve, reject) => {
server.on('listening', () =>
resolve({
app,
server,
eventBus,
stateService,
})
);
server.on('error', reject);
});
}
async function start(opts) {
const options = createOptions(opts);
const logger = options.getLogger('server-impl.js');
try {
await migrator(options);
} catch (err) {
logger.error('Failed to migrate db', err);
throw err;
}
return createApp(options);
}
module.exports = {
start,
User,
AuthenticationRequired,
};