Skip to content
Snippets Groups Projects
index.js 1.92 KiB
Newer Older
const path = require( 'path' );
const http = require( 'http' );
const express = require('express');
const cors = require('cors');
const helmet = require('helmet');
const dbClientInstance_ = require('./db/mongo.js');
const todoRoutes = require('./routes/todo');
const userRoutes = require('./routes/user');
const errorRoutes = require('./routes/error');
const envRoute = require('./routes/env.js');
let cookieParser = require('cookie-parser');

const app = express();
const port = process.env.PORT || 5000;
    origin: `http://localhost:${ port }`,
app.use(express.json());
app.use(cors(corsOptions));
app.use(helmet.contentSecurityPolicy({
    directives: {
        defaultSrc: ["'self'"],
        styleSrc: ["'self' 'unsafe-inline'"],
        scriptSrc: ["'self' 'unsafe-inline' 'unsafe-eval'"]
app.use(todoRoutes);
app.use(userRoutes);
app.use('/', express.static(path.resolve(__dirname, `./public`)));
// IMPORTANT: Educational purpose only! Possibly exposes sensitive data.
app.use(envRoute);
// NOTE: must be last one, because is uses a wildcard (!) that behaves aa
// fallback and catches everything else
app.use(errorRoutes);


(async function main(){
    process.on( 'exit', async ()=>{
        const dbClient = await dbClientInstance_;
        await dbClient.disconnect();
    });

        const server = http.createServer( app );
        await new Promise( (__ful, rej__ )=>{
            server.listen( port, ()=>{
                console.log( `ToDo server is up & bound to port ${ port }` );
            }).on( 'error', rej__ );
        process.on( 'SIGINT', ()=>{
            server.close( ()=>{
                console.log( 'Shutting down ToDo server' );
            });
            process.exit( 0 );