Skip to main content
Glama

mcptix

by ownlytics
middleware.js1.75 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.notFoundHandler = notFoundHandler; exports.errorHandler = errorHandler; exports.requestLogger = requestLogger; exports.validateRequest = validateRequest; const logger_1 = require("../utils/logger"); /** * Middleware for handling 404 Not Found errors */ function notFoundHandler(req, res, _next) { res.status(404).json({ error: `Route ${req.method} ${req.path} not found` }); } /** * Middleware for handling errors */ function errorHandler(err, req, res, _next) { logger_1.Logger.error('API', 'Request error', err); // Handle specific error types if (err.name === 'SyntaxError') { return res.status(400).json({ error: 'Invalid JSON' }); } // Default error response res.status(500).json({ error: err.message || 'Internal Server Error' }); } /** * Middleware for logging requests */ function requestLogger(req, res, next) { const start = Date.now(); // Log the request logger_1.Logger.request(req.method, req.path); // Add response listener to log after completion res.on('finish', () => { const duration = Date.now() - start; logger_1.Logger.request(req.method, req.path, res.statusCode, duration); }); next(); } /** * Factory function for creating validation middleware * @param validator A function that validates the request and returns an error message or null * @returns Middleware function */ function validateRequest(validator) { return (req, res, next) => { const error = validator(req); if (error) { res.status(400).json({ error }); } else { next(); } }; } //# sourceMappingURL=middleware.js.map

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/ownlytics/mcptix'

If you have feedback or need assistance with the MCP directory API, please join our Discord server