UNPKG

@modelcontextprotocol/sdk

Version:

Model Context Protocol implementation for TypeScript

32 lines 1.25 kB
import { RequestHandler } from 'express'; /** * Express middleware for DNS rebinding protection. * Validates Host header hostname (port-agnostic) against an allowed list. * * This is particularly important for servers without authorization or HTTPS, * such as localhost servers or development servers. DNS rebinding attacks can * bypass same-origin policy by manipulating DNS to point a domain to a * localhost address, allowing malicious websites to access your local server. * * @param allowedHostnames - List of allowed hostnames (without ports). * For IPv6, provide the address with brackets (e.g., '[::1]'). * @returns Express middleware function * * @example * ```typescript * const middleware = hostHeaderValidation(['localhost', '127.0.0.1', '[::1]']); * app.use(middleware); * ``` */ export declare function hostHeaderValidation(allowedHostnames: string[]): RequestHandler; /** * Convenience middleware for localhost DNS rebinding protection. * Allows only localhost, 127.0.0.1, and [::1] (IPv6 localhost) hostnames. * * @example * ```typescript * app.use(localhostHostValidation()); * ``` */ export declare function localhostHostValidation(): RequestHandler; //# sourceMappingURL=hostHeaderValidation.d.ts.map