@genie-solutions/lambda-toolbelt
Advanced tools
Comparing version 2.5.1 to 2.6.0
@@ -30,3 +30,3 @@ "use strict"; | ||
_regenerator["default"].mark(function _callee(event, context, callback) { | ||
var headerName, _context$genie$jwt, jwtContext, token, algorithm, publicKey, payload; | ||
var headerName, headerKey, _context$genie$jwt, jwtContext, token, algorithm, publicKey, payload; | ||
@@ -38,5 +38,8 @@ return _regenerator["default"].wrap(function _callee$(_context) { | ||
headerName = opts.headerName || 'X-GENIE-ROLES'; | ||
headerKey = Object.keys(event.headers).find(function (key) { | ||
return key.toLowerCase() === headerName.toLowerCase(); | ||
}); | ||
if (event.headers[headerName]) { | ||
_context.next = 3; | ||
if (headerKey) { | ||
_context.next = 4; | ||
break; | ||
@@ -47,11 +50,11 @@ } | ||
case 3: | ||
case 4: | ||
_context$genie$jwt = context.genie.jwt, jwtContext = _context$genie$jwt === void 0 ? {} : _context$genie$jwt; // Support both formats: `Bearer ${token}` and `${token}`. | ||
token = event.headers[headerName].split(' ').pop(); | ||
token = event.headers[headerKey].split(' ').pop(); | ||
algorithm = opts.algorithm || 'RS256'; | ||
_context.next = 8; | ||
_context.next = 9; | ||
return opts.getPublicKey(); | ||
case 8: | ||
case 9: | ||
publicKey = _context.sent; | ||
@@ -67,3 +70,3 @@ payload = (0, _jsonwebtoken.verify)(token, publicKey, { | ||
case 11: | ||
case 12: | ||
case "end": | ||
@@ -86,2 +89,2 @@ return _context.stop(); | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoSldUUGF5bG9hZC50cyJdLCJuYW1lcyI6WyJ3aXRoSldUUGF5bG9hZCIsIm9wdHMiLCJmIiwiZXZlbnQiLCJjb250ZXh0IiwiY2FsbGJhY2siLCJoZWFkZXJOYW1lIiwiaGVhZGVycyIsIkhUVFBFcnJvciIsImdlbmllIiwiand0Iiwiand0Q29udGV4dCIsInRva2VuIiwic3BsaXQiLCJwb3AiLCJhbGdvcml0aG0iLCJnZXRQdWJsaWNLZXkiLCJwdWJsaWNLZXkiLCJwYXlsb2FkIiwiYWxnb3JpdGhtcyIsInBheWxvYWRLZXkiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBVUEsSUFBTUEsY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixDQUFDQyxJQUFEO0FBQUEsU0FBK0MsVUFBQ0MsQ0FBRDtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxxQ0FBMkQsaUJBQy9IQyxLQUQrSCxFQUUvSEMsT0FGK0gsRUFHL0hDLFFBSCtIO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFLekhDLGtCQUFBQSxVQUx5SCxHQUs1R0wsSUFBSSxDQUFDSyxVQUFMLElBQW1CLGVBTHlGOztBQUFBLHNCQU0xSEgsS0FBSyxDQUFDSSxPQUFOLENBQWNELFVBQWQsQ0FOMEg7QUFBQTtBQUFBO0FBQUE7O0FBQUEsd0JBT3ZILElBQUlFLHFCQUFKLENBQWMsR0FBZCxvQkFBOEJGLFVBQTlCLFlBUHVIOztBQUFBO0FBQUEsdUNBU25GRixPQVRtRixDQVN2SEssS0FUdUgsQ0FTOUdDLEdBVDhHLEVBU3pHQyxVQVR5RyxtQ0FTNUYsRUFUNEYsdUJBVy9IOztBQUNNQyxrQkFBQUEsS0FaeUgsR0FZakhULEtBQUssQ0FBQ0ksT0FBTixDQUFjRCxVQUFkLEVBQTBCTyxLQUExQixDQUFnQyxHQUFoQyxFQUFxQ0MsR0FBckMsRUFaaUg7QUFjekhDLGtCQUFBQSxTQWR5SCxHQWM3R2QsSUFBSSxDQUFDYyxTQUFMLElBQWtCLE9BZDJGO0FBQUE7QUFBQSx5QkFldkdkLElBQUksQ0FBQ2UsWUFBTCxFQWZ1Rzs7QUFBQTtBQWV6SEMsa0JBQUFBLFNBZnlIO0FBZ0J6SEMsa0JBQUFBLE9BaEJ5SCxHQWdCL0csMEJBQU9OLEtBQVAsRUFBd0JLLFNBQXhCLEVBQW1DO0FBQ2pERSxvQkFBQUEsVUFBVSxFQUFFLENBQUNKLFNBQUQ7QUFEcUMsbUJBQW5DLENBaEIrRztBQUFBLG1EQW9CeEhiLENBQUMsQ0FDTkMsS0FETSxxQ0FHREMsT0FIQztBQUlKSyxvQkFBQUEsS0FBSyxxQ0FDQUwsT0FBTyxDQUFDSyxLQURSO0FBRUhDLHNCQUFBQSxHQUFHLHFDQUNHQyxVQURILHVDQUVBVixJQUFJLENBQUNtQixVQUFMLElBQW1CLFNBRm5CLEVBRStCRixPQUYvQjtBQUZBO0FBSkQsc0JBWU5iLFFBWk0sQ0FwQnVIOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLFNBQTNEOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxHQUEvQztBQUFBLENBQXZCOztlQW9DZUwsYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHZlcmlmeSB9IGZyb20gJ2pzb253ZWJ0b2tlbic7XG5pbXBvcnQgSFRUUEVycm9yIGZyb20gJy4vaHR0cEVycm9yJztcbmltcG9ydCB7IEhUVFBFdmVudCwgSFRUUENvbnRleHQsIEhUVFBDYWxsYmFjaywgSFRUUE1pZGRsZXdhcmUsIEp3dENvbnRleHQgfSBmcm9tICcuL3R5cGVzJztcblxuaW50ZXJmYWNlIEpXVE9wdHMge1xuICBnZXRQdWJsaWNLZXk6ICgpID0+IFByb21pc2U8c3RyaW5nPlxuICBhbGdvcml0aG0/OiBzdHJpbmdcbiAgcGF5bG9hZEtleT86IHN0cmluZ1xuICBoZWFkZXJOYW1lPzogc3RyaW5nXG59XG5cbmNvbnN0IHdpdGhKV1RQYXlsb2FkID0gKG9wdHM6IEpXVE9wdHMpOiBIVFRQTWlkZGxld2FyZTxKd3RDb250ZXh0PiA9PiAoZjogSFRUUENhbGxiYWNrPEp3dENvbnRleHQ+KTogSFRUUENhbGxiYWNrPEp3dENvbnRleHQ+ID0+IGFzeW5jIChcbiAgZXZlbnQ6IEhUVFBFdmVudCxcbiAgY29udGV4dDogSFRUUENvbnRleHQ8Snd0Q29udGV4dD4sXG4gIGNhbGxiYWNrOiBBV1NMYW1iZGEuQVBJR2F0ZXdheVByb3h5Q2FsbGJhY2ssXG4pOiBQcm9taXNlPG9iamVjdCB8IHZvaWQ+ID0+IHtcbiAgY29uc3QgaGVhZGVyTmFtZSA9IG9wdHMuaGVhZGVyTmFtZSB8fCAnWC1HRU5JRS1ST0xFUyc7XG4gIGlmICghZXZlbnQuaGVhZGVyc1toZWFkZXJOYW1lXSlcbiAgICB0aHJvdyBuZXcgSFRUUEVycm9yKDQwMSwgYE1pc3NpbmcgJHtoZWFkZXJOYW1lfSB0b2tlbmApO1xuXG4gIGNvbnN0IHsgZ2VuaWU6IHsgand0OiBqd3RDb250ZXh0ID0ge30gfSB9ID0gY29udGV4dDtcblxuICAvLyBTdXBwb3J0IGJvdGggZm9ybWF0czogYEJlYXJlciAke3Rva2VufWAgYW5kIGAke3Rva2VufWAuXG4gIGNvbnN0IHRva2VuID0gZXZlbnQuaGVhZGVyc1toZWFkZXJOYW1lXS5zcGxpdCgnICcpLnBvcCgpO1xuXG4gIGNvbnN0IGFsZ29yaXRobSA9IG9wdHMuYWxnb3JpdGhtIHx8ICdSUzI1Nic7XG4gIGNvbnN0IHB1YmxpY0tleSA9IGF3YWl0IG9wdHMuZ2V0UHVibGljS2V5KCk7XG4gIGNvbnN0IHBheWxvYWQgPSB2ZXJpZnkodG9rZW4gYXMgc3RyaW5nLCBwdWJsaWNLZXksIHtcbiAgICBhbGdvcml0aG1zOiBbYWxnb3JpdGhtXSxcbiAgfSk7XG5cbiAgcmV0dXJuIGYoXG4gICAgZXZlbnQsXG4gICAge1xuICAgICAgLi4uY29udGV4dCxcbiAgICAgIGdlbmllOiB7XG4gICAgICAgIC4uLmNvbnRleHQuZ2VuaWUsXG4gICAgICAgIGp3dDoge1xuICAgICAgICAgIC4uLihqd3RDb250ZXh0IGFzIG9iamVjdCksXG4gICAgICAgICAgW29wdHMucGF5bG9hZEtleSB8fCAncGF5bG9hZCddOiBwYXlsb2FkIGFzIG9iamVjdCxcbiAgICAgICAgfSxcbiAgICAgIH1cbiAgICB9LFxuICAgIGNhbGxiYWNrLFxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aEpXVFBheWxvYWQ7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoSldUUGF5bG9hZC50cyJdLCJuYW1lcyI6WyJ3aXRoSldUUGF5bG9hZCIsIm9wdHMiLCJmIiwiZXZlbnQiLCJjb250ZXh0IiwiY2FsbGJhY2siLCJoZWFkZXJOYW1lIiwiaGVhZGVyS2V5IiwiT2JqZWN0Iiwia2V5cyIsImhlYWRlcnMiLCJmaW5kIiwia2V5IiwidG9Mb3dlckNhc2UiLCJIVFRQRXJyb3IiLCJnZW5pZSIsImp3dCIsImp3dENvbnRleHQiLCJ0b2tlbiIsInNwbGl0IiwicG9wIiwiYWxnb3JpdGhtIiwiZ2V0UHVibGljS2V5IiwicHVibGljS2V5IiwicGF5bG9hZCIsImFsZ29yaXRobXMiLCJwYXlsb2FkS2V5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQVVBLElBQU1BLGNBQWMsR0FBRyxTQUFqQkEsY0FBaUIsQ0FBQ0MsSUFBRDtBQUFBLFNBQStDLFVBQUNDLENBQUQ7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEscUNBQTJELGlCQUMvSEMsS0FEK0gsRUFFL0hDLE9BRitILEVBRy9IQyxRQUgrSDtBQUFBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBS3pIQyxrQkFBQUEsVUFMeUgsR0FLNUdMLElBQUksQ0FBQ0ssVUFBTCxJQUFtQixlQUx5RjtBQU16SEMsa0JBQUFBLFNBTnlILEdBTTdHQyxNQUFNLENBQUNDLElBQVAsQ0FBWU4sS0FBSyxDQUFDTyxPQUFsQixFQUEyQkMsSUFBM0IsQ0FBZ0MsVUFBQUMsR0FBRztBQUFBLDJCQUFJQSxHQUFHLENBQUNDLFdBQUosT0FBc0JQLFVBQVUsQ0FBQ08sV0FBWCxFQUExQjtBQUFBLG1CQUFuQyxDQU42Rzs7QUFBQSxzQkFRMUhOLFNBUjBIO0FBQUE7QUFBQTtBQUFBOztBQUFBLHdCQVN2SCxJQUFJTyxxQkFBSixDQUFjLEdBQWQsb0JBQThCUixVQUE5QixZQVR1SDs7QUFBQTtBQUFBLHVDQVduRkYsT0FYbUYsQ0FXdkhXLEtBWHVILENBVzlHQyxHQVg4RyxFQVd6R0MsVUFYeUcsbUNBVzVGLEVBWDRGLHVCQWEvSDs7QUFDTUMsa0JBQUFBLEtBZHlILEdBY2pIZixLQUFLLENBQUNPLE9BQU4sQ0FBY0gsU0FBZCxFQUF5QlksS0FBekIsQ0FBK0IsR0FBL0IsRUFBb0NDLEdBQXBDLEVBZGlIO0FBZ0J6SEMsa0JBQUFBLFNBaEJ5SCxHQWdCN0dwQixJQUFJLENBQUNvQixTQUFMLElBQWtCLE9BaEIyRjtBQUFBO0FBQUEseUJBaUJ2R3BCLElBQUksQ0FBQ3FCLFlBQUwsRUFqQnVHOztBQUFBO0FBaUJ6SEMsa0JBQUFBLFNBakJ5SDtBQWtCekhDLGtCQUFBQSxPQWxCeUgsR0FrQi9HLDBCQUFPTixLQUFQLEVBQXdCSyxTQUF4QixFQUFtQztBQUNqREUsb0JBQUFBLFVBQVUsRUFBRSxDQUFDSixTQUFEO0FBRHFDLG1CQUFuQyxDQWxCK0c7QUFBQSxtREFzQnhIbkIsQ0FBQyxDQUNOQyxLQURNLHFDQUdEQyxPQUhDO0FBSUpXLG9CQUFBQSxLQUFLLHFDQUNBWCxPQUFPLENBQUNXLEtBRFI7QUFFSEMsc0JBQUFBLEdBQUcscUNBQ0dDLFVBREgsdUNBRUFoQixJQUFJLENBQUN5QixVQUFMLElBQW1CLFNBRm5CLEVBRStCRixPQUYvQjtBQUZBO0FBSkQsc0JBWU5uQixRQVpNLENBdEJ1SDs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxTQUEzRDs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsR0FBL0M7QUFBQSxDQUF2Qjs7ZUFzQ2VMLGMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB2ZXJpZnkgfSBmcm9tICdqc29ud2VidG9rZW4nO1xuaW1wb3J0IEhUVFBFcnJvciBmcm9tICcuL2h0dHBFcnJvcic7XG5pbXBvcnQgeyBIVFRQRXZlbnQsIEhUVFBDb250ZXh0LCBIVFRQQ2FsbGJhY2ssIEhUVFBNaWRkbGV3YXJlLCBKd3RDb250ZXh0IH0gZnJvbSAnLi90eXBlcyc7XG5cbmludGVyZmFjZSBKV1RPcHRzIHtcbiAgZ2V0UHVibGljS2V5OiAoKSA9PiBQcm9taXNlPHN0cmluZz5cbiAgYWxnb3JpdGhtPzogc3RyaW5nXG4gIHBheWxvYWRLZXk/OiBzdHJpbmdcbiAgaGVhZGVyTmFtZT86IHN0cmluZ1xufVxuXG5jb25zdCB3aXRoSldUUGF5bG9hZCA9IChvcHRzOiBKV1RPcHRzKTogSFRUUE1pZGRsZXdhcmU8Snd0Q29udGV4dD4gPT4gKGY6IEhUVFBDYWxsYmFjazxKd3RDb250ZXh0Pik6IEhUVFBDYWxsYmFjazxKd3RDb250ZXh0PiA9PiBhc3luYyAoXG4gIGV2ZW50OiBIVFRQRXZlbnQsXG4gIGNvbnRleHQ6IEhUVFBDb250ZXh0PEp3dENvbnRleHQ+LFxuICBjYWxsYmFjazogQVdTTGFtYmRhLkFQSUdhdGV3YXlQcm94eUNhbGxiYWNrLFxuKTogUHJvbWlzZTxvYmplY3QgfCB2b2lkPiA9PiB7XG4gIGNvbnN0IGhlYWRlck5hbWUgPSBvcHRzLmhlYWRlck5hbWUgfHwgJ1gtR0VOSUUtUk9MRVMnO1xuICBjb25zdCBoZWFkZXJLZXkgPSBPYmplY3Qua2V5cyhldmVudC5oZWFkZXJzKS5maW5kKGtleSA9PiBrZXkudG9Mb3dlckNhc2UoKSA9PT0gaGVhZGVyTmFtZS50b0xvd2VyQ2FzZSgpKTtcblxuICBpZiAoIWhlYWRlcktleSlcbiAgICB0aHJvdyBuZXcgSFRUUEVycm9yKDQwMSwgYE1pc3NpbmcgJHtoZWFkZXJOYW1lfSB0b2tlbmApO1xuXG4gIGNvbnN0IHsgZ2VuaWU6IHsgand0OiBqd3RDb250ZXh0ID0ge30gfSB9ID0gY29udGV4dDtcblxuICAvLyBTdXBwb3J0IGJvdGggZm9ybWF0czogYEJlYXJlciAke3Rva2VufWAgYW5kIGAke3Rva2VufWAuXG4gIGNvbnN0IHRva2VuID0gZXZlbnQuaGVhZGVyc1toZWFkZXJLZXldLnNwbGl0KCcgJykucG9wKCk7XG5cbiAgY29uc3QgYWxnb3JpdGhtID0gb3B0cy5hbGdvcml0aG0gfHwgJ1JTMjU2JztcbiAgY29uc3QgcHVibGljS2V5ID0gYXdhaXQgb3B0cy5nZXRQdWJsaWNLZXkoKTtcbiAgY29uc3QgcGF5bG9hZCA9IHZlcmlmeSh0b2tlbiBhcyBzdHJpbmcsIHB1YmxpY0tleSwge1xuICAgIGFsZ29yaXRobXM6IFthbGdvcml0aG1dLFxuICB9KTtcblxuICByZXR1cm4gZihcbiAgICBldmVudCxcbiAgICB7XG4gICAgICAuLi5jb250ZXh0LFxuICAgICAgZ2VuaWU6IHtcbiAgICAgICAgLi4uY29udGV4dC5nZW5pZSxcbiAgICAgICAgand0OiB7XG4gICAgICAgICAgLi4uKGp3dENvbnRleHQgYXMgb2JqZWN0KSxcbiAgICAgICAgICBbb3B0cy5wYXlsb2FkS2V5IHx8ICdwYXlsb2FkJ106IHBheWxvYWQgYXMgb2JqZWN0LFxuICAgICAgICB9LFxuICAgICAgfVxuICAgIH0sXG4gICAgY2FsbGJhY2ssXG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCB3aXRoSldUUGF5bG9hZDtcbiJdfQ== |
@@ -64,3 +64,3 @@ "use strict"; | ||
}))); | ||
it('should throw a 401 if header not present', | ||
it('should support x-Genie-ROles case-insensitive header', | ||
/*#__PURE__*/ | ||
@@ -78,7 +78,11 @@ (0, _asyncToGenerator2["default"])( | ||
return Promise.resolve(secret); | ||
} | ||
}, | ||
algorithm: 'HS256', | ||
payloadKey: 'roles' | ||
}; | ||
lambda = jest.fn(); | ||
event = { | ||
headers: {} | ||
headers: { | ||
'x-Genie-ROles': "Bearer ".concat(sampleToken) | ||
} | ||
}; | ||
@@ -90,6 +94,16 @@ context = { | ||
_context2.next = 7; | ||
return expect((0, _withJWTPayload["default"])(opts)(lambda)(event, context, callback)).rejects.toThrow('Missing X-GENIE-ROLES token'); | ||
return (0, _withJWTPayload["default"])(opts)(lambda)(event, context, callback); | ||
case 7: | ||
expect(lambda).not.toHaveBeenCalled(); | ||
expect(lambda).toHaveBeenCalledWith(event, expect.objectContaining({ | ||
genie: { | ||
jwt: expect.objectContaining({ | ||
roles: expect.objectContaining({ | ||
sub: '1234567890', | ||
name: 'John Doe', | ||
iat: 1516239022 | ||
}) | ||
}) | ||
} | ||
}), callback); | ||
@@ -103,3 +117,3 @@ case 8: | ||
}))); | ||
it('should throw an error if invalid token provided', | ||
it('should throw a 401 if header not present', | ||
/*#__PURE__*/ | ||
@@ -109,3 +123,3 @@ (0, _asyncToGenerator2["default"])( | ||
_regenerator["default"].mark(function _callee3() { | ||
var event, context, callback, opts; | ||
var opts, lambda, event, context, callback; | ||
return _regenerator["default"].wrap(function _callee3$(_context3) { | ||
@@ -115,3 +129,39 @@ while (1) { | ||
case 0: | ||
opts = { | ||
getPublicKey: function getPublicKey() { | ||
return Promise.resolve(secret); | ||
} | ||
}; | ||
lambda = jest.fn(); | ||
event = { | ||
headers: {} | ||
}; | ||
context = { | ||
genie: {} | ||
}; | ||
callback = jest.fn(); | ||
_context3.next = 7; | ||
return expect((0, _withJWTPayload["default"])(opts)(lambda)(event, context, callback)).rejects.toThrow('Missing X-GENIE-ROLES token'); | ||
case 7: | ||
expect(lambda).not.toHaveBeenCalled(); | ||
case 8: | ||
case "end": | ||
return _context3.stop(); | ||
} | ||
} | ||
}, _callee3); | ||
}))); | ||
it('should throw an error if invalid token provided', | ||
/*#__PURE__*/ | ||
(0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee4() { | ||
var event, context, callback, opts; | ||
return _regenerator["default"].wrap(function _callee4$(_context4) { | ||
while (1) { | ||
switch (_context4.prev = _context4.next) { | ||
case 0: | ||
event = { | ||
headers: { | ||
@@ -130,3 +180,3 @@ 'X-GENIE-ROLES': "Bearer invalidtokenisinvalid" | ||
}; | ||
_context3.next = 6; | ||
_context4.next = 6; | ||
return expect((0, _withJWTPayload["default"])(opts)(callback)(event, context, callback)).rejects.toThrow('jwt malformed'); | ||
@@ -139,8 +189,8 @@ | ||
case "end": | ||
return _context3.stop(); | ||
return _context4.stop(); | ||
} | ||
} | ||
}, _callee3); | ||
}, _callee4); | ||
}))); | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoSldUUGF5bG9hZC5zcGVjLnRzIl0sIm5hbWVzIjpbInNhbXBsZVRva2VuIiwic2VjcmV0IiwiZGVzY3JpYmUiLCJpdCIsIm9wdHMiLCJnZXRQdWJsaWNLZXkiLCJQcm9taXNlIiwicmVzb2x2ZSIsImFsZ29yaXRobSIsInBheWxvYWRLZXkiLCJsYW1iZGEiLCJqZXN0IiwiZm4iLCJldmVudCIsImhlYWRlcnMiLCJjb250ZXh0IiwiZ2VuaWUiLCJjYWxsYmFjayIsImV4cGVjdCIsInRvSGF2ZUJlZW5DYWxsZWRXaXRoIiwib2JqZWN0Q29udGFpbmluZyIsImp3dCIsInJvbGVzIiwic3ViIiwibmFtZSIsImlhdCIsInJlamVjdHMiLCJ0b1Rocm93Iiwibm90IiwidG9IYXZlQmVlbkNhbGxlZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQTs7QUFHQSxJQUFNQSxXQUFXLEdBQUcsNkpBQXBCO0FBQ0EsSUFBTUMsTUFBTSxHQUFHLHFCQUFmO0FBRUFDLFFBQVEsQ0FBQyxnQkFBRCxFQUFtQixZQUFNO0FBQy9CQyxFQUFBQSxFQUFFLENBQUMsK0NBQUQ7QUFBQTtBQUFBO0FBQUE7QUFBQSwrQkFBa0Q7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQzVDQyxZQUFBQSxJQUQ0QyxHQUNyQztBQUNYQyxjQUFBQSxZQUFZLEVBQUU7QUFBQSx1QkFBTUMsT0FBTyxDQUFDQyxPQUFSLENBQWdCTixNQUFoQixDQUFOO0FBQUEsZUFESDtBQUVYTyxjQUFBQSxTQUFTLEVBQUUsT0FGQTtBQUdYQyxjQUFBQSxVQUFVLEVBQUU7QUFIRCxhQURxQztBQU01Q0MsWUFBQUEsTUFONEMsR0FNbkNDLElBQUksQ0FBQ0MsRUFBTCxFQU5tQztBQU81Q0MsWUFBQUEsS0FQNEMsR0FPcEM7QUFDWkMsY0FBQUEsT0FBTyxFQUFFO0FBQ1Asa0RBQTJCZCxXQUEzQjtBQURPO0FBREcsYUFQb0M7QUFZNUNlLFlBQUFBLE9BWjRDLEdBWWxDO0FBQ2RDLGNBQUFBLEtBQUss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VyxHQUFqQixDQUFxQkMsZ0JBQXJCOztBQVRvRDtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxHQUFwRCxHQUFGO0FBV0QsQ0F4RE8sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB3aXRoSldUUGF5bG9hZCBmcm9tICcuL3dpdGhKV1RQYXlsb2FkJztcbmltcG9ydCB7IEhUVFBFdmVudCwgSFRUUENvbnRleHQsIEp3dENvbnRleHQgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3Qgc2FtcGxlVG9rZW4gPSAnZXlKaGJHY2lPaUpJVXpJMU5pSXNJblI1Y0NJNklrcFhWQ0o5LmV5SnpkV0lpT2lJeE1qTTBOVFkzT0Rrd0lpd2libUZ0WlNJNklrcHZhRzRnUkc5bElpd2lhV0YwSWpveE5URTJNak01TURJeWZRLlNmbEt4d1JKU01lS0tGMlFUNGZ3cE1lSmYzNlBPazZ5SlZfYWRRc3N3NWMnO1xuY29uc3Qgc2VjcmV0ID0gJ3lvdXItMjU2LWJpdC1zZWNyZXQnO1xuXG5kZXNjcmliZSgnd2l0aEpXVFBheWxvYWQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQgcG9wdWxhdGUgY29udGV4dCB3aXRoIHBhcnNlZCBKV1QgVG9rZW4nLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgb3B0cyA9IHtcbiAgICAgIGdldFB1YmxpY0tleTogKCkgPT4gUHJvbWlzZS5yZXNvbHZlKHNlY3JldCksXG4gICAgICBhbGdvcml0aG06ICdIUzI1NicsXG4gICAgICBwYXlsb2FkS2V5OiAncm9sZXMnLFxuICAgIH07XG4gICAgY29uc3QgbGFtYmRhID0gamVzdC5mbigpO1xuICAgIGNvbnN0IGV2ZW50ID0ge1xuICAgICAgaGVhZGVyczoge1xuICAgICAgICAnWC1HRU5JRS1ST0xFUyc6IGBCZWFyZXIgJHtzYW1wbGVUb2tlbn1gLFxuICAgICAgfSxcbiAgICB9O1xuICAgIGNvbnN0IGNvbnRleHQgPSB7XG4gICAgICBnZW5pZToge30sXG4gICAgfTtcbiAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcblxuICAgIGF3YWl0IHdpdGhKV1RQYXlsb2FkKG9wdHMpKGxhbWJkYSkoZXZlbnQgYXMgdW5rbm93biBhcyBIVFRQRXZlbnQsIGNvbnRleHQgYXMgSFRUUENvbnRleHQ8Snd0Q29udGV4dD4sIGNhbGxiYWNrKTtcbiAgICBleHBlY3QobGFtYmRhKS50b0hhdmVCZWVuQ2FsbGVkV2l0aChldmVudCwgZXhwZWN0Lm9iamVjdENvbnRhaW5pbmcoe1xuICAgICAgZ2VuaWU6IHtcbiAgICAgICAgand0OiBleHBlY3Qub2JqZWN0Q29udGFpbmluZyh7XG4gICAgICAgICAgcm9sZXM6IGV4cGVjdC5vYmplY3RDb250YWluaW5nKHtcbiAgICAgICAgICAgIHN1YjogJzEyMzQ1Njc4OTAnLFxuICAgICAgICAgICAgbmFtZTogJ0pvaG4gRG9lJyxcbiAgICAgICAgICAgIGlhdDogMTUxNjIzOTAyMixcbiAgICAgICAgICB9KSxcbiAgICAgICAgfSksXG4gICAgICB9LFxuICAgIH0pLCBjYWxsYmFjayk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgdGhyb3cgYSA0MDEgaWYgaGVhZGVyIG5vdCBwcmVzZW50JywgYXN5bmMgKCkgPT4ge1xuICAgIGNvbnN0IG9wdHMgPSB7XG4gICAgICBnZXRQdWJsaWNLZXk6ICgpID0+IFByb21pc2UucmVzb2x2ZShzZWNyZXQpLFxuICAgIH07XG4gICAgY29uc3QgbGFtYmRhID0gamVzdC5mbigpO1xuICAgIGNvbnN0IGV2ZW50ID0geyBoZWFkZXJzOiB7IH0gfTtcbiAgICBjb25zdCBjb250ZXh0ID0geyBnZW5pZToge30gfTtcbiAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKTtcblxuICAgIGF3YWl0IGV4cGVjdCh3aXRoSldUUGF5bG9hZChvcHRzKShsYW1iZGEpKGV2ZW50IGFzIHVua25vd24gYXMgSFRUUEV2ZW50LCBjb250ZXh0IGFzIEhUVFBDb250ZXh0PEp3dENvbnRleHQ+LCBjYWxsYmFjaykpLnJlamVjdHMudG9UaHJvdygnTWlzc2luZyBYLUdFTklFLVJPTEVTIHRva2VuJyk7XG4gICAgZXhwZWN0KGxhbWJkYSkubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCB0aHJvdyBhbiBlcnJvciBpZiBpbnZhbGlkIHRva2VuIHByb3ZpZGVkJywgYXN5bmMgKCkgPT4ge1xuICAgIGNvbnN0IGV2ZW50ID0geyBoZWFkZXJzOiB7ICdYLUdFTklFLVJPTEVTJzogYEJlYXJlciBpbnZhbGlkdG9rZW5pc2ludmFsaWRgIH0gfTtcbiAgICBjb25zdCBjb250ZXh0ID0geyBnZW5pZToge30gfTtcbiAgICBjb25zdCBjYWxsYmFjayA9IGplc3QuZm4oKCkgPT4ge30pO1xuICAgIGNvbnN0IG9wdHMgPSB7XG4gICAgICBnZXRQdWJsaWNLZXk6ICgpID0+IFByb21pc2UucmVzb2x2ZShzZWNyZXQpLFxuICAgIH07XG5cbiAgICBhd2FpdCBleHBlY3Qod2l0aEpXVFBheWxvYWQob3B0cykoY2FsbGJhY2spKGV2ZW50IGFzIHVua25vd24gYXMgSFRUUEV2ZW50LCBjb250ZXh0IGFzIEhUVFBDb250ZXh0PEp3dENvbnRleHQ+LCBjYWxsYmFjaykpLnJlamVjdHMudG9UaHJvdygnand0IG1hbGZvcm1lZCcpO1xuICAgIGV4cGVjdChjYWxsYmFjaykubm90LnRvSGF2ZUJlZW5DYWxsZWQoKTtcbiAgfSk7XG59KTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/withJWTPayload.spec.ts"],"names":["sampleToken","secret","describe","it","opts","getPublicKey","Promise","resolve","algorithm","payloadKey","lambda","jest","fn","event","headers","context","genie","callback","expect","toHaveBeenCalledWith","objectContaining","jwt","roles","sub","name","iat","rejects","toThrow","not","toHaveBeenCalled"],"mappings":"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","sourcesContent":["import withJWTPayload from './withJWTPayload';\nimport { HTTPEvent, HTTPContext, JwtContext } from './types';\n\nconst sampleToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c';\nconst secret = 'your-256-bit-secret';\n\ndescribe('withJWTPayload', () => {\n  it('should populate context with parsed JWT Token', async () => {\n    const opts = {\n      getPublicKey: () => Promise.resolve(secret),\n      algorithm: 'HS256',\n      payloadKey: 'roles',\n    };\n    const lambda = jest.fn();\n    const event = {\n      headers: {\n        'X-GENIE-ROLES': `Bearer ${sampleToken}`,\n      },\n    };\n    const context = {\n      genie: {},\n    };\n    const callback = jest.fn();\n\n    await withJWTPayload(opts)(lambda)(event as unknown as HTTPEvent, context as HTTPContext<JwtContext>, callback);\n    expect(lambda).toHaveBeenCalledWith(event, expect.objectContaining({\n      genie: {\n        jwt: expect.objectContaining({\n          roles: expect.objectContaining({\n            sub: '1234567890',\n            name: 'John Doe',\n            iat: 1516239022,\n          }),\n        }),\n      },\n    }), callback);\n  });\n\n  it('should support x-Genie-ROles case-insensitive header', async () => {\n    const opts = {\n      getPublicKey: () => Promise.resolve(secret),\n      algorithm: 'HS256',\n      payloadKey: 'roles',\n    };\n    const lambda = jest.fn();\n    const event = {\n      headers: {\n        'x-Genie-ROles': `Bearer ${sampleToken}`,\n      },\n    };\n    const context = {\n      genie: {},\n    };\n    const callback = jest.fn();\n\n    await withJWTPayload(opts)(lambda)(event as unknown as HTTPEvent, context as HTTPContext<JwtContext>, callback);\n    expect(lambda).toHaveBeenCalledWith(event, expect.objectContaining({\n      genie: {\n        jwt: expect.objectContaining({\n          roles: expect.objectContaining({\n            sub: '1234567890',\n            name: 'John Doe',\n            iat: 1516239022,\n          }),\n        }),\n      },\n    }), callback);\n  });\n\n  it('should throw a 401 if header not present', async () => {\n    const opts = {\n      getPublicKey: () => Promise.resolve(secret),\n    };\n    const lambda = jest.fn();\n    const event = { headers: { } };\n    const context = { genie: {} };\n    const callback = jest.fn();\n\n    await expect(withJWTPayload(opts)(lambda)(event as unknown as HTTPEvent, context as HTTPContext<JwtContext>, callback)).rejects.toThrow('Missing X-GENIE-ROLES token');\n    expect(lambda).not.toHaveBeenCalled();\n  });\n\n  it('should throw an error if invalid token provided', async () => {\n    const event = { headers: { 'X-GENIE-ROLES': `Bearer invalidtokenisinvalid` } };\n    const context = { genie: {} };\n    const callback = jest.fn(() => {});\n    const opts = {\n      getPublicKey: () => Promise.resolve(secret),\n    };\n\n    await expect(withJWTPayload(opts)(callback)(event as unknown as HTTPEvent, context as HTTPContext<JwtContext>, callback)).rejects.toThrow('jwt malformed');\n    expect(callback).not.toHaveBeenCalled();\n  });\n});\n"]} |
{ | ||
"name": "@genie-solutions/lambda-toolbelt", | ||
"version": "2.5.1", | ||
"version": "2.6.0", | ||
"description": "Toolbelt for creating Lambda functions", | ||
@@ -5,0 +5,0 @@ "access": "public", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
12188852
28520