diff options
author | 2022-06-01 18:25:47 +0100 | |
---|---|---|
committer | 2022-06-01 19:22:56 +0100 | |
commit | 3a215e58fb9f867ff8788d9d30cc55fbebb4ae23 (patch) | |
tree | 5863173a59ba6c9a6332398a6342f18f5b04347f /pages/api | |
parent | 6caea2b785b72edc33954674b9c96b3e373441b4 (diff) | |
parent | 684377e55cc239aa1f09ef9c65e1f768e8733fa5 (diff) | |
download | my_apps-3a215e58fb9f867ff8788d9d30cc55fbebb4ae23.tar.gz my_apps-3a215e58fb9f867ff8788d9d30cc55fbebb4ae23.tar.bz2 my_apps-3a215e58fb9f867ff8788d9d30cc55fbebb4ae23.zip |
Merge branch 'log_activity'
Diffstat (limited to 'pages/api')
-rw-r--r-- | pages/api/login.js | 8 | ||||
-rw-r--r-- | pages/api/password.js | 11 | ||||
-rw-r--r-- | pages/api/register.js | 14 | ||||
-rw-r--r-- | pages/api/verify.js | 9 |
4 files changed, 39 insertions, 3 deletions
diff --git a/pages/api/login.js b/pages/api/login.js index 1e9f816..283f185 100644 --- a/pages/api/login.js +++ b/pages/api/login.js @@ -1,10 +1,10 @@ import withSession from 'hocs/withSession' import dbConnect from 'configs/dbConnect' import User from 'models/User' +import log from 'helpers/log' export default withSession(async (req, res) => { const { method } = req - await dbConnect() switch (method) { @@ -17,8 +17,14 @@ export default withSession(async (req, res) => { const user = { _id, email, isVerified, isLoggedIn: true, noteList, theme, language } req.session.set('user', user) await req.session.save() + log({ email, action: 'login' }) res.status(201).json(user) } catch (error) { + log({ + email: JSON.parse(req.body)?.email, + action: 'login', + error, + }) res.status(400).json({ isLoggedIn: false }) } break diff --git a/pages/api/password.js b/pages/api/password.js index 871c9e6..a491e15 100644 --- a/pages/api/password.js +++ b/pages/api/password.js @@ -3,6 +3,7 @@ import withSession from 'hocs/withSession' import sendMail from 'configs/sendMail' import mailData from 'helpers/email' import User from 'models/User' +import log from 'helpers/log' export default withSession(async (req, res) => { await dbConnect() @@ -16,11 +17,19 @@ export default withSession(async (req, res) => { req.session.set('user', user) await req.session.save() - sendMail({to: user.email, ...mailData('p', user.language)}) + try { + sendMail({to: user.email, ...mailData('p', user.language)}) + } finally {} + log({ email: user.email, action: 'change password' }) res.status(200).json(user) } } catch (error) { + log({ + error, + email: req.session?.get('user')?.email, + action: 'change password', + }) if (error?.message === 'Wrong password') { res.status(401).send({ error: 'Wrong password' }) } else { diff --git a/pages/api/register.js b/pages/api/register.js index 56c8ba9..1ff12e1 100644 --- a/pages/api/register.js +++ b/pages/api/register.js @@ -4,6 +4,7 @@ import withSession from 'hocs/withSession' import mailData from 'helpers/email' import User from 'models/User' import NoteList from 'apps/Notes/models/NoteList' +import log from 'helpers/log' export default withSession(async (req, res) => { const conn = await dbConnect() @@ -20,16 +21,27 @@ export default withSession(async (req, res) => { if (!email) { throw new Error('Something went wrong') } - sendMail({to: body.email, ...mailData('v', language, key)}) + try { + sendMail({to: email, ...mailData('v', language, key)}) + } catch (e) { + log({ email, action: 'register_mail', error: e }) + } const user = { _id, email, noteList, theme, language, isVerified: false, isLoggedIn: true } req.session.set('user', user) await req.session.save() session.endSession() + + log({ email, action: 'register' }) res.status(201).json(user) }) } catch (error) { + log({ + email: JSON.parse(req.body)?.email, + action: 'register', + error, + }) res.status(400).json({ isLoggedIn: false }) } break diff --git a/pages/api/verify.js b/pages/api/verify.js index edcc7a9..623d087 100644 --- a/pages/api/verify.js +++ b/pages/api/verify.js @@ -3,6 +3,7 @@ import sendMail from 'configs/sendMail' import User from 'models/User' import withSession from 'hocs/withSession' import mailData from 'helpers/email' +import log from 'helpers/log' export default withSession(async (req, res) => { await dbConnect() @@ -19,8 +20,10 @@ export default withSession(async (req, res) => { const response = await sendMail({to: email, ...mailData('v', l, key)}) if (!response?.accepted?.length) { throw new Error('Something went wrong') } + log({ email, action: 'verify_mail' }) res.status(204).send() } catch (error) { + log({ email: req.session.get('user'), action: 'verify_mail', error }) res.status(400).send() } break @@ -30,9 +33,15 @@ export default withSession(async (req, res) => { const user = await User.verifyUser(req.body._id, req.body.key) req.session.set('user', user) await req.session.save() + log({ email: user.email, action: 'verify' }) res.status(200).json(user) } } catch (error) { + log({ + email: req.session.get('user')?.email, + action: 'verify', + error, + }) res.status(400).send() } break |