ban.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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, next) => {
  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) { next(e) }
  37. })
  38. router.get('/', async (req, res, next) => {
  39. try {
  40. let bans = await Ban.findAll({
  41. include: [User]
  42. })
  43. res.json(bans.map(b => b.toJSON()))
  44. } catch (e) { next(e) }
  45. })
  46. router.delete('/:ban_id', async (req, res, next) => {
  47. try {
  48. let ban = await Ban.findById(req.params.ban_id)
  49. if(!ban) throw Errors.sequelizeValidation(Sequelize, {
  50. error: 'ban does not exist',
  51. value: req.body.userId
  52. })
  53. await ban.destroy()
  54. res.json({ success: true })
  55. } catch (e) { next(e) }
  56. })
  57. module.exports = router