-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
102 lines (82 loc) · 3.1 KB
/
server.js
File metadata and controls
102 lines (82 loc) · 3.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
const express = require("express");
const mysql = require("mysql");
const cors = require("cors");
const app = express();
app.use(cors());
app.use(express.json());
const port = 3003;
// ✅ Connect to MySQL Database
const db = mysql.createConnection({
host: "localhost",
user: "root",
password: "", // Default MySQL password in XAMPP is empty
database: "users2",
});
// ✅ Ensure Database Connection Works
db.connect((err) => {
if (err) {
console.error("Database connection failed:", err);
} else {
console.log("Database connected successfully!");
}
});
// ✅ Test DB Connection (Optional Debugging)
db.query("SELECT 1", (err, results) => {
if (err) {
console.error("Database connection error:", err);
} else {
console.log("Database connection successful!");
}
});
// ✅ Login Route (Authentication)
app.post("/login", (req, res) => {
const { username, password } = req.body;
if (!username || !password) {
return res.status(400).json({ error: "Username and Password are required" });
}
db.query("SELECT * FROM users WHERE username = ? AND password = ?", [username, password], (err, results) => {
if (err) {
console.error("Database error:", err);
return res.status(500).json({ error: "Database error" });
}
if (results.length === 0) {
return res.status(401).json({ error: "Invalid credentials" });
}
const user = results[0];
// ✅ Simple Token Generation (Replace with JWT in Production)
const token = Buffer.from(`${user.username}:${Date.now()}`).toString("base64");
res.json({ token, user });
});
});
// ✅ Add Products Route (For Sellers to Post Products)
app.post("/add-products", (req, res) => {
console.log("Received products:", req.body.products); // Debugging
const { products } = req.body;
if (!Array.isArray(products) || products.length === 0) {
return res.status(400).json({ message: "No products provided" });
}
const sql = "INSERT INTO products (username, type, brand, quantity, description) VALUES ?";
const values = products.map((p) => [p.username, p.type, p.brand, p.quantity, p.description]);
db.query(sql, [values], (err, result) => {
if (err) {
console.error("MySQL Error:", err);
return res.status(500).json({ message: "DB error" });
}
res.json({ message: "Products added successfully!" });
});
});
// ✅ Fetch Products Route
app.get("/products", (req, res) => {
db.query("SELECT * FROM products", (err, results) => {
if (err) {
console.error("Database query failed:", err);
return res.status(500).json({ error: "Failed to fetch products" });
}
if (results.length === 0) {
return res.status(404).json({ message: "No products found" });
}
res.json(results);
});
});
// ✅ Start the Server
app.listen(3003, () => console.log("Server running on port 3003"));