2023-01-06 00:58:55 +01:00
|
|
|
require('dotenv').config();
|
|
|
|
|
2023-01-06 19:12:43 +01:00
|
|
|
require('./app/tasks/sync')();
|
|
|
|
|
2023-01-06 00:58:55 +01:00
|
|
|
const express = require("express");
|
|
|
|
const bodyParser = require("body-parser");
|
|
|
|
const cors = require("cors");
|
2023-01-15 18:42:26 +01:00
|
|
|
const helmet = require("helmet");
|
2023-01-06 00:58:55 +01:00
|
|
|
|
|
|
|
const ivaoRoutes = require('./app/routes/ivao');
|
2023-01-15 18:42:26 +01:00
|
|
|
const ltsRoutes = require('./app/routes/lts');
|
|
|
|
const adminRoutes = require('./app/routes/admin');
|
2023-01-06 00:58:55 +01:00
|
|
|
|
|
|
|
const app = express();
|
|
|
|
|
2023-01-15 18:42:26 +01:00
|
|
|
// const whitelist = process.env.HOSTS_WHITELIST ? process.env.HOSTS_WHITELIST.split(',') : [];
|
2023-01-06 19:12:43 +01:00
|
|
|
|
2023-01-06 00:58:55 +01:00
|
|
|
// parse application/json
|
|
|
|
app.use(bodyParser.json());
|
|
|
|
|
|
|
|
// parse application/x-www-form-urlencoded
|
|
|
|
app.use(bodyParser.urlencoded({ extended: true }));
|
|
|
|
|
2023-01-15 18:42:26 +01:00
|
|
|
// var corsOptions = {
|
|
|
|
// origin: function(origin, callback) {
|
|
|
|
// if (whitelist.indexOf(origin) !== -1) {
|
|
|
|
// callback(null, true)
|
|
|
|
// } else {
|
|
|
|
// callback(new Error('Not allowed by CORS'))
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// };
|
2023-01-06 00:58:55 +01:00
|
|
|
// use cors options
|
2023-01-15 18:42:26 +01:00
|
|
|
app.use(cors());
|
|
|
|
app.use(helmet.referrerPolicy({
|
|
|
|
policy: ["origin", "unsafe-url"],
|
|
|
|
}));
|
2023-01-06 00:58:55 +01:00
|
|
|
app.use(express.static('assets'));
|
|
|
|
|
|
|
|
// routes
|
|
|
|
app.use('/api/v1/ivao', ivaoRoutes);
|
2023-01-15 18:42:26 +01:00
|
|
|
app.use('/api/v1', ltsRoutes);
|
|
|
|
app.use('/api/v1/admin', adminRoutes);
|
2023-01-06 00:58:55 +01:00
|
|
|
|
|
|
|
// listening port
|
|
|
|
const PORT = process.env.PORT || 3000;
|
|
|
|
app.listen(PORT, () => {
|
|
|
|
console.log(`Server is running on port ${PORT}.`);
|
|
|
|
});
|