Skip to main content
Glama

Modal MCP Server

Status: local read-only beta Python: 3.12+ License: Apache-2.0

Local, read-only Modal context for coding agents.

Modal MCP lets Codex, Claude Desktop, and other MCP clients inspect Modal apps, deployments, logs, containers, volumes, and sandboxes without granting mutation tools. It runs on your machine, uses your local Modal credentials, and exposes only read-oriented toolsets by default.

Why Use It

  • Let agents inspect live Modal state instead of asking you to paste CLI output.

  • Debug deployments, startup failures, and recent logs from the same chat.

  • Keep Modal credentials local to your machine.

  • Start with read-only behavior; destructive tools are disabled in v1.

Related MCP server: MCP Snowflake Reader

Project Status

v1 is a local read-only beta.

Area

Status

Local MCP server

Supported

Claude Code install

modal-mcp setup --install claude-code

Codex CLI install

Supported by modal-mcp setup --install codex

Claude Desktop install

Supported by modal-mcp setup --install claude

Read-only Modal tools

Supported

Mutating Modal tools

Disabled stubs only

Hosted OAuth / multi-tenant service

Not part of v1

Helm / Kubernetes packaging

Deferred

Installation

# Pin to a release tag for supply-chain safety
curl -fsSL https://raw.githubusercontent.com/php-workx/modal-mcp/refs/tags/v0.1.0/install.sh -o install.sh
# Verify checksum against release notes, then execute:
sh install.sh

This script auto-detects your Python toolchain and installs modal-mcp with the best available method:

Toolchain

Command used

Notes

uv (preferred)

uv tool install modal-mcp

Fast, isolated, no virtualenv needed

pipx

pipx install modal-mcp

Good isolation, widely available

pip (fallback)

pip install --user modal-mcp

Always works, requires PATH setup

From source

git clone https://github.com/php-workx/modal-mcp.git
cd modal-mcp
uv sync --extra dev
uv run modal-mcp --help

PyPI

uv tool install modal-mcp
# or
pipx install modal-mcp
# or
pip install --user modal-mcp

Quickstart

Install from source and generate local server settings:

uv sync --extra dev
uv run modal-mcp setup --yes

modal-mcp setup --yes creates .env and .secrets/signing-key.txt when missing. If an .env already exists, missing MODAL_MCP_* keys are merged into it; existing content (including Modal tokens and MODAL_ENVIRONMENT) is left unchanged.

File

Mode

Contains

.env

0600

Local server settings and signing-key path

.secrets/signing-key.txt

0600

HMAC signing key for server internals

The generated .env intentionally does not contain Modal tokens or MODAL_ENVIRONMENT unless they are already present in an existing file.

If this machine already has Modal CLI credentials in ~/.modal.toml, you can verify and start the server immediately:

uv run modal-mcp doctor --env-file .env
uv run modal-mcp run --env-file .env

Add Modal Credentials

For a quick local evaluation, existing Modal CLI credentials in ~/.modal.toml are used automatically. modal-mcp doctor warns when it finds them because they often belong to a personal editor or admin account.

For regular use, create a dedicated Modal service-user token with Viewer access and store it in files. Replace the placeholder values before running the diagnostic or server commands:

