X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fasync.ts;h=f770bc1209e27996e37f0c7fe51a6046df4f1fc1;hb=7ccddd7b5250bd25a917a6e77e58b87b9484a2a4;hp=534891899cab0364af5a41a0a37bf82a5b1dcf9c;hpb=a2431b7dcbc72c05101dcdbe631ff84a823aeb51;p=oweals%2Fpeertube.git diff --git a/server/middlewares/async.ts b/server/middlewares/async.ts index 534891899..f770bc120 100644 --- a/server/middlewares/async.ts +++ b/server/middlewares/async.ts @@ -1,5 +1,6 @@ import { eachSeries } from 'async' import { NextFunction, Request, RequestHandler, Response } from 'express' +import { retryTransactionWrapper } from '../helpers/database-utils' // Syntactic sugar to avoid try/catch in express controllers // Thanks: https://medium.com/@Abazhenov/using-async-await-in-express-with-node-8-b8af872c0016 @@ -11,17 +12,26 @@ function asyncMiddleware (fun: RequestPromiseHandler | RequestPromiseHandler[]) if (Array.isArray(fun) === true) { return eachSeries(fun as RequestHandler[], (f, cb) => { Promise.resolve(f(req, res, cb)) - .catch(next) + .catch(err => next(err)) }, next) } return Promise.resolve((fun as RequestHandler)(req, res, next)) - .catch(next) + .catch(err => next(err)) + } +} + +function asyncRetryTransactionMiddleware (fun: RequestPromiseHandler) { + return (req: Request, res: Response, next: NextFunction) => { + return Promise.resolve( + retryTransactionWrapper(fun, req, res, next) + ).catch(err => next(err)) } } // --------------------------------------------------------------------------- export { - asyncMiddleware + asyncMiddleware, + asyncRetryTransactionMiddleware }