neutral-old/routes/login.js
2023-02-21 12:02:37 +01:00

75 lines
1.5 KiB
JavaScript

var express = require('express');
var router = express.Router();
var path = require("path")
var fs = require("fs")
var CryptoJS = require("crypto-js");
var uuid = require("uuid")
var ntr = require("../neutral-functions.js")
/* GET home page. */
router.get('/', function(req, res, next) {
var check = ntr.checkToken(req, res)
if(check != false) {
res.redirect(302, "/")
} else {
res.render('login', {error: ""});
}
});
router.post("/", function(req, res, next) {
const users = new Map();
fs.readdirSync(__dirname.replace("routes", "users")).forEach(file => {
const fileData = JSON.parse(fs.readFileSync(__dirname.replace("routes", "users") + path.sep + file))
users.set(fileData.username, fileData.uuid)
})
const bod = req.body
if(users.has(bod.username)) {
const userData = JSON.parse(fs.readFileSync(__dirname.replace("routes", "users") + path.sep + users.get(req.body.username) + ".json"))
var userpassword = CryptoJS.AES.decrypt(userData.password,"D*G-KaPdSgVkYp3s").toString(CryptoJS.enc.Utf8)
if(bod.password == userpassword) {
userpassword = null;
const tokenID = ntr.generateTokenID(bod.username, userData, req, users)
res.cookie('tokenID' , tokenID, { maxAge: 900000000, httpOnly: true })
res.status(202).send({"token":"auth_success"})
} else {
userpassword = null;
res.status(202).send({"token":"auth_failed"})
}
} else {
res.status(202).send({"token":"auth_failed"})
}
})
module.exports = router;