pixelplanet/src/server.js

96 lines
2.5 KiB
JavaScript
Raw Normal View History

/*
* Entrypoint for main server script
*/
2020-01-02 16:58:06 +00:00
2020-01-14 16:42:18 +00:00
import url from 'url';
2020-01-02 16:58:06 +00:00
import compression from 'compression';
import express from 'express';
import http from 'http';
// import baseCss from './components/base.tcss';
import forceGC from './core/forceGC';
import logger from './core/logger';
import rankings from './core/ranking';
2020-01-02 16:58:06 +00:00
import models from './data/models';
import routes from './routes';
import chatProvider from './core/ChatProvider';
2020-01-02 16:58:06 +00:00
2020-01-14 16:42:18 +00:00
import SocketServer from './socket/SocketServer';
import APISocketServer from './socket/APISocketServer';
import { PORT, HOST } from './core/config';
import { SECOND } from './core/constants';
2020-01-02 16:58:06 +00:00
import { startAllCanvasLoops } from './core/tileserver';
startAllCanvasLoops();
const app = express();
app.disable('x-powered-by');
// Call Garbage Collector every 30 seconds
setInterval(forceGC, 15 * 60 * SECOND);
2020-01-14 16:42:18 +00:00
// create http server
2020-01-02 16:58:06 +00:00
const server = http.createServer(app);
2020-01-14 16:42:18 +00:00
//
// websockets
// -----------------------------------------------------------------------------
const usersocket = new SocketServer();
const apisocket = new APISocketServer();
function wsupgrade(request, socket, head) {
const { pathname } = url.parse(request.url);
if (pathname === '/ws') {
usersocket.wss.handleUpgrade(request, socket, head, (ws) => {
usersocket.wss.emit('connection', ws, request);
});
} else if (pathname === '/mcws') {
apisocket.wss.handleUpgrade(request, socket, head, (ws) => {
apisocket.wss.emit('connection', ws, request);
});
} else {
socket.destroy();
}
}
2020-01-02 16:58:06 +00:00
server.on('upgrade', wsupgrade);
/*
* use gzip compression for following calls
/* level from -1 (default, 6) to 0 (no) from 1 (fastest) to 9 (best)
* Set custon filter to make sure that .bmp files get compressed
*/
2020-01-04 06:00:47 +00:00
app.use(compression({
level: 3,
2020-01-02 16:58:06 +00:00
filter: (req, res) => {
if (res.getHeader('Content-Type') === 'application/octet-stream') {
return true;
}
return compression.filter(req, res);
2020-01-04 06:00:47 +00:00
},
}));
2020-01-02 16:58:06 +00:00
app.use(routes);
2020-01-02 16:58:06 +00:00
//
// ip config
// -----------------------------------------------------------------------------
// use this if models changed:
2020-11-26 18:17:00 +00:00
const promise = models.sync({ alter: { drop: false } })
// const promise = models.sync()
.catch((err) => logger.error(err.stack));
2020-01-02 16:58:06 +00:00
promise.then(() => {
2021-07-10 13:51:15 +00:00
rankings.updateRanking();
chatProvider.initialize();
server.listen(PORT, HOST, () => {
2020-01-02 16:58:06 +00:00
const address = server.address();
logger.log(
2021-02-04 23:29:47 +00:00
'info',
`web is running at http://${address.host}:${address.port}/`,
);
2020-01-02 16:58:06 +00:00
});
});