Access Self-Hosted MCP Server
Provides MCP server protection via Cloudflare Access, including JWT validation, user identity verification, and conditional tool exposure based on user identity.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Access Self-Hosted MCP Servershow me my available tools"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Server + Access Self-Hosted App
A Model Context Protocol (MCP) server protected by Cloudflare Access as a self-hosted application. Unlike the Access for SaaS demo, this approach requires no OAuth implementation — Cloudflare Access handles authentication automatically.
The MCP server demonstrates:
Validating the Access JWT signature against your team's public keys using
joseVerifying the JWT issuer and audience claims
Reading user identity from the validated JWT
Conditionally exposing tools based on user identity
Getting Started
Clone the repo and install dependencies:
npm installCreate a self-hosted Access application
In Cloudflare One, go to Access controls > Applications > Add an application > Self-hosted.
Set the Application domain to your Worker URL (e.g.,
mcp-access-self-hosted.<your-subdomain>.workers.dev).Add an Access policy to control who can connect (e.g., allow emails ending in
@yourcompany.com).
Configure environment variables
Update wrangler.jsonc with your Access application details:
TEAM_DOMAIN: Your Cloudflare One team domain (e.g.,https://<your-team-name>.cloudflareaccess.com)POLICY_AUD: Your application's AUD tag (found under Access controls > Applications > your app > Basic information)
Deploy
wrangler deployTest
Test the remote server using Inspector:
npx @modelcontextprotocol/inspector@latestEnter https://mcp-access-self-hosted.<your-subdomain>.workers.dev/mcp and connect. You will be prompted to log in through your Access identity provider.
Connect from Claude Desktop
Open Claude Desktop, go to Settings > Developer > Edit Config, and add:
{
"mcpServers": {
"access-self-hosted": {
"type": "http",
"url": "https://mcp-access-self-hosted.<your-subdomain>.workers.dev/mcp"
}
}
}Local Development
wrangler devNote: In local development, Cf-Access-Jwt-Assertion is not set by Access. You can test by manually setting the header or by using cloudflared access to tunnel through Access.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
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/jlavoieca/mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server