=====Вынесенная отдельным middleware валидация=====
**validator/validator.js**
const {body, validationResult} = require('express-validator');//валидая работающая с express
/**
* Название валидатора произвольное
* @type {*[]}
*/
exports.registerValidators = [
body('email').isEmail().withMessage('Введите корректный email'),//ПРоверка email
body('password','минимум 6 символов').isLength({min: 6, max: 56}).isAlphanumeric().withMessage('Только цифры и латинские буквы'),
body('confirm').custom((valuem, {req}) => {//Кастомный валидатор
if(valuem !== req.body.password){//Проверяем совподают ли значения при подтверждении пароля
throw new Error('Пароль должен совпадать');
}
}),
body('name').isLength({min: 3}).withMessage('Минимум три символа')//Имя пользователя
];
**routes/auth.js**
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 {validationResult} = require('express-validator');//валидация работающая с express
const {registerValidators} = require('../validator/validator');//middleware - мой валидатор на основе express-validator
const router = Router();//инициируем роутер
/**
* Регистрация пользователя
* первый параметр адрес страницы, в данном случае используется префикс при регистрации ройтера,
* второй параметр валидация
* третий параметр callback - обработчик запроса req - request , запрос от браузера
* res - response, ответ сервера
*/
router.post('/register', registerValidators,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(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;//Экспортирум роутер