mkdir -p .secrets
printf '%s' '<modal-token-id>'     > .secrets/modal-token-id
printf '%s' '<modal-token-secret>' > .secrets/modal-token-secret
chmod 600 .secrets/*
printf '\nMODAL_TOKEN_ID_FILE=%s/.secrets/modal-token-id\n' "$PWD" >> .env
printf 'MODAL_TOKEN_SECRET_FILE=%s/.secrets/modal-token-secret\n' "$PWD" >> .env

Run the diagnostics again after adding credentials:

uv run modal-mcp doctor --env-file .env
uv run modal-mcp run --env-file .env

What Agents Can Ask

Try prompts like these after connecting your MCP client:

  • "Which Modal workspaces and environments can this token see?"

  • "List the apps in the current environment and summarize deployment status."

  • "Show recent logs for this app and group likely startup failures."

  • "Compare these two deployment versions and tell me what changed."

  • "List running sandboxes and containers so I can spot stale resources."

  • "Inspect this volume path and read a small text file from it."

See docs/examples.md for longer workflows.

Toolsets

Toolset

Tools

Helps agents answer

discovery

modal_discovery_server_info, modal_whoami, modal_list_workspaces, modal_list_environments, modal_get_environment

Who am I authenticated as, what environments exist, and what server features are enabled?

apps

modal_list_apps, modal_get_app, modal_list_app_deployments

What apps exist and what versions are deployed?

logs

modal_get_app_logs, modal_search_logs, modal_summarize_failures, modal_compare_deployments, modal_diagnose_app_startup

What happened recently and what failures look most likely?

containers

modal_list_containers, modal_get_container, modal_get_container_logs

Which containers exist and what are they reporting?

volumes

modal_list_volumes, modal_ls_volume, modal_read_volume_text, modal_stat_volume_path

What volume paths exist and what small text content can be inspected?

sandboxes

modal_list_sandboxes, modal_get_sandbox, modal_get_sandbox_stdio

What sandboxes exist and what stdio did they produce?

The change and expert toolsets are registered only as disabled stubs so policy code can block them consistently. They are hidden from default tools/list.

Full catalog: docs/tools.md.

Connect An Agent

Codex CLI

Codex launches modal-mcp as a subprocess over stdio:

uv run modal-mcp setup --install codex --env-file "$PWD/.env" --dry-run
uv run modal-mcp setup --install codex --env-file "$PWD/.env" --yes

Claude Desktop

Claude Desktop connects to a running local server:

uv run modal-mcp run --env-file "$PWD/.env"
uv run modal-mcp setup --install claude --dry-run
uv run modal-mcp setup --install claude --yes

Other MCP Clients

Point Streamable HTTP clients at:

http://127.0.0.1:8765/mcp

For clients that still expect SSE:

http://127.0.0.1:8765/mcp/sse

More details: docs/clients.md.

Safety Model

  • Local by default: the server binds to 127.0.0.1:8765 unless configured otherwise.

  • Read-only by default: MODAL_MCP_READ_ONLY=true.

  • Toolsets are allowlisted by MODAL_MCP_ENABLED_TOOLSETS.

  • Origin and Host allowlists run before MCP request handling.

  • Known secrets are redacted before JSON responses and audit logs leave the server.

  • Raw Modal tokens should not be placed in .env; prefer file-backed secrets.

Volume text, logs, and sandbox stdio can still contain application-sensitive data. Use a non-production workspace or a dedicated Viewer-scoped service user when evaluating the server.

Security details: docs/threat-model.md.

Configuration

Required for self-hosted startup:

Variable

Purpose

MODAL_MCP_ALLOWED_ORIGINS

Browser/client origins allowed to call the MCP server

MODAL_MCP_SIGNING_KEYS or MODAL_MCP_SIGNING_KEY_FILE

HMAC signing keys for internal refs, cursors, and approval tokens

Modal credentials

Either ~/.modal.toml, MODAL_TOKEN_ID plus MODAL_TOKEN_SECRET, or their _FILE variants

Recommended defaults:

MODAL_MCP_READ_ONLY=true
MODAL_MCP_ENABLED_TOOLSETS=discovery,apps,containers,logs,volumes,sandboxes
MODAL_MCP_AUDIT_LOG=stdout
MODAL_MCP_HTTP_BIND=127.0.0.1:8765

Full deployment guide: docs/self-hosting.md.

Troubleshooting

Start with:

uv run modal-mcp doctor --env-file .env

doctor checks package imports, .env, signing keys, allowed origins, read-only settings, enabled toolsets, Modal credential source, Modal SDK auth, and Modal CLI availability.

Exit codes:

Code

Meaning

0

Ready

3

Warnings only; local use may still work

1

At least one required check failed

Common fixes: docs/troubleshooting.md.

Development

Install local command runners:

brew install just shellcheck actionlint betterleaks semgrep

Run the local gates:

just setup
just pre-commit
just pre-push
just check
just uv-audit

Live Modal tests are opt-in and should use non-production credentials:

MODAL_MCP_LIVE=1 MODAL_ENVIRONMENT=dev uv run pytest tests/integration/live -q

Documentation

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

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/php-workx/modal-mcp'

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