ban.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. let express = require('express')
  2. let router = express.Router()
  3. let { User, Ban, Sequelize } = require('../models')
  4. const Errors = require('../lib/errors')
  5. router.all('*', (req, res, next) => {
  6. if(req.session.admin) {
  7. next()
  8. } else {
  9. res.status(400)
  10. res.json({
  11. errors: [Errors.requestNotAuthorized]
  12. })
  13. }
  14. })
  15. router.post('/', async (req, res) => {
  16. try {
  17. let user = await User.findOne({ where: { username: req.body.username } })
  18. if(!user) throw Errors.sequelizeValidation(Sequelize, {
  19. error: 'user does not exist',
  20. value: req.body.userId
  21. })
  22. let ban = await Ban.create({
  23. message: req.body.message,
  24. canCreateThreads: req.body.canCreateThreads,
  25. canCreatePosts: req.body.canCreatePosts,
  26. ipBanned: req.body.ipBanned
  27. })
  28. await ban.setUser(user)
  29. let ret = await ban.reload({
  30. include: [{
  31. model: User,
  32. attributes: ['username', 'description', 'color', 'createdAt']
  33. }]
  34. })
  35. res.json(ret.toJSON())
  36. } catch (e) {
  37. if(e instanceof Sequelize.ValidationError) {
  38. res.status(400)
  39. res.json(e)
  40. } else {
  41. console.log(e)
  42. res.status(500)
  43. res.json({
  44. errors: [Errors.unknown]
  45. })
  46. }
  47. }
  48. })
  49. router.get('/', async (req, res) => {
  50. try {
  51. let bans = await Ban.findAll({
  52. include: [User]
  53. })
  54. res.json(bans.map(b => b.toJSON()))
  55. } catch (e) {
  56. console.log(e)
  57. res.status(500)
  58. res.json({
  59. errors: [Errors.unknown]
  60. })
  61. }
  62. })
  63. router.delete('/:ban_id', async (req, res) => {
  64. try {
  65. let ban = await Ban.findById(req.params.ban_id)
  66. if(!ban) throw Errors.sequelizeValidation(Sequelize, {
  67. error: 'ban does not exist',
  68. value: req.body.userId
  69. })
  70. await ban.destroy()
  71. res.json({ success: true })
  72. } catch (e) {
  73. if(e instanceof Sequelize.ValidationError) {
  74. res.status(400)
  75. res.json(e)
  76. } else {
  77. console.log(e)
  78. res.status(500)
  79. res.json({
  80. errors: [Errors.unknown]
  81. })
  82. }
  83. }
  84. })
  85. module.exports = router