Skip to main content
Glama

FastAPI-MCP

by tadata-org
08_auth_example_token_passthrough.py1.29 kB
""" This example shows how to reject any request without a valid token passed in the Authorization header. In order to configure the auth header, the config file for the MCP server should looks like this: ```json { "mcpServers": { "remote-example": { "command": "npx", "args": [ "mcp-remote", "http://localhost:8000/mcp", "--header", "Authorization:${AUTH_HEADER}" ] }, "env": { "AUTH_HEADER": "Bearer <your-token>" } } } ``` """ from examples.shared.apps.items import app # The FastAPI app from examples.shared.setup import setup_logging from fastapi import Depends from fastapi.security import HTTPBearer from fastapi_mcp import FastApiMCP, AuthConfig setup_logging() # Scheme for the Authorization header token_auth_scheme = HTTPBearer() # Create a private endpoint @app.get("/private") async def private(token=Depends(token_auth_scheme)): return token.credentials # Create the MCP server with the token auth scheme mcp = FastApiMCP( app, name="Protected MCP", auth_config=AuthConfig( dependencies=[Depends(token_auth_scheme)], ), ) # Mount the MCP server mcp.mount_http() if __name__ == "__main__": import uvicorn uvicorn.run(app, host="0.0.0.0", port=8000)

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/tadata-org/fastapi_mcp'

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