Базовая валидация (body)

const {Router} = require('express');//модуль express
const bcrypt = require('bcryptjs');//Модуль шифрования
const User = require('../models/user');//модель пользователя
const nodeMailer = require('nodemailer');//mailer
const sendGrid = require('nodemailer-sendgrid-transport');//Транспорт для mailer
const config = require('../config/config');//конфигурация
const regMail = require('../emails/registration');//конфигурация для почтовой рассылки
const resetMail = require('../emails/reset');//конфигурация для почтовой рассылки
const crypto = require('crypto');//Встроеннная в node.js криптографическая библиотека
const {body, validationResult} = require('express-validator');//Базовая валидая работающая с express
const router = Router();//инициируем роутер
 
 
/**
 * Регистрация пользователя
 * первый параметр адрес страницы, в данном случае используется префикс при регистрации ройтера,
 * второй параметр валидация
 * третий параметр callback - обработчик запроса req - request , запрос от браузера
 * res - response, ответ сервера
 */
router.post('/register', body('email').isEmail(),async (req, res) => {
       const {email, password, confirm, name} = req.body;//получить данные пользоватедя
 
       const candidate = await User.findOne({email: email});//поиск пользователя с таким же email
 
       const error = validationResult(req);//получить результирующую ошибку если она есть
 
       if(!error.isEmpty()){//если ошибка присутствует
           req.flash('error', error.array()[0].msg);//сохранить ошибку в сессии
           return res.status(422).redirect('/auth/login#register');//редирект на страницу регистрации
       }
 
       if(password !== confirm){//Проверка пароля
           req.flash('error', 'Пароль не совпадает');//сохроняем ошибку в сессию, с ключом error
           res.redirect('/auth/login#register');//редирект на страницу регистрации
       }
       if(candidate){//если такой email уже зарегестрирован
            req.flash('error', 'Такой email уже существует');//сохроняем ошибку в сессию, с ключом error
            res.redirect('/auth/login#register');//редирект на страницу регистрации
       }
       else{
           const hashPassword = await bcrypt.hash(password, 10);//Шифруем пароль
           const user = new User({email, name, password:hashPassword, cart: {items:[]}});//создание пользователя
           await user.save();//сохраняем запись
 
           await transporter.sendMail(regMail(email));//отправить mail, Рекомендуется использовать после редиректов
 
           res.redirect('/auth/login#login');
       }
 
    }
);
 
 
 
 
module.exports = router;//Экспортирум роутер