Oura MCP Server
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., "@Oura MCP ServerGet my daily readiness for yesterday."
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.
Oura MCP Server
A remote Model Context Protocol (MCP) server for accessing Oura Ring data over Streamable HTTP.
This server is designed for deployment behind HTTPS, such as a self-hosted Coolify instance, so it can be added to Claude.ai as a Custom Connector. It uses the MCP TypeScript SDK's StreamableHTTPServerTransport, not stdio and not the legacy SSE transport.
Setup
Prerequisites
Node.js 22+
pnpm
Oura account
Installation
Clone the repository
Run:
pnpm install
pnpm run buildRelated MCP server: Oura MCP Server
Configuration
Environment Variables
Create a .env file for local development only:
PORT=3000
MCP_ALLOWED_HOSTS=oura-mcp.mydomain.com
OURA_PERSONAL_ACCESS_TOKEN=your_tokenDo not commit .env or any real Oura token. In Coolify, set OURA_PERSONAL_ACCESS_TOKEN in the Resource environment variable UI.
You can also set MCP_ALLOWED_HOSTS to your connector hostname, for example oura-mcp.mydomain.com, to restrict accepted Host headers.
Obtaining An Oura Token
Log in to Oura Cloud Console.
Create a Personal Access Token at Personal Access Tokens.
Store it only as
OURA_PERSONAL_ACCESS_TOKENin your deployment environment.
Local Usage
pnpm run build
PORT=3000 OURA_PERSONAL_ACCESS_TOKEN=placeholder pnpm startThe MCP endpoint is:
http://localhost:3000/mcpDocker
Build and run locally:
docker build -t oura-mcp .
docker run --rm -p 3000:3000 -e OURA_PERSONAL_ACCESS_TOKEN=your_token oura-mcpCoolify Deployment
Push this repository to your GitHub account, or use Coolify's Public Repository option with your fork URL.
In Coolify, create a new Project if needed.
Add a new Resource.
Choose your Git repository, or choose Public Repository and paste the repository URL.
Select Dockerfile as the build pack.
Confirm the Dockerfile path is
Dockerfile.Set Port Exposes to
3000.In Environment Variables, add:
OURA_PERSONAL_ACCESS_TOKEN=<your Oura personal access token>Do not put the token in code,
.env.example, build arguments, or logs.Optional but recommended: add
MCP_ALLOWED_HOSTSwith only the hostname from your FQDN, for example:MCP_ALLOWED_HOSTS=oura-mcp.mydomain.comSet the Resource FQDN/domain field, for example:
https://oura-mcp.mydomain.comDeploy. Coolify will route HTTPS traffic to the container and provision a Let's Encrypt certificate for the FQDN.
Your final Claude Custom Connector URL should be:
https://oura-mcp.mydomain.com/mcpMCP Handshake Check
After deployment, replace the URL below with your actual HTTPS FQDN:
curl -i https://oura-mcp.mydomain.com/mcp \
-H 'Content-Type: application/json' \
-H 'Accept: application/json, text/event-stream' \
-d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2025-06-18","capabilities":{},"clientInfo":{"name":"curl-handshake","version":"1.0.0"}}}'A healthy response returns HTTP 200, an mcp-session-id response header, and a JSON-RPC result containing the server info for oura-provider.
Available Resources
personal_info- User profiledaily_activity- Activity summariesdaily_readiness- Readiness scoresdaily_sleep- Sleep summariessleep- Detailed sleep datasleep_time- Sleep timingworkout- Workout datasession- Session datadaily_spo2- SpO2 measurementsrest_mode_period- Rest periodsring_configuration- Ring configdaily_stress- Stress metricsdaily_resilience- Resilience metricsdaily_cardiovascular_age- CV agevO2_max- VO2 max data
Available Tools
For date-based resources, use tools like get_daily_sleep with startDate and endDate parameters (YYYY-MM-DD).
This server cannot be installed
Maintenance
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/BabyBlackEyes2023/oura-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server