Reka Vision MCP Server
OfficialClick 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., "@Reka Vision MCP Serversearch for videos with a person holding a phone"
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.
Reka Vision MCP Server
mcp-name: ai.reka/mcp
MCP server that lets AI agents upload, index, search, and analyze videos through the Reka Vision API. Agents can search across videos using natural language, ask questions about video content with visual analysis, detect objects in specific time ranges with text prompts, and read processed data like transcripts, captions, and scenes.
Quick Start
# Run the published local stdio server with your Reka API key
REKA_VISION_API_KEY="your-api-key" uvx reka-mcpFor MCP clients that need explicit command configuration:
{
"command": "uvx",
"args": ["reka-mcp"],
"env": {
"REKA_VISION_API_KEY": "your-api-key-here"
}
}For local development:
uv sync
uv run pre-commit install
REKA_VISION_API_KEY="test-key" uv run reka-mcpThe default mode is local stdio. In local mode, REKA_VISION_API_KEY is read once
from the process environment and used for all requests.
Hosted Mode
Hosted mode runs the same MCP tools over Streamable HTTP. It does not use a
process-wide Reka API key. Instead, each MCP HTTP request must include the user's
key in X-Reka-API-Key; the server forwards that value to the Reka Vision API as
x-api-key for that request only.
Production-style hosted startup:
REKA_MCP_MODE=hosted \
REKA_MCP_HTTP_HOST=0.0.0.0 \
PORT=8080 \
uv run reka-mcpEndpoints:
MCP Streamable HTTP:
http://<host>:<port>/mcpHealth check:
http://<host>:<port>/health
Hosted clients must send:
X-Reka-API-Key: your-api-keyREKA_MCP_AUTH_TOKEN is optional MCP transport auth. When set, HTTP clients must
also send Authorization: Bearer <token>.
index_video works the same in both modes: it polls the feature DAG until all
requested features are ready (or times out). After upload_video, poll
get_video until the video status is uploaded, then call index_video.
Run Hosted Mode Locally
Hosted mode enables DNS rebinding protection. Its default allowed hosts and origins are production/staging domains, so override them for localhost testing:
REKA_MCP_MODE=hosted \
REKA_MCP_TRANSPORT=http \
REKA_MCP_HTTP_HOST=0.0.0.0 \
REKA_MCP_HTTP_PORT=8080 \
PORT=8080 \
REKA_MCP_HTTP_PATH=/mcp \
REKA_MCP_ALLOWED_HOSTS="localhost:*,127.0.0.1:*" \
REKA_MCP_ALLOWED_ORIGINS="http://localhost:*,http://127.0.0.1:*" \
uv run reka-mcpThen connect to http://localhost:8080/mcp and configure your MCP client or
inspector to send X-Reka-API-Key. Check the server with:
curl -H "Host: localhost:8080" http://localhost:8080/healthConnect to Hosted MCP (mcp.reka.ai)
No installation required — connect directly to the hosted server with your Reka API key.
Claude Desktop
Claude Desktop does not speak Streamable HTTP directly, so use the
mcp-remote bridge. Add to
~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"reka-mcp": {
"command": "npx",
"args": [
"-y",
"mcp-remote",
"https://mcp.reka.ai/mcp",
"--header",
"X-Reka-API-Key:${REKA_VISION_API_KEY}"
],
"env": {
"REKA_VISION_API_KEY": "your-api-key-here"
}
}
}
}Requires Node.js installed locally. Restart Claude Desktop after editing the config.
Claude Code
claude mcp add --transport http reka-mcp https://mcp.reka.ai/mcp \
--header "X-Reka-API-Key: your-api-key-here"Cursor
Add to .cursor/mcp.json:
{
"mcpServers": {
"reka-mcp": {
"type": "streamable-http",
"url": "https://mcp.reka.ai/mcp",
"headers": {
"X-Reka-API-Key": "your-api-key-here"
}
}
}
}Claude Desktop Setup (Local)
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"reka-mcp": {
"command": "uvx",
"args": ["reka-mcp"],
"env": {
"REKA_VISION_API_KEY": "your-api-key-here"
}
}
}
}Cursor Setup (Local)
Add to .cursor/mcp.json:
{
"mcpServers": {
"reka-mcp": {
"command": "uvx",
"args": ["reka-mcp"],
"env": {
"REKA_VISION_API_KEY": "your-api-key-here"
}
}
}
}Claude Code Setup (Local)
claude mcp add reka-mcp -e REKA_VISION_API_KEY=your-api-key-here -- uvx reka-mcpUpdating
To update to the latest version, clear the cached package and restart your client:
uv cache clean reka-mcpTo check which version you're running:
uvx reka-mcp --versionAvailable Tools
Tool | Description |
| Upload a video from a URL |
| List videos in your account or a group |
| Get video details, metadata, and feature status |
| Update a video's name, title, description, or group |
| Permanently delete a video and all indexed data |
| Create a new video group |
| List all video groups |
| Delete a video group |
| Index a video for search/QA/analysis. Waits until all requested features are ready (2-10 min). |
| Semantic search across indexed videos |
| Ask questions about video content with visual analysis |
| Get transcript as text, segments, or words |
| Get AI-generated visual descriptions |
| Get detected scene boundaries |
| List available features and dependencies |
| Compact overview of video content and status |
Environment Variables
Variable | Default | Description |
|
| Runtime mode: |
| (required in local mode) | API key from https://platform.reka.ai. Not used as the primary auth source in hosted mode. |
|
| API base URL |
|
| Max seconds to wait for indexing |
|
| Seconds between index status polls |
|
| Transport: |
|
| Host for HTTP transport |
|
| Port for HTTP transport. In hosted mode, |
|
| Streamable HTTP endpoint path |
|
| Comma-separated allowed HTTP Host values for DNS rebinding protection |
|
| Comma-separated allowed Origin values |
| (none) | Optional bearer token for HTTP transport auth. Clients must send |
Release Checks
cd /path/to/reka-mcp
uv build
uv run twine check dist/*
# Publish only after explicit approval:
uv run twine upload dist/*Example Workflows
Search and Visual Q&A
Agent: search_videos(query="revenue chart")
→ [{video_id: "v1", start: 30.0, end: 35.0, score: 0.95}]
Agent: ask_video(question="What numbers are on the chart?",
video_id="v1", start=30.0, end=35.0)
→ {answer: "Q3 revenue of $4.2M, up 32%...", conversation_id: "c1"}
Agent: ask_video(question="What's the percentage change?",
conversation_id="c1")
→ {answer: "Revenue increased by 32% quarter-over-quarter..."}Cross-Video Comparison
Agent: search_videos(query="quarterly revenue")
→ [{video_id: "v1", start: 30.0, ...}, {video_id: "v2", start: 120.0, ...}]
Agent: ask_video(question="How do the revenue figures compare?",
videos=[
{video_id: "v1", start: 30.0, end: 35.0},
{video_id: "v2", start: 120.0, end: 125.0}
])
→ {answer: "Video 1 shows Q3 at $4.2M while Video 2 shows Q4 at $5.1M..."}Video Summary and Transcript Extraction
Agent: summarize_video(video_id="v1")
→ {name: "Lecture 3", duration_seconds: 3600, features: {...},
scene_count: 42, transcript_preview: "Welcome to today's lecture..."}
Agent: get_transcript(video_id="v1", format="segments", start=0, end=60)
→ {data: [{start: 0.0, end: 5.2, text: "Welcome..."}, ...],
total_count: 12, truncated: false}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
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/reka-ai/reka-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server