1
0
mirror of synced 2026-01-04 09:06:46 -05:00
Files
docs/middleware/events.js
James M. Greene c940dcd98b Middleware overhaul! (#18218)
* Middleware overhaul!

- Remove unnecessary 'async' keywords from middleware functions
- Ensure all middleware functions we create have names
- Wrap the method contents of all async middleware functions in a try-catch+next(error) pattern

* Use asyncMiddleware wrapper instead of try-catch+next(error) pattern

* Remove unnecessary try-catch+next(error) pattern from context middleware
2021-03-11 01:12:41 +00:00

55 lines
1.3 KiB
JavaScript

const express = require('express')
const { omit } = require('lodash')
const Ajv = require('ajv')
const schema = require('../lib/schema-event')
const FailBot = require('../lib/failbot')
const OMIT_FIELDS = ['type', 'token']
const ajv = new Ajv()
const router = express.Router()
router.post('/', async function postEvents (req, res, next) {
const isDev = process.env.NODE_ENV === 'development'
const fields = omit(req.body, '_csrf')
if (!ajv.validate(schema, fields)) {
if (isDev) console.log(ajv.errorsText())
return res.status(400).json({})
}
// Don't depend on Hydro on local development
if (isDev && !req.hydro.maySend()) {
return res.status(200).json({})
}
try {
const hydroRes = await req.hydro.publish(
req.hydro.schemas[fields.type],
omit(fields, OMIT_FIELDS)
)
if (!hydroRes.ok) {
const err = new Error('Hydro request failed')
err.status = hydroRes.status
err.path = fields.path
await FailBot.report(err, {
path: fields.path,
hydroStatus: hydroRes.status,
hydroText: await hydroRes.text()
})
throw err
}
return res.status(201).json(fields)
} catch (err) {
if (isDev) console.error(err)
return res.status(502).json({})
}
})
module.exports = router