import express from 'express'; import http from 'http'; import cors from 'cors'; import 'dotenv/config'; import { record, workflow, storage, auth, integration } from './routes'; import { BrowserPool } from "./browser-management/classes/BrowserPool"; import logger from './logger'; import cookieParser from 'cookie-parser'; import csrf from 'csurf'; import { SERVER_PORT } from "./constants/config"; import { Server } from "socket.io"; const csrfProtection = csrf({ cookie: true }) const app = express(); app.use(cors()); app.use(express.json()); const server = http.createServer(app); /** * Globally exported singleton instance of socket.io for socket communication with the client. * @type {Server} */ export const io = new Server(server); /** * {@link BrowserPool} globally exported singleton instance for managing browsers. */ export const browserPool = new BrowserPool(); // parse cookies - "cookie" is true in csrfProtection app.use(cookieParser()) app.use(csrfProtection) app.use('/record', record); app.use('/workflow', workflow); app.use('/storage', storage); app.use('/auth', auth); app.use('/integration', integration); app.get('/', function (req, res) { return res.send('Maxun server started 🚀'); }); app.get('/csrf-token', (req, res) => { res.json({ csrfToken: req.csrfToken() }) }) server.listen(SERVER_PORT, () => logger.log('info', `Server listening on port ${SERVER_PORT}`));