import mongoose from 'mongoose'; // MongoDB (database) import express from 'express'; // Backend App (server) import cors from 'cors'; // HTTP headers (enable requests) import morgan from 'morgan'; // Logs incoming requests import dotenv from 'dotenv'; // Secures variables // import usersRoutes from './api/routes/usersRoutes.js'; // ^ ^ ^ un-comment this to use imported route(s) // doing this will link the following files: server.js -> usersRoutes.js -> usersControllers.js -> User.js // initialize app const app = express(); // middlewares app.use(express.json({ limit: '10mb', extended: false })); // body parser app.use(express.urlencoded({ limit: '10mb', extended: false })); // url parser app.use(cors({ origin: 'http://localhost:3000' })); // enables http requests on react development server app.use(morgan('common')); // logs requests dotenv.config(); // protected variables // configure db: // for "atlas" edit CONNECTION_URL in -> .env file || for "community server" edit const CONNECTION_URL = process.env.CONNECTION_URL || 'mongodb://localhost:27017/'; const DEPRECATED_FIX = { useNewUrlParser: true, useUnifiedTopology: true, useCreateIndex: true }; // connect to db mongoose .connect(CONNECTION_URL, DEPRECATED_FIX) .catch((error) => console.log('❌ MongoDB connection error', error)); // listen for errors on initial connection mongoose.connection.on('connected', () => console.log('✅ MongoDB connected')); // connected mongoose.connection.on('disconnected', () => console.log('❌ MongoDB disconnected')); // disconnected mongoose.connection.on('error', (error) => console.log('❌ MongoDB connection error', error)); // listen for errors during the session // routes app.get('/', (request, response, next) => response.status(200).json('Hello World - Express.js')); // app.use('/api/v1/users', usersRoutes); // ^ ^ ^ un-comment this to use imported route(s) // server is listening for requests const PORT = process.env.PORT || 8080; app.listen(PORT, () => console.log(`✅ Server is listening on port: ${PORT}`));