56 lines
1.3 KiB
JavaScript
Raw Permalink Normal View History

2017-11-16 14:12:03 +01:00
'use strict';
/**
* Jwt.js service
*
* @description: A set of functions similar to controller's actions to avoid code duplication.
*/
const _ = require('lodash');
const jwt = require('jsonwebtoken');
2018-01-26 07:32:28 +01:00
2021-07-08 11:20:13 +02:00
module.exports = ({ strapi }) => ({
getToken(ctx) {
2021-11-15 17:54:17 +01:00
let token;
if (ctx.request && ctx.request.header && ctx.request.header.authorization) {
2021-11-15 17:54:17 +01:00
const parts = ctx.request.header.authorization.split(/\s+/);
2021-11-15 17:54:17 +01:00
if (parts[0].toLowerCase() !== 'bearer' || parts.length !== 2) {
return null;
}
2021-11-15 17:54:17 +01:00
token = parts[1];
} else {
2021-11-15 17:54:17 +01:00
return null;
}
return this.verify(token);
2017-12-07 15:27:11 +01:00
},
issue(payload, jwtOptions = {}) {
_.defaults(jwtOptions, strapi.config.get('plugin::users-permissions.jwt'));
2017-12-07 15:27:11 +01:00
return jwt.sign(
_.clone(payload.toJSON ? payload.toJSON() : payload),
strapi.config.get('plugin::users-permissions.jwtSecret'),
jwtOptions
2017-12-07 15:27:11 +01:00
);
},
verify(token) {
2022-08-08 23:33:39 +02:00
return new Promise((resolve, reject) => {
jwt.verify(
token,
strapi.config.get('plugin::users-permissions.jwtSecret'),
2022-08-08 23:33:39 +02:00
{},
(err, tokenPayload = {}) => {
if (err) {
return reject(new Error('Invalid token.'));
}
resolve(tokenPayload);
2017-12-07 15:27:11 +01:00
}
2022-08-08 23:33:39 +02:00
);
2017-12-07 15:27:11 +01:00
});
},
2021-07-08 11:20:13 +02:00
});