aboutsummaryrefslogtreecommitdiff
path: root/hooks
diff options
context:
space:
mode:
authorEugene Sokolov <eug-vs@keemail.me>2020-06-28 19:01:52 +0300
committerGitHub <noreply@github.com>2020-06-28 19:01:52 +0300
commit88e97a42096c1e4de7b9f1d8fefa0829bbc0d321 (patch)
treeae402f77d0d0d7b8d06dcefc614bbb9aad12ed59 /hooks
parent8baf96be5ea7880cebe3aeda733b9196950be434 (diff)
parent29197dd3bc7e941707979b6c226e5f3b1a4cbbed (diff)
downloadwhich-api-88e97a42096c1e4de7b9f1d8fefa0829bbc0d321.tar.gz
Merge pull request #16 from which-ecosystem/feedback
Feedback endpoint & schema updates
Diffstat (limited to 'hooks')
-rw-r--r--hooks/convertPoll.ts43
-rw-r--r--hooks/signAuthority.ts8
2 files changed, 8 insertions, 43 deletions
diff --git a/hooks/convertPoll.ts b/hooks/convertPoll.ts
deleted file mode 100644
index 5e6f9f4..0000000
--- a/hooks/convertPoll.ts
+++ /dev/null
@@ -1,43 +0,0 @@
-import { HookContext } from '@feathersjs/feathers';
-import { Types } from 'mongoose';
-import bluebird from 'bluebird';
-import _ from 'lodash';
-import { Poll } from 'which-types';
-
-import { PollSchema } from '../models/polls/poll.schema';
-import VoteModel from '../models/votes/vote.model';
-
-
-export default async (context: HookContext): Promise<HookContext> => {
- const { app, result, params: { user } } = context;
-
- const convert = async (poll: PollSchema): Promise<Poll | null> => {
- const author = await app.service('users').get(poll.authorId);
-
- const contents = await VoteModel.aggregate([
- { $match: { pollId: Types.ObjectId(poll._id) } },
- { $group: { _id: '$which', total: { $sum: 1 } } }
- ]).then(groups => groups.reduce(
- (acc, group) => _.set(acc, `${group._id}.votes`, group.total),
- { left: { votes: 0 }, right: { votes: 0 } }
- ));
-
- const userChoice = await VoteModel.findOne(
- { pollId: poll._id, userId: user?._id }
- ).then(vote => vote?.which);
-
- return _.merge(
- _.omit(poll, ['authorId']),
- { author, contents, userChoice }
- );
- };
-
- if (Array.isArray(result)) {
- const polls = await bluebird.map(result, (poll: PollSchema) => convert(poll));
- context.result = _.compact(polls);
- } else {
- context.result = await convert(result);
- }
- return context;
-};
-
diff --git a/hooks/signAuthority.ts b/hooks/signAuthority.ts
new file mode 100644
index 0000000..b4d74b8
--- /dev/null
+++ b/hooks/signAuthority.ts
@@ -0,0 +1,8 @@
+import { HookContext } from '@feathersjs/feathers';
+
+export default async (context: HookContext): Promise<HookContext> => {
+ const { params: { user } } = context;
+ context.data.authorId = user._id;
+ return context;
+};
+