post.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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.findById(
  59. req.body.replyingToId,
  60. { include: [Thread] }
  61. )
  62. if(!replyingToPost) {
  63. throw Errors.invalidParameter('replyingToId', 'post does not exist')
  64. } else if(replyingToPost.Thread.id !== thread.id) {
  65. throw Errors.invalidParameter('replyingToId', 'replies must be in same thread')
  66. } else {
  67. post = await Post.create({ content: req.body.content })
  68. await post.setReplyingTo(replyingToPost)
  69. await replyingToPost.addReplies(post)
  70. }
  71. } else {
  72. post = await Post.create({ content: req.body.content })
  73. }
  74. await post.setUser(user)
  75. await post.setThread(thread)
  76. res.json(await post.reload({
  77. include: Post.includeOptions()
  78. }))
  79. } catch (e) {
  80. if(e === Errors.VALIDATION_ERROR) {
  81. res.status(400)
  82. res.json({
  83. errors: validationErrors
  84. })
  85. } else if(e.name === 'invalidParameter') {
  86. res.status(400)
  87. res.json({
  88. errors: [e]
  89. })
  90. } else {
  91. console.log(e)
  92. res.status(500)
  93. res.json({
  94. errors: [Errors.unknown]
  95. })
  96. }
  97. }
  98. })
  99. module.exports = router