post.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. let express = require('express')
  2. let router = express.Router()
  3. const Errors = require('../lib/errors')
  4. let { User, Thread, Post } = require('../models')
  5. router.get('/:post_id', async (req, res) => {
  6. try {
  7. let post = await Post.findById(req.params.post_id, { include: Post.includeOptions() })
  8. if(!post) throw Errors.invalidParameter('id', 'post does not exist')
  9. res.json(post.toJSON())
  10. } catch (e) {
  11. if(e.name === 'invalidParameter') {
  12. res.status(400)
  13. res.json({
  14. errors: [e]
  15. })
  16. } else {
  17. res.status(500)
  18. res.json({
  19. errors: [Errors.unknown]
  20. })
  21. }
  22. }
  23. })
  24. router.all('*', (req, res, next) => {
  25. if(req.session.loggedIn) {
  26. next()
  27. } else {
  28. res.status(401)
  29. res.json({
  30. errors: [Errors.requestNotAuthorized]
  31. })
  32. }
  33. })
  34. router.post('/', async (req, res) => {
  35. let validationErrors = []
  36. let thread, replyingToPost, post
  37. try {
  38. if(req.body.content === undefined) {
  39. validationErrors.push(Errors.missingParameter('content'))
  40. } else if(typeof req.body.content !== 'string') {
  41. validationErrors.push(Errors.invalidParameterType('content', 'string'))
  42. } if (req.body.threadId === undefined) {
  43. validationErrors.push(Errors.missingParameter('threadId'))
  44. } else if(!Number.isInteger(req.body.threadId)) {
  45. validationErrors.push(Errors.invalidParameterType('threadId', 'integer'))
  46. } if(req.body.replyingToId !== undefined && !Number.isInteger(req.body.replyingToId)) {
  47. validationErrors.push(Errors.invalidParameterType('replyingToId', 'integer'))
  48. }
  49. if(validationErrors.length) throw Errors.VALIDATION_ERROR
  50. thread = await Thread.findOne({ where: {
  51. id: req.body.threadId
  52. }})
  53. user = await User.findOne({ where: {
  54. username: req.session.username
  55. }})
  56. if(!thread) throw Errors.invalidParameter('threadId', 'thread does not exist')
  57. if(req.body.replyingToId) {
  58. replyingToPost = await Post.findOne({ where: {
  59. id: req.body.replyingToId
  60. }, include: [Thread] })
  61. if(!replyingToPost) {
  62. throw Errors.invalidParameter('replyingToId', 'post does not exist')
  63. } else if(replyingToPost.Thread.id !== thread.id) {
  64. throw Errors.invalidParameter('replyingToId', 'replies must be in same thread')
  65. } else {
  66. post = await Post.create({ content: req.body.content })
  67. await post.setReplyingTo(replyingToPost)
  68. await replyingToPost.addReplies(post)
  69. }
  70. } else {
  71. post = await Post.create({ content: req.body.content })
  72. }
  73. await post.setUser(user)
  74. await post.setThread(thread)
  75. res.json(await post.reload({
  76. include: Post.includeOptions()
  77. }))
  78. } catch (e) {
  79. if(e === Errors.VALIDATION_ERROR) {
  80. res.status(400)
  81. res.json({
  82. errors: validationErrors
  83. })
  84. } else if(e.name === 'invalidParameter') {
  85. res.status(400)
  86. res.json({
  87. errors: [e]
  88. })
  89. } else {
  90. console.log(e)
  91. res.status(500)
  92. res.json({
  93. errors: [Errors.unknown]
  94. })
  95. }
  96. }
  97. })
  98. module.exports = router