pixelplanet/src/server.js

116 lines
3.0 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 forceGC from './core/forceGC';
import logger from './core/logger';
import rankings from './core/ranking';
2022-06-19 21:19:10 +00:00
import sequelize from './data/sql/sequelize';
import { connect as connectRedis } from './data/redis/client';
import routes from './routes';
import chatProvider from './core/ChatProvider';
2022-06-30 13:06:36 +00:00
import rpgEvent from './core/RpgEvent';
import canvasCleaner from './core/CanvasCleaner';
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, HOURLY_EVENT } from './core/config';
import { SECOND } from './core/constants';
2020-01-02 16:58:06 +00:00
import { startAllCanvasLoops } from './core/tileserver';
const app = express();
app.disable('x-powered-by');
// Call Garbage Collector every 30 seconds
setInterval(forceGC, 10 * 60 * SECOND);
2020-01-02 16:58:06 +00:00
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
// -----------------------------------------------------------------------------
// sync sql models
2022-06-19 21:19:10 +00:00
sequelize.sync({ alter: { drop: false } })
// connect to redis
2022-06-19 21:19:10 +00:00
.then(connectRedis)
2022-04-05 19:37:33 +00:00
.then(() => {
rankings.initialize();
2022-04-05 19:37:33 +00:00
chatProvider.initialize();
startAllCanvasLoops();
usersocket.initialize();
apisocket.initialize();
if (HOURLY_EVENT) {
rpgEvent.initialize();
}
canvasCleaner.initialize();
// start http server
const startServer = () => {
server.listen(PORT, HOST, () => {
logger.log(
'info',
`HTTP Server listening on port ${PORT}`,
);
});
};
startServer();
// catch errors of server
server.on('error', (e) => {
logger.error(
`HTTP Server Error ${e.code} occured, trying again in 5s...`,
2022-04-05 19:37:33 +00:00
);
setTimeout(() => {
server.close();
startServer();
}, 5000);
2022-04-05 19:37:33 +00:00
});
2020-01-02 16:58:06 +00:00
});