-
Notifications
You must be signed in to change notification settings - Fork 299
Expand file tree
/
Copy pathauthorization.controller.js
More file actions
38 lines (36 loc) · 1.32 KB
/
Copy pathauthorization.controller.js
File metadata and controls
38 lines (36 loc) · 1.32 KB
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
const jwtSecret = require('../../common/config/env.config.js').jwt_secret,
jwt = require('jsonwebtoken');
const crypto = require('crypto');
const uuid = require('uuid');
exports.login = (req, res) => {
try {
let salt = crypto.randomBytes(16).toString('base64');
let hash = crypto.createHmac('sha512', salt).update(req.body.userId + jwtSecret).digest("base64");
let b = Buffer.from(hash);
let refresh_token = salt + '.' + b.toString('base64');
let token = jwt.sign({
userId: req.body.userId,
email: req.body.email,
permissionLevel: req.body.permissionLevel,
provider: req.body.provider,
name: req.body.name,
}, jwtSecret, {expiresIn: 36000});
res.status(201).send({accessToken: token, refreshToken: refresh_token});
} catch (err) {
res.status(500).send({errors: err});
}
};
exports.refresh_token = (req, res) => {
try {
let token = jwt.sign({
userId: req.jwt.userId,
email: req.jwt.email,
permissionLevel: req.jwt.permissionLevel,
provider: req.jwt.provider,
name: req.jwt.name,
}, jwtSecret, {expiresIn: 36000});
res.status(201).send({id: token});
} catch (err) {
res.status(500).send({errors: err});
}
};