Website restoration: Node.js backend, restored design, GitHub sync disabled

- Replaced broken .NET backend with Node.js/Express
- Restored original website design with purple gradient hero
- Updated homepage and shop pages with Bootstrap 5 responsive design
- Disabled GitHub remote sync - all code now stored locally only
- Created backup scripts and documentation
- All changes saved on Ubuntu server at /var/www/SkyArtShop
This commit is contained in:
Local Server
2025-12-13 17:53:34 -06:00
parent d90bb4cb5d
commit 8bb6430a70
3132 changed files with 285659 additions and 0 deletions

80
backend/routes/admin.js Normal file
View File

@@ -0,0 +1,80 @@
const express = require('express');
const { query } = require('../config/database');
const { requireAuth } = require('../middleware/auth');
const router = express.Router();
router.get('/dashboard', requireAuth, async (req, res) => {
try {
const productsCount = await query('SELECT COUNT(*) FROM products');
const ordersCount = await query('SELECT COUNT(*) FROM orders');
const usersCount = await query('SELECT COUNT(*) FROM appusers');
const pagesCount = await query('SELECT COUNT(*) FROM pages');
const recentOrders = await query(
'SELECT id, ordernumber, totalamount, status, createdat FROM orders ORDER BY createdat DESC LIMIT 5'
);
res.render('admin/dashboard', {
title: 'Dashboard - SkyArtShop Admin',
user: req.session,
stats: {
products: productsCount.rows[0].count,
orders: ordersCount.rows[0].count,
users: usersCount.rows[0].count,
pages: pagesCount.rows[0].count
},
recentOrders: recentOrders.rows
});
} catch (error) {
console.error('Dashboard error:', error);
res.status(500).send('Server error');
}
});
router.get('/products', requireAuth, async (req, res) => {
try {
const result = await query(
'SELECT id, name, price, stockquantity, isactive, createdat FROM products ORDER BY createdat DESC'
);
res.render('admin/products', {
title: 'Products - SkyArtShop Admin',
user: req.session,
products: result.rows
});
} catch (error) {
console.error('Products error:', error);
res.status(500).send('Server error');
}
});
router.get('/orders', requireAuth, async (req, res) => {
try {
const result = await query(
'SELECT id, ordernumber, totalamount, status, createdat FROM orders ORDER BY createdat DESC'
);
res.render('admin/orders', {
title: 'Orders - SkyArtShop Admin',
user: req.session,
orders: result.rows
});
} catch (error) {
console.error('Orders error:', error);
res.status(500).send('Server error');
}
});
router.get('/users', requireAuth, async (req, res) => {
try {
const result = await query(
'SELECT id, email, name, role, createdat, lastlogin FROM adminusers ORDER BY createdat DESC'
);
res.render('admin/users', {
title: 'Admin Users - SkyArtShop Admin',
user: req.session,
users: result.rows
});
} catch (error) {
console.error('Users error:', error);
res.status(500).send('Server error');
}
});
module.exports = router;

50
backend/routes/auth.js Normal file
View File

@@ -0,0 +1,50 @@
const express = require("express");
const bcrypt = require("bcrypt");
const { query } = require("../config/database");
const { redirectIfAuth } = require("../middleware/auth");
const router = express.Router();
router.get("/login", redirectIfAuth, (req, res) => {
res.render("admin/login", {
error: req.query.error,
title: "Admin Login - SkyArtShop",
});
});
router.post("/login", async (req, res) => {
const { email, password } = req.body;
try {
const result = await query(
"SELECT id, email, name, passwordhash, role FROM adminusers WHERE email = $1",
[email]
);
if (result.rows.length === 0) {
return res.redirect("/admin/login?error=invalid");
}
const admin = result.rows[0];
const validPassword = await bcrypt.compare(password, admin.passwordhash);
if (!validPassword) {
return res.redirect("/admin/login?error=invalid");
}
await query("UPDATE adminusers SET lastlogin = NOW() WHERE id = $1", [
admin.id,
]);
req.session.adminId = admin.id;
req.session.email = admin.email;
req.session.name = admin.name;
req.session.role = admin.role;
res.redirect("/admin/dashboard");
} catch (error) {
console.error("Login error:", error);
res.redirect("/admin/login?error=server");
}
});
router.get("/logout", (req, res) => {
req.session.destroy((err) => {
if (err) console.error("Logout error:", err);
res.redirect("/admin/login");
});
});
module.exports = router;

39
backend/routes/public.js Normal file
View File

@@ -0,0 +1,39 @@
const express = require('express');
const { query } = require('../config/database');
const router = express.Router();
router.get('/', async (req, res) => {
try {
const products = await query(
'SELECT id, name, description, price, imageurl FROM products WHERE isactive = true ORDER BY createdat DESC LIMIT 8'
);
const sections = await query(
'SELECT * FROM homepagesections ORDER BY displayorder ASC'
);
res.render('public/home', {
title: 'Welcome - SkyArtShop',
products: products.rows,
sections: sections.rows
});
} catch (error) {
console.error('Home page error:', error);
res.status(500).send('Server error');
}
});
router.get('/shop', async (req, res) => {
try {
const products = await query(
'SELECT id, name, description, price, imageurl, category FROM products WHERE isactive = true ORDER BY name ASC'
);
res.render('public/shop', {
title: 'Shop - SkyArtShop',
products: products.rows
});
} catch (error) {
console.error('Shop page error:', error);
res.status(500).send('Server error');
}
});
module.exports = router;