poll.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. let express = require('express')
  2. let router = express.Router()
  3. let { PollAnswer, PollQuestion, PollVote, User, Sequelize } = require('../models')
  4. const Errors = require('../lib/errors')
  5. router.get('/:id', async (req, res) => {
  6. try {
  7. let id = req.params.id
  8. let pollQuestion = await PollQuestion.findById(id, {
  9. include: [
  10. { model: User, attributes: { exclude: ['hash'] } },
  11. { model: PollAnswer, include: [PollVote] }
  12. ]
  13. })
  14. if(!pollQuestion) throw Errors.sequelizeValidation(Sequelize, {
  15. error: 'invalid poll id',
  16. value: id
  17. })
  18. let totalVotes = pollQuestion.PollAnswers.reduce((sum, answer) => {
  19. return sum + answer.PollVotes.length
  20. }, 0)
  21. let answersWithPercent = pollQuestion.PollAnswers.map(answer => {
  22. let jsonAnswer = answer.toJSON()
  23. let percent = answer.PollVotes.length / totalVotes
  24. jsonAnswer.percent = Math.round(percent*100 * 10) / 10
  25. return jsonAnswer
  26. })
  27. let jsonPollQuestion = pollQuestion.toJSON()
  28. jsonPollQuestion.totalVotes = totalVotes
  29. jsonPollQuestion.PollAnswers = answersWithPercent
  30. res.json(jsonPollQuestion)
  31. } catch (e) {
  32. if(e instanceof Sequelize.ValidationError) {
  33. res.status(400)
  34. res.json(e)
  35. } else {
  36. console.log(e)
  37. res.status(500)
  38. res.json({
  39. errors: [Errors.unknown]
  40. })
  41. }
  42. }
  43. })
  44. router.all('*', (req, res, next) => {
  45. if(req.session.loggedIn) {
  46. next()
  47. } else {
  48. res.status(401)
  49. res.json({
  50. errors: [Errors.requestNotAuthorized]
  51. })
  52. }
  53. })
  54. router.post('/', async (req, res) => {
  55. try {
  56. let answers = req.body.answers
  57. if(!answers || answers.length < 2) {
  58. throw Errors.sequelizeValidation(Sequelize, {
  59. error: 'You must provide at least 2 answers',
  60. value: answers
  61. })
  62. } else if(answers.length !== new Set(answers).size) {
  63. throw Errors.sequelizeValidation(Sequelize, {
  64. error: 'Answers cannot contain any duplicates',
  65. value: answers
  66. })
  67. }
  68. let user = await User.findById(req.session.UserId)
  69. let pollQuestion = await PollQuestion.create({ question: req.body.question })
  70. let pollAnswers = await Promise.all(
  71. answers.map(answer => {
  72. return PollAnswer.create({ answer })
  73. })
  74. )
  75. //Set associations
  76. await pollQuestion.setUser(user)
  77. await Promise.all(
  78. pollAnswers.map(pollAnswer => {
  79. return pollQuestion.addPollAnswer(pollAnswer)
  80. })
  81. )
  82. res.json(pollQuestion.toJSON())
  83. } catch (e) {
  84. if(e instanceof Sequelize.ValidationError) {
  85. res.status(400)
  86. res.json(e)
  87. } else {
  88. console.log(e)
  89. res.status(500)
  90. res.json({
  91. errors: [Errors.unknown]
  92. })
  93. }
  94. }
  95. })
  96. router.post('/:id', async (req, res) => {
  97. try {
  98. let previousVote = await PollVote.findOne({
  99. where: { PollQuestionId: req.params.id, UserId: req.session.UserId }
  100. })
  101. if(previousVote) throw Errors.sequelizeValidation(Sequelize, {
  102. error: 'you cannot vote twice',
  103. value: req.params.id
  104. })
  105. let poll = await PollQuestion.findById(req.params.id, {
  106. include: [PollAnswer]
  107. })
  108. if(!poll) throw Errors.sequelizeValidation(Sequelize, {
  109. error: 'invalid poll id',
  110. value: req.params.id
  111. })
  112. let pollAnswer = poll.PollAnswers.find(a => a.answer === req.body.answer)
  113. if(!pollAnswer) throw Errors.sequelizeValidation(Sequelize, {
  114. error: 'invalid answer',
  115. value: req.body.answer
  116. })
  117. let pollVote = await PollVote.create({ UserId: req.session.UserId })
  118. await pollVote.setPollQuestion(poll)
  119. await pollVote.setPollAnswer(pollAnswer)
  120. res.json(pollVote.toJSON())
  121. } catch (e) {
  122. if(e instanceof Sequelize.ValidationError) {
  123. res.status(400)
  124. res.json(e)
  125. } else {
  126. console.log(e)
  127. res.status(500)
  128. res.json({
  129. errors: [Errors.unknown]
  130. })
  131. }
  132. }
  133. })
  134. module.exports = router