From 7da6c6a8e4a3590dfb8569b9fc24b4054552c96f Mon Sep 17 00:00:00 2001 From: eug-vs Date: Sun, 15 Nov 2020 03:46:51 +0300 Subject: feat: setup authentication --- src/services/users/user.hooks.js | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 src/services/users/user.hooks.js (limited to 'src/services/users/user.hooks.js') diff --git a/src/services/users/user.hooks.js b/src/services/users/user.hooks.js new file mode 100644 index 0000000..daeda68 --- /dev/null +++ b/src/services/users/user.hooks.js @@ -0,0 +1,21 @@ +const { hooks } = require ('@feathersjs/authentication-local'); +const { NotAuthenticated } = require('@feathersjs/errors'); + +const compareUser = async context => { + if (context.id !== context.params.user._id.toString()) { + throw new NotAuthenticated('You can only PATCH/UPDATE your own user!'); + } + return context; +}; + + +module.exports = { + after: { + all: hooks.protect('password') + }, + before: { + patch: [compareUser], + update: [compareUser] + } +}; + -- cgit v1.2.3