Skip to main content
Glama

mcptix

by ownlytics
middleware.ts1.71 kB
import { Request, Response, NextFunction, RequestHandler } from 'express'; import { Logger } from '../utils/logger'; /** * Middleware for handling 404 Not Found errors */ export function notFoundHandler(req: Request, res: Response, _next: NextFunction): void | Response { res.status(404).json({ error: `Route ${req.method} ${req.path} not found` }); } /** * Middleware for handling errors */ export function errorHandler(err: Error, req: Request, res: Response, _next: NextFunction): void | Response { 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 */ export function requestLogger(req: Request, res: Response, next: NextFunction): void { const start = Date.now(); // Log the request Logger.request(req.method, req.path); // Add response listener to log after completion res.on('finish', () => { const duration = Date.now() - start; 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 */ export function validateRequest(validator: (req: Request) => string | null): RequestHandler { return (req: Request, res: Response, next: NextFunction): void => { const error = validator(req); if (error) { res.status(400).json({ error }); } else { next(); } }; }

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