Gitlab@Informatics

Skip to content
Snippets Groups Projects
Select Git revision
  • 040b126e319f995e2c7d9df38a6cdbb1255fdb45
  • main default protected
2 results

tourController.js

Blame
  • tourController.js 2.07 KiB
    const { User, Tour } = require('../models/tourModel');
    
    exports.getTours = async (req, res) => {
      try {
        const tours = await Tour.getAllTours();
        res.render('index', { 
          tours: tours,
          session: req.session // ส่ง session ไปยัง ejs
        });
      } catch (error) {
        res.status(500).send('เกิดข้อผิดพลาด');
      }
    };
    
    exports.getTourDetails = async (req, res) => {
      try {
        const tour = await Tour.getTourById(req.params.id);
        if (!tour) return res.status(404).send('ไม่พบข้อมูล');
        res.render('tour-details', { tour });
      } catch (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 isMatch = await User.comparePassword(email, password);
          if (!isMatch) {
              return res.render('login', { message: 'Invalid email or password' });
          }
    
          req.session.userId = email;
          req.session.userName = user.name;
          res.redirect('/');
      } catch (err) {
          console.error(err);
          res.render('login', { message: 'Error logging in' });