-
Notifications
You must be signed in to change notification settings - Fork 3.1k
Open
Description
Description
Problem
Currently, the allowed_hosts configuration in TransportSecuritySettings only supports exact string matching link. This is too restrictive for real-world scenarios where you need to allow multiple subdomains under the same parent domain.
For example, if you want to allow app.mysite.com, api.mysite.com, admin.mysite.com, etc., you currently need to list each subdomain explicitly:
allowed_hosts=["app.mysite.com", "api.mysite.com", "admin.mysite.com", ...]This becomes impractical when you have many subdomains or dynamic subdomain generation.
Proposed Solution
Add wildcard pattern support similar to Starlette's TrustedHostMiddleware or Django's ALLOWED_HOSTS , allowing patterns like:
*.mysite.com- matches any subdomain ofmysite.com(e.g.,app.mysite.com,api.mysite.com) as well as the base domainmysite.comexample.com:*- matchesexample.comwith any port (already supported)
Example Usage
from mcp.server.transport_security import TransportSecuritySettings
settings = TransportSecuritySettings(
enable_dns_rebinding_protection=True,
allowed_hosts=["*.mysite.com", "localhost:*"],
)I'd be happy to follow up and create a PR.
References
No response
Reactions are currently unavailable
Metadata
Metadata
Assignees
Labels
No labels