Renat
Ребята, всем привет! Я начинающий в node.js. Как реализовать авторизацию следующую? Проект учебный. Пользователь для входа в личный кабинет должен ввести логин(email), ему приходить на email 4-значный код подтверждения. Далее происходит сверка 4-ех значного кода и возврат идентификатора сессии. Отправку пользователю сгенерированного 4-значного кода я могу реализовать через Nodemailer, не уверен что это правильное решение)) Непонятно как реализовать саму авторизацию. Есть схожая стратегия в passport.js или в какое-нибудь другое готовое решение, которая позволит реализовать такую авторизацию ? Смотрел стратегии в passport js, но не нашел сходу что-то похожего. Буду признателен за информацию.
1. Пользователь вводит email
2. генерируешь код и куда-нибудь сохраняешь пару email+код
Можно просто в глобальную переменную, если нет масштабирования и пофиг на потери при перезапуске сервера (для учебного потянет).
Но лучше в БД, конечно.
3. В письмо также добавляешь ссылку. Тебе надо понять, что код вводит именно этот человек.
Но тут вариантов много. (Возможно, в БД ничего и сохранять не надо будет)
4. Отправляешь письмо. Либо сам, либо через какой-нибудь почтовый сервис. Для учебного можно условно взять свой smtp с личной почты. А можео saas типа mailgun.
5. Пользователь переходит по ссылке и вводит код.
6. На сервере сверяешь код+мыло
7. добавляешь мыло / id пользователя в сессию
8. по сессии определяешь, авторизован ли юзер