Select Git revision
tourController.js
tourController.js 12.33 KiB
const { User, Tour , Booking } = require('../models/tourModel');
const pool = require('../config/database');
exports.getTours = async (req, res) => {
try {
const tours = await Tour.getAllTours(req.session.userId); // ดึงทัวร์ที่สร้างโดยผู้ใช้ที่ล็อกอิน
res.render('index', { tours, session: req.session });
} catch (error) {
res.status(500).send(error.message);
}
};
exports.getTourDetails = async (req, res) => {
const tourId = req.params.id;
try {
const tour = await Tour.getTourById(tourId); // ค้นหาทัวร์จาก ID
// ถ้าทัวร์ไม่พบ จะส่งข้อความกลับไป
if (!tour) {
return res.status(404).send('ไม่พบข้อมูลทัวร์ที่ต้องการ');
}
res.render('tour-details', { tour });
} catch (error) {
console.error('Error fetching tour by ID:', error);
res.status(500).send('เกิดข้อผิดพลาดในการดึงข้อมูลทัวร์');
}
};
//User//
exports.getLogin = (req, res) => {
res.render('login', { message: null });
};
exports.getRegister = (req, res) => {
res.render('register', { message: null });
};
exports.postRegister = async (req, res) => {
const { name, email, password, confirmPassword } = req.body;
if (password !== confirmPassword) {
return res.render('register', { message: 'Passwords do not match' });
}
try {
const existingUser = await User.findOne(email);
if (existingUser) {
return res.render('register', { message: 'Email already in use' });
}
const userId = await User.create(name, email, password);
req.session.userId = userId;
res.redirect('/login');
} catch (err) {
console.error(err);
res.render('register', { message: 'Error creating user' });
}
};
exports.postLogin = async (req, res) => {
const { email, password } = req.body;
try {
const user = await User.findOne(email); // หาผู้ใช้จากฐานข้อมูล
if (!user) {
return res.render('login', { message: 'Invalid email or password' });