diff options
author | Eugene Sokolov <eug-vs@keemail.me> | 2020-08-17 23:42:34 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-17 23:42:34 +0300 |
commit | 5097e7b05d260b378f315aa48aa577692b0495dd (patch) | |
tree | dde301d6529fc1140e413c9cd3db8c4033cff552 /services/polls | |
parent | c43e6d185b7606ff8c0d038746b9e376e04143b5 (diff) | |
parent | 1cddff7de99c6b209d35137ceb7cde3045573dc0 (diff) | |
download | which-api-5097e7b05d260b378f315aa48aa577692b0495dd.tar.gz |
Merge pull request #21 from which-ecosystem/deletions
Cleanup after poll deletion
Diffstat (limited to 'services/polls')
-rw-r--r-- | services/polls/polls.hooks.ts | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/services/polls/polls.hooks.ts b/services/polls/polls.hooks.ts index 7853c54..3bc26e8 100644 --- a/services/polls/polls.hooks.ts +++ b/services/polls/polls.hooks.ts @@ -1,5 +1,6 @@ import { HookContext } from '@feathersjs/feathers'; import { disallow } from 'feathers-hooks-common'; +import { NotAuthenticated } from '@feathersjs/errors'; import { Types } from 'mongoose'; import bluebird from 'bluebird'; import _ from 'lodash'; import { Poll } from 'which-types'; @@ -9,6 +10,7 @@ import VoteModel from '../../models/votes/vote.model'; import sortByDate from '../../hooks/sortByDate'; import signAuthority from '../../hooks/signAuthority'; import fetchImages from '../../hooks/fetchImages'; +import deleteImages from '../../hooks/deleteImages'; const convertPoll = async (context: HookContext): Promise<HookContext> => { @@ -44,12 +46,24 @@ const convertPoll = async (context: HookContext): Promise<HookContext> => { return context; }; +const onDelete = async (context: HookContext): Promise<HookContext> => { + const { params: { user }, service, id } = context; + if (id) { + const { author } = await service.get(id); + if (author._id.toString() !== user._id.toString()) { + throw new NotAuthenticated('You can only DELETE your own posts!'); + } + VoteModel.deleteMany({ pollId: id.toString() }); + } + return context; +}; + export default { before: { find: sortByDate, create: signAuthority, - remove: disallow('external'), + remove: [onDelete, deleteImages(['contents.left.url', 'contents.right.url'])], update: disallow('external'), patch: disallow('external') }, |