feat: implement user creation functionality and update dashboard notifications

This commit is contained in:
2025-06-21 01:28:39 +02:00
parent df199cf9a5
commit 01bce663f6
3 changed files with 54 additions and 15 deletions

View File

@@ -3,7 +3,7 @@ import express from "express";
const app = express();
const port = 4000;
import { loginUser } from "./database.js";
import { loginUser, createUser } from "./database.js";
app.use(express.urlencoded({ extended: true }));
app.set("view engine", "ejs");
@@ -31,16 +31,18 @@ app.get("/", (req, res) => {
res.render("login.ejs", { error: null, reload: false });
});
let latestUser;
// Route to handle user login
app.post("/login", (req, res) => {
loginUser(req.body.username, req.body.password).then((result) => {
if (result.success) {
res
.status(200)
.render("dashboard.ejs", {
sqlResult: result,
newLink: `/dashboard/${result.user.id}`,
});
res.status(200).render("dashboard.ejs", {
sqlResult: result,
newLink: `/dashboard/${result.user.id}`,
});
latestUser = result;
console.log(latestUser);
} else {
res
.status(401)
@@ -49,6 +51,30 @@ app.post("/login", (req, res) => {
});
});
app.post("/createUser", (req, res) => {
createUser(
req.body.username,
req.body.first_name,
req.body.last_name,
req.body.password,
req.body.email
).then((result) => {
if (result.success) {
res.status(201).render("dashboard.ejs", {
sqlResult: latestUser,
newLink: `/dashboard/${latestUser.id}`,
});
console.log(latestUser);
} else {
res.status(400).render("dashboard.ejs", {
sqlResult: latestUser,
newLink: `/dashboard/${latestUser.id}`,
});
console.log(latestUser);
}
});
});
// error handling code
app.use((err, req, res, next) => {
console.error(err.stack);