const express = require('express') const session = require('express-session') const app = express() const {MongoClient} = require('mongodb') const MongoStore = require('connect-mongo'); const bcrypt = require('bcrypt') require('dotenv').config() app.use(express.static("public")); app.use(express.json()) const client = new MongoClient(process.env.URI, { useUnifiedTopology: true }) app.use(session({ secret: process.env.SECRET, resave: false, saveUninitialized: true, store: MongoStore.create({ client, dbName: 'reg_example' }), cookie: { maxAge: 1000 * 60 * 60 * 24 } })) client.connect() app.get('/', (req, res) => { if (req.session.loggedIn) { res.sendFile(__dirname+'/public/personal.html') } else res.sendFile(__dirname+'/public/auth.html') }) app.get('/get-users', async (_, res) => { try { const users = await client.db('reg_example').collection('users').find().toArray() res.send(users) } catch (e) { console.log("Error: " + e) res.status(500).send() } }) app.get('/register', async (req, res) => { const hashedPass = await bcrypt.hash(req.query.pass, 10) try { await client.db('reg_example').collection('users').insertOne({ login: req.query.login, pass: hashedPass }) req.session.loggedIn = true res.status(201).send("Welcome aboard!") } catch (e) { console.log("Error: " + e) res.status(500).send() } }) app.get('/login', async (req, res) => { try { const user = await client.db('reg_example').collection('users').findOne({ login: req.query.login }) if (user && bcrypt.compareSync(req.query.pass, user.pass)) { req.session.loggedIn = true res.status(200).send("Logged in!") } else { res.status(401).send("Invalid login credentials") } } catch (e) { console.log("Error: " + e) res.status(500).send() } }) app.get('/logout', (req, res) => { if (req.session) { req.session.destroy(function() {}) } res.send() }) app.listen(3000)