blob: de4284b8c9e6a69de91908fbee42e3b821ced40a [file] [log] [blame]
/*
* Copyright (C) 2022 Savoir-faire Linux Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation; either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with this program. If not, see
* <https://www.gnu.org/licenses/>.
*/
import 'reflect-metadata';
import * as dotenv from 'dotenv';
dotenv.config();
import { createServer } from 'node:http';
import log from 'loglevel';
import { Container } from 'typedi';
import { App } from './app.js';
import { Jamid } from './jamid/jamid.js';
import { SigningKeys } from './storage/signing-keys.js';
import { WebSocketServer } from './websocket/websocket-server.js';
log.setLevel(process.env.NODE_ENV === 'production' ? 'error' : 'trace');
const port: string | number = 5000;
await Container.get(SigningKeys).build();
const jamid = Container.get(Jamid);
const app = Container.get(App);
const webSocketServer = Container.get(WebSocketServer);
const server = createServer();
server.on('request', app.app);
server.on('upgrade', webSocketServer.upgrade.bind(webSocketServer));
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
process.once('SIGTERM', shutdown);
process.once('SIGINT', shutdown);
function onError(error: NodeJS.ErrnoException) {
if (error.syscall !== 'listen') {
throw error;
}
const bind = typeof port === 'string' ? `Pipe ${port}` : `Port ${port}`;
switch (error.code) {
case 'EACCESS':
log.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
log.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
function onListening() {
const address = server.address();
const bind = typeof address === 'string' ? `pipe ${address}` : `port ${address?.port}`;
log.debug('Listening on ' + bind);
}
function shutdown(signal: NodeJS.Signals) {
log.debug(`${signal} received: shutting down server`);
jamid.stop();
server.close(() => {
log.debug('Server shut down');
// Needed in order to actually exit the process as its shutdown is blocked by something else
process.exit();
});
}