| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- const { validationResult } = require("express-validator");
- const signale = require("signale");
- const { logger } = require("../config/winston");
- const { CustomError } = require("../utils");
- const env = require("../env");
- function ip(req, res, next) {
- req.realIP = req.headers["x-real-ip"] || req.connection.remoteAddress || "";
- return next();
- };
- function error(error, req, res, _next) {
- if (env.isDev) {
- signale.fatal(error);
- }
- if (!env.isDev && !(error instanceof CustomError)) {
- logger.error(error.message);
- }
- const message = error instanceof CustomError ? error.message : "An error occurred.";
- const statusCode = error.statusCode ?? 500;
- if (req.isHTML && req.viewTemplate) {
- res.render(req.viewTemplate, { error: message });
- return;
- }
- if (req.isHTML) {
- res.render("error", {
- message: "An error occurred. Please try again later."
- });
- return;
- }
- return res.status(statusCode).json({ error: message });
- };
- function verify(req, res, next) {
- const result = validationResult(req);
- if (result.isEmpty()) return next();
- const errors = result.array();
- const error = errors[0].msg;
-
- res.locals.errors = {};
- errors.forEach(e => {
- if (res.locals.errors[e.param]) return;
- res.locals.errors[e.param] = e.msg;
- });
- throw new CustomError(error, 400);
- }
- function parseQuery(req, res, next) {
- const { admin } = req.user || {};
- if (
- typeof req.query.limit !== "undefined" &&
- typeof req.query.limit !== "string"
- ) {
- return res.status(400).json({ error: "limit query is not valid." });
- }
- if (
- typeof req.query.skip !== "undefined" &&
- typeof req.query.skip !== "string"
- ) {
- return res.status(400).json({ error: "skip query is not valid." });
- }
- if (
- typeof req.query.search !== "undefined" &&
- typeof req.query.search !== "string"
- ) {
- return res.status(400).json({ error: "search query is not valid." });
- }
- const limit = parseInt(req.query.limit) || 10;
- req.context = {
- limit: limit > 50 ? 50 : limit,
- skip: parseInt(req.query.skip) || 0,
- all: admin ? req.query.all === "true" || req.query.all === "on" : false
- };
- next();
- };
- module.exports = {
- error,
- ip,
- parseQuery,
- verify,
- }
|