aboutsummaryrefslogtreecommitdiff
path: root/services/polls
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-08-17 23:40:16 +0300
committereug-vs <eug-vs@keemail.me>2020-08-17 23:40:39 +0300
commit1cddff7de99c6b209d35137ceb7cde3045573dc0 (patch)
treedde301d6529fc1140e413c9cd3db8c4033cff552 /services/polls
parentc43e6d185b7606ff8c0d038746b9e376e04143b5 (diff)
downloadwhich-api-1cddff7de99c6b209d35137ceb7cde3045573dc0.tar.gz
feat: cleanup after poll deletion
Diffstat (limited to 'services/polls')
-rw-r--r--services/polls/polls.hooks.ts16
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')
},