mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
ccaab0c47b
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.
84 lines
2.0 KiB
JavaScript
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,
|
|
};
|