76 lines
1.6 KiB
JavaScript
76 lines
1.6 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) {
|
|
|
|
|
|
ntr.checkUser()
|
|
var check = ntr.checkToken(req, res)
|
|
|
|
if(check.name != 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;
|