aboutsummaryrefslogtreecommitdiff
path: root/services
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-06-22 01:42:43 +0300
committereug-vs <eug-vs@keemail.me>2020-06-22 01:43:27 +0300
commit4909dda29566710793b8445ab4426102ca4a0324 (patch)
treed3bc9a565647c160b7464251f2688bd5455dd674 /services
parente99b51895afd532a529744396ecae87d47c68503 (diff)
downloadwhich-api-4909dda29566710793b8445ab4426102ca4a0324.tar.gz
feat: create Votes service
Diffstat (limited to 'services')
-rw-r--r--services/index.ts2
-rw-r--r--services/votes/votes.class.ts14
-rw-r--r--services/votes/votes.hooks.ts15
-rw-r--r--services/votes/votes.service.ts10
4 files changed, 41 insertions, 0 deletions
diff --git a/services/index.ts b/services/index.ts
index f000837..638fb7a 100644
--- a/services/index.ts
+++ b/services/index.ts
@@ -2,6 +2,7 @@ import { Application } from '@feathersjs/express';
import Users from './users/users.service';
import Polls from './polls/polls.service';
import Profiles from './profiles/profiles.service';
+import Votes from './votes/votes.service';
import Auth from './auth/auth.service';
export default (app: Application): void => {
@@ -9,5 +10,6 @@ export default (app: Application): void => {
app.configure(Users);
app.configure(Polls);
app.configure(Profiles);
+ app.configure(Votes);
};
diff --git a/services/votes/votes.class.ts b/services/votes/votes.class.ts
new file mode 100644
index 0000000..d95c148
--- /dev/null
+++ b/services/votes/votes.class.ts
@@ -0,0 +1,14 @@
+import PollModel from '../../models/polls/poll.model';
+import { PollSchema } from '../../models/polls/poll.schema';
+
+export default class Votes {
+ async create(data: any, params: any): Promise<PollSchema | null> {
+ return PollModel.findById(params.route.id)
+ .then(poll => poll?.vote(params.user._id, data.which))
+ .catch(e => {
+ console.error(e);
+ return null;
+ });
+ }
+}
+
diff --git a/services/votes/votes.hooks.ts b/services/votes/votes.hooks.ts
new file mode 100644
index 0000000..2e29008
--- /dev/null
+++ b/services/votes/votes.hooks.ts
@@ -0,0 +1,15 @@
+import {
+ convertPollHook
+} from '../../hooks/convertPoll';
+
+import { authenticate } from '@feathersjs/authentication';
+
+export default {
+ before: {
+ create: [authenticate('jwt')]
+ },
+ after: {
+ all: [convertPollHook]
+ }
+};
+
diff --git a/services/votes/votes.service.ts b/services/votes/votes.service.ts
new file mode 100644
index 0000000..3947d9b
--- /dev/null
+++ b/services/votes/votes.service.ts
@@ -0,0 +1,10 @@
+import { Application } from '@feathersjs/express';
+import Votes from './votes.class';
+
+import hooks from './votes.hooks';
+
+export default (app: Application): void => {
+ app.use('/polls/:id/votes/', new Votes());
+ app.service('/polls/:id/votes/').hooks(hooks);
+};
+