diff --git a/backend/database.js b/backend/database.js index 97ee916..f04d01d 100644 --- a/backend/database.js +++ b/backend/database.js @@ -26,18 +26,25 @@ export async function loginUser(username, password) { } } -export async function createUser(username, first_name, last_name, password, email) { +export async function createUser( + username, + first_name, + last_name, + password, + email +) { try { + const [result] = await pool.query( "INSERT INTO users (username, first_name, last_name, password, email) VALUES (?, ?, ?, ?, ?)", [username, first_name, last_name, password, email] ); - console.log("User created successfully: ", result); - return { success: true, userId: result.insertId }; + + console.log("User created successfully!"); + return { success: true }; + } catch (error) { console.error("Error creating user: ", error); return { success: false, message: "Error creating user" }; } - - -} \ No newline at end of file +} diff --git a/backend/server.js b/backend/server.js index f8bbbc0..641fcd7 100644 --- a/backend/server.js +++ b/backend/server.js @@ -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); diff --git a/backend/views/dashboard.ejs b/backend/views/dashboard.ejs index 5bd881a..ba39803 100644 --- a/backend/views/dashboard.ejs +++ b/backend/views/dashboard.ejs @@ -3,7 +3,7 @@
@@ -104,6 +104,12 @@ + <% if (typeof status !== 'undefined') { %> <% if (status === + 'success') { %> +