diff options
Diffstat (limited to 'hooks')
-rw-r--r-- | hooks/convertPoll.ts | 43 |
1 files changed, 0 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; -}; - |