-
Notifications
You must be signed in to change notification settings - Fork 0
/
utils.js
77 lines (64 loc) · 2.05 KB
/
utils.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
'use strict';
// Get process environments
const { POSTMAN_EMAIL, POSTMAN_PASSWORD } = process.env;
const NodeMailer = require('nodemailer');
const { User } = require('./models');
const _ = require('lodash');
const self = module.exports = {
/**
* Validation function for 'hapi-auth-jwt2' plugin.
* @param {Object} decoded
* @param {Object} req
* @param {Object} h
* @returns {Promise<{isValid: boolean}>}
*/
validate: async (decoded, req, h) => {
const { decrypt } = req.server.methods;
const decryptedUserId = await decrypt(decoded.userId);
const user = await User.findUserById(decryptedUserId, true);
if(!user || decoded.type !== 'access') {
return { isValid: false };
}
const encodedRefreshTokenData = user.token.split('.')[1];
const refreshTokenData = JSON.parse(Buffer.from(encodedRefreshTokenData, 'base64'));
if (refreshTokenData.tokenId !== decoded.tokenId) {
return { isValid: false };
}
req.info.userClient = _.omit(user, ['password', 'token', '__v']);
return { isValid: true };
},
/**
* Create transporter for sending email
* @param {String} service
* @returns {Promise<*>}
*/
getTransporter: (service = 'gmail') => {
return new Promise((resolve) => {
const transporter = NodeMailer.createTransport({
service,
auth: {
user: POSTMAN_EMAIL,
pass: POSTMAN_PASSWORD
}
});
resolve(transporter);
});
},
/**
* Create mail config
* @param {Object} options
* @returns {Promise<Object>}
*/
createMailOptions: (options) => {
return new Promise((resolve) => {
const {email, subject, html} = options;
const mailOptions = {
from: POSTMAN_EMAIL,
to: email,
subject,
html
};
resolve(mailOptions);
});
}
};