1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- let express = require('express')
- let router = express.Router()
- let { User, Ban, Sequelize } = require('../models')
- const Errors = require('../lib/errors')
- router.all('*', (req, res, next) => {
- if(req.session.admin) {
- next()
- } else {
- res.status(400)
- res.json({
- errors: [Errors.requestNotAuthorized]
- })
- }
- })
- router.post('/', async (req, res) => {
- try {
- let user = await User.findById(req.body.userId)
- if(!user) throw Errors.sequelizeValidation(Sequelize, {
- error: 'user does not exist',
- value: req.body.userId
- })
- let ban = await Ban.create({
- message: req.body.message,
- canCreateThreads: req.body.canCreateThreads,
- canCreatePosts: req.body.canCreatePosts
- })
- await ban.setUser(user)
- res.json(ban.toJSON())
- } catch (e) {
- if(e instanceof Sequelize.ValidationError) {
- res.status(400)
- res.json(e)
- } else {
- console.log(e)
- res.status(500)
- res.json({
- errors: [Errors.unknown]
- })
- }
- }
- })
- router.get('/', async (req, res) => {
- try {
- let bans = await Ban.findAll({
- include: [User]
- })
- res.json(bans.map(b => b.toJSON()))
- } catch (e) {
- console.log(e)
- res.status(500)
- res.json({
- errors: [Errors.unknown]
- })
- }
- })
- router.delete('/:ban_id', async (req, res) => {
- try {
- let ban = await Ban.findById(req.params.ban_id)
- if(!ban) throw Errors.sequelizeValidation(Sequelize, {
- error: 'ban does not exist',
- value: req.body.userId
- })
- await ban.destroy()
- res.json({ success: true })
- } catch (e) {
- if(e instanceof Sequelize.ValidationError) {
- res.status(400)
- res.json(e)
- } else {
- console.log(e)
- res.status(500)
- res.json({
- errors: [Errors.unknown]
- })
- }
- }
- })
- module.exports = router
|