Server data from the Official MCP Registry
Read and act on your own Dynamite Circle membership data via the public DC Member API.
Read and act on your own Dynamite Circle membership data via the public DC Member API.
Remote endpoints: streamable-http: https://api.dynamitecircle.com/mcp
A well-architected, single-file MCP server for the Dynamite Circle Member API. Authentication is properly delegated to API keys stored in environment variables or .env files with secure handling (chmod 600). Code quality is solid with proper input validation, no dangerous patterns detected, and permissions appropriately scoped to the API's intended use. Minor code quality observations (broad exception handling, some informal error messages) are present but do not constitute security vulnerabilities. Supply chain analysis found 3 known vulnerabilities in dependencies (0 critical, 3 high severity).
4 files analyzed · 7 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Available as Local & Remote
This plugin can run on your machine or connect to a hosted endpoint. during install.
From the project's GitHub README.
The official Python client for the Dynamite Circle Member API — your own profile, trips, events, virtual events, tickets, invites, inbox, rooms, chapters, places lookup, and the weekly locator digest.
A single self-contained file. Zero dependencies (stdlib only). Works as a CLI, a Python library, and a Model Context Protocol server. Compatible with Claude Code, Claude Desktop, Codex CLI, Gemini CLI, Cursor, GitHub Copilot, and every other Agent Skills / MCP-compatible tool.
py/dc.py ← one file, three integration modes
The Dynamite Circle is the place where global founders find their people — a curated, members-only community of location-independent business owners running profitable companies around the world. Founded in 2011 (it started with twenty listeners on a remote tropical island), the DC has grown into a hand-selected network of ~1,500 active founders who meet at vetted in-person events like DCBKK and DCMEX, swap notes in private rooms, and travel through each other's home cities year-round.
DC is a private community, but it's open to applications from founders running location-independent businesses doing $100k+ in annual revenue. Every application is personally reviewed by a team member within 48 business hours — start an application here if that sounds like you.
Never used Claude Code, Codex, or git? Here's the 5-minute path from zero to "Claude can read my DC profile."
You need three free things on your computer:
If anything during install asks "do you want to add to PATH?" — say yes.
Open a terminal:
Then paste:
git clone https://github.com/dynamitecircle/dc.git
cd dc
You now have a folder called dc with all the code in it.
In your browser: go to https://dc.dynamitecircle.com, log in, click your profile photo (top-right), and choose DC Member API Key. Copy the long string starting with dk_….
Back in your terminal (still inside the dc folder):
python3 py/dc.py setup --api-key dk_paste_your_key_here
Open Claude Code and make sure it's pointed at the dc folder you just downloaded. (Claude usually opens to your last project — if it's somewhere else, click the folder icon and pick dc.)
Then ask:
"Show me my DC profile"
Claude runs the right command and shows you back your profile. A few more to try:
"What's the latest in DC announcements?" "What events am I attending?" "Show me the DCMEX schedule and bookmark anything about marketing" "Who else from my chapter is going to DCBKK?"
You're done. The rest of this README explains what's possible in more detail; py/SKILL.md lists every command Claude can run.
| Symptom | What to try |
|---|---|
python3: command not found | Python didn't install or didn't get added to PATH. Re-install and check the "Add to PATH" box on Windows; on Mac, try python instead of python3. |
git: command not found | Same idea — re-install Git. |
Claude says "I don't see a dc skill" | Make sure Claude Code is opened to the dc folder, not your home directory or another project. Or just ask Claude: "are you in the dc folder?" |
| Anything else | Run python3 py/dc.py self-test from the dc folder — it tells you exactly which step is broken. |
The same dc.py file is shipped as four integrations — pick whichever fits how your tool talks to it:
| Integration | What it is | Invoke with | Dependencies |
|---|---|---|---|
| Agent Skill | Auto-discovered via SKILL.md frontmatter (Claude Code, Codex, Gemini CLI, Cursor, Copilot) | Just open the repo with the tool — it reads py/SKILL.md and offers the commands | stdlib only |
| CLI | Run commands directly from the shell or scripts | python3 py/dc.py <command> | stdlib only |
| Python library | Import in your own Python code | from dc import DC; DC().profile() | stdlib only |
| MCP server | Speaks Model Context Protocol over stdio (Claude Desktop, Cursor, Codex MCP, Cline, etc.) | python3 py/dc.py --mcp | pip install mcp (optional) |
The mcp package is lazy-imported — Agent Skill / CLI / Python-library users never need it.
The DC Member API is also a hosted MCP server — a remote endpoint you point your AI app at, with nothing to clone, install, or update:
https://api.dynamitecircle.com/mcp (Streamable HTTP)
claude mcp add --transport http dc https://api.dynamitecircle.com/mcpcode --add-mcp '{"name":"dc","url":"https://api.dynamitecircle.com/mcp"}'When prompted, sign in with your DC account (one-click OAuth) — or send a dk_ key as Authorization: Bearer. The server is always on the current API version, so there's nothing to keep up to date.
Hosted MCP vs. this client — which do I want?
| You want… | Use |
|---|---|
| Zero install, always-current, just MCP tools in a chat app | Hosted MCP (URL above) |
To call DC from your own Python code (from dynamitecircle import DC) | This client (library) |
A local CLI (dc profile) or shell scripting | This client (CLI) |
| A local stdio MCP server (offline-capable, pin a version, dev against localhost) | This client (dc --mcp) |
The rest of this README is about this client. For the hosted MCP, the URL above is all you need.
python3 py/dc.py help for the live list).env.dc next to the skill/profile call end-to-end[--limit N] [--cursor TOKEN] shape and returns the canonical envelope {items, count, cursor, has_more}--json, --python.mcp.json, just cd and claudeIf you're skipping past the Quick Start above and just want the CLI flow, here's the condensed version.
DC profile dropdown → DC Member API Key (admins/testers only). Keys look like dk_<api-key> and are revocable from the same dropdown.
python3 py/dc.py setup --api-key dk_<api-key>
This writes py/.env.dc (chmod 600, gitignored).
python3 py/dc.py self-test
Expected output:
{
"ok": true,
"userID": "<your-id>",
"displayName": "<Your Name>",
"checks": [
{ "step": "env", "ok": true, "message": "DC_API_KEY loaded from ..." },
{ "step": "keyShape", "ok": true, "message": "Key prefix valid (expected userID: <id>)" },
{ "step": "profile", "ok": true, "message": "connected as userID[<id>] <Your Name>" }
]
}
python3 py/dc.py profile
python3 py/dc.py trips --limit 5
python3 py/dc.py events --past --limit 3
python3 py/dc.py chapters --limit 5
python3 py/dc.py permacode
Run python3 py/dc.py help for the full command list.
Nothing to clone or update — point your tool at the remote endpoint:
# Claude Code
claude mcp add --transport http dc https://api.dynamitecircle.com/mcp
For Claude web / Desktop, Cursor, ChatGPT, and other MCP apps, add a custom / remote connector pointing at https://api.dynamitecircle.com/mcp (Streamable HTTP). Sign in with your DC account (OAuth) or send a dk_ key as a Bearer header. Discovery is published at /.well-known/mcp.json. This is the lowest-effort path; everything below runs the client locally instead.
.mcp.json is already shipped with this repo. Open the repo with claude:
cd dc
claude
Tools become available as mcp__dc__*. First-time install of the optional MCP dependency:
pip install -r py/requirements.txt
Skill discovery (CLI + import) works automatically via py/SKILL.md.
uvx (PyPI)Prefer a local stdio server that pulls the latest published client on every launch with no clone to maintain? Use uv's uvx and pass your key in the env block:
{
"mcpServers": {
"dc": {
"type": "stdio",
"command": "uvx",
"args": ["--refresh", "--from", "dynamitecircle[mcp]", "dc", "--mcp"],
"env": { "DC_API_KEY": "dk_<api-key>" }
}
}
}
Notes: the console script is dc (not dynamitecircle), so --from dynamitecircle[mcp] is required — it both names the package and pulls the optional mcp extra. --refresh is what makes it auto-update; drop it to let uvx cache. The DC_API_KEY in env wins over any .env.dc (an ephemeral uvx install has none).
Easiest — one-click .mcpb: download dc.mcpb from the latest GitHub release and double-click it. Claude Desktop installs the dc server and prompts for your DC_API_KEY (no JSON editing). Requires Python 3.9+ with the mcp package available on your machine (pip install 'dynamitecircle[mcp]'). (Or skip local install entirely and use the hosted MCP connector above.)
Manual — edit your config file:
~/Library/Application Support/Claude/claude_desktop_config.json~/.config/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json{
"mcpServers": {
"dc": {
"command": "python3",
"args": ["/absolute/path/to/dc/py/dc.py", "--mcp"]
}
}
}
Restart Claude Desktop.
Edit ~/.codex/config.toml:
[mcp_servers.dc]
command = "python3"
args = ["/absolute/path/to/dc/py/dc.py", "--mcp"]
Codex auto-discovers AGENTS.md (symlinked to CLAUDE.md) and .agents/skills/ (symlinked to .claude/skills/).
Reads GEMINI.md (symlinked to CLAUDE.md) for context. For MCP, configure in your Gemini CLI settings:
mcp_servers:
dc:
command: python3
args:
- /absolute/path/to/dc/py/dc.py
- --mcp
Settings → MCP → Add server, then point at the same dc.py --mcp.
Reads .github/copilot-instructions.md for context. Copilot doesn't have native MCP support yet — use it for in-editor suggestions while developing.
Same recipe: command = python3, args = ["/path/to/dc.py", "--mcp"]. The protocol is standard.
python3 dc.py profile # text (pretty JSON for dicts/lists)
python3 dc.py profile --json # explicit JSON
python3 dc.py profile --python # Python repr (eval-safe)
Global flags work before or after the command name:
python3 dc.py --json profile
python3 dc.py profile --json
All list-returning commands take the same flags:
python3 dc.py trips
python3 dc.py trips --limit 10
python3 dc.py trips --limit 10 --cursor <opaque-token-from-previous-response>
python3 dc.py trips --past --limit 5
Standard envelope:
{
"items": [ /* page of records */ ],
"count": 42,
"cursor": "opaque-token-or-null",
"has_more": true
}
Non-paginated extras (e.g. totalUnread on inbox) are passed through under an extra key.
Installed from PyPI (pip install dynamitecircle) — import by the package name:
from dynamitecircle import DC
dc = DC()
Working from a clone instead? Point sys.path at the py/ folder and import as dc:
import sys
sys.path.insert(0, "py")
from dc import DC
dc = DC()
# Reads
profile = dc.profile()
trips = dc.trips(past=True, limit=10)
events = dc.events(past=True, limit=5)
chapters = dc.chapters()
overlaps = dc.overlaps()
locator = dc.locator(sections="homeCity,favoriteCities")
# Writes
dc.profile_update({"headline": "CEO at Acme"})
dc.trip_create(start_date="2026-12-01", end_date="2026-12-05", place_id="ChIJ...")
dc.event_rsvp("<eventID>", "yes")
dc.invite_create(email="new@friend.com", full_name="New Friend")
Override the API URL (e.g. for a local dev server):
dc = DC(api_url="http://localhost:8080")
The full live reference for the DC Member API — every endpoint, parameter, and response shape — is at https://www.dynamitecircle.com/developers/. The page is regenerated on every deploy, so it's always current.
The DC Member API ships new endpoints and refinements regularly. This skill is the official client and we update it whenever the API changes. Plan for updates — the skill will warn you on stderr the first time a request returns a server X-API-Version newer than DC_API_VERSION, and major-version bumps may break older clients.
The no-maintenance option: if you use the hosted MCP (https://api.dynamitecircle.com/mcp), there's nothing to update — the server always runs the current API version. The strategies below apply only to the local client.
Pick whichever integration style fits your project. From simplest to most isolated:
pip / uvxpip install dynamitecircle # CLI + library
pip install 'dynamitecircle[mcp]' # + local MCP server (dc --mcp)
Then dc setup --api-key dk_<api-key> and dc self-test. Update with pip install --upgrade dynamitecircle. For a local MCP that auto-updates on every launch, use the uvx config above.
Best for: the quickest local install, and the auto-updating uvx MCP setup.
git clone https://github.com/dynamitecircle/dc.git
cd dc
python3 py/dc.py setup --api-key dk_<api-key>
To update: cd dc && git pull. Run self-test afterwards.
Best for: trying things out, scripts you run by hand, no other repo involved.
If you have your own project repo and want the dc repo versioned alongside it:
cd your-project
git submodule add https://github.com/dynamitecircle/dc.git vendor/dc
git commit -m "Add dc client as submodule"
To update later:
cd vendor/dc
git pull origin main
cd ../..
git add vendor/dc
git commit -m "Bump dc client"
Then in your code:
import sys
sys.path.insert(0, "vendor/dc/py")
from dc import DC
Best for: production-ish code where you want explicit, reviewable bumps.
cd your-project
git subtree add --prefix vendor/dc \
https://github.com/dynamitecircle/dc.git main --squash
Update with:
git subtree pull --prefix vendor/dc \
https://github.com/dynamitecircle/dc.git main --squash
Best for: teammates who don't know submodules — files just appear in your repo.
If you keep all your projects in ~/code/:
git clone https://github.com/dynamitecircle/dc.git ~/code/dc
# In each project that uses it:
cd ~/code/your-project
ln -s ../dc vendor/dc
Now cd ~/code/dc && git pull updates every consumer at once. Project-level .mcp.json / .codex/config.toml entries can use vendor/dc/py/dc.py and they'll resolve through the symlink.
Best for: power users with multiple personal projects and one machine.
The skill is one file with no setup.py, but you can install the package the MCP server needs and check the file out as a sibling:
pip install mcp
git clone https://github.com/dynamitecircle/dc.git
Best for: CI environments, ephemeral containers, scripted setups.
self-test after every update. Five seconds, catches breakage.| Tier | Per minute | Per day |
|---|---|---|
| DC Community | 10 | 300 |
| DC BLACK | 60 | 3,000 |
Headers on every response: X-RateLimit-Limit, X-RateLimit-Remaining, X-RateLimit-Reset, X-RateLimit-Daily-Remaining.
Tested on macOS, Linux, and Windows 10/11. Python 3.9+ required (uses pathlib, Path.replace, inspect.signature, contextvars, urllib).
stdout and stderr to UTF-8 at startup, so emoji and em-dashes render correctly even on legacy cmd.exe (which defaults to cp1252). If you still see mojibake on a very old terminal, set PYTHONIOENCODING=utf-8 once: setx PYTHONIOENCODING utf-8 then restart your shell.setup writes .env.dc and tries to chmod 600 it. On Windows this is a no-op — the file inherits NTFS perms from its parent. The skill emits a one-time note about this when you run setup. Make sure your repo isn't on a shared drive.python or python3.exe to invoke; the #!/usr/bin/env python3 shebang is ignored on Windows.dc/
├── README.md # this file
├── CLAUDE.md # AI-tool guide (also linked as AGENTS.md, GEMINI.md)
├── AGENTS.md → CLAUDE.md # symlink (Codex)
├── GEMINI.md → CLAUDE.md # symlink (Gemini)
├── LICENSE # MIT
├── manifest.json # MCPB manifest (MCP 2025-11 spec)
├── .mcp.json # auto-registers `dc` MCP server in Claude Code
├── .codex/
│ └── config.toml # auto-registers `dc` for Codex CLI
├── .github/
│ └── copilot-instructions.md # GitHub Copilot
│
├── py/ # ← Python client (canonical)
│ ├── SKILL.md # Agent Skills frontmatter + usage
│ ├── config.json # name, version, env requirements
│ ├── dc.py # CLI + Python import + --mcp server
│ ├── requirements.txt # optional MCP dep — skip for CLI/import
│ ├── .env.dc.example # template
│ └── .env.dc # gitignored (created by `setup`)
│
│ (Future: go/, node/, rs/ folders for sister clients in other languages)
│
├── DC/
│ └── SKILL.md → ../py/SKILL.md # human-friendly skill path (symlink)
│
├── docs/ # ← REAL design docs (canonical)
│ ├── skill-info.md # design rules / architecture
│ └── mcp-info.md # MCP setup for every supported client
│
├── .claude/ # Agent Skills discovery (Claude Code)
│ ├── skills/dc → ../../py # symlink to canonical Python client
│ └── docs → ../docs # symlink to canonical docs
│
├── .agents/ # Agent Skills discovery (Codex CLI + Gemini CLI alias)
│ ├── skills/dc → ../../py # symlink to canonical Python client
│ └── docs → ../docs # symlink to canonical docs
│
├── .gemini/ # Gemini CLI MCP config
│ └── settings.json # auto-approves dc MCP tools (trust: true)
│
├── .gitignore
└── .gitattributes
This is a monorepo. The Python client lives at /py/ so we can add future sister clients (go/, node/, rs/) at the same level — they all wrap the same DC Member API. /docs/ is shared. The dotfile-prefixed directories (.claude/, .agents/, .gemini/) exist because AI tools auto-discover skills from those specific paths — they're kept hidden but each one symlinks (or points) straight to the canonical folder, so you only edit files in one place. Edit py/dc.py and Claude Code, Codex, and Gemini CLI all see the same file via their respective discovery directories. Gemini CLI also reads .agents/skills/ as an alias, so we don't need a redundant .gemini/skills/ symlink.
If you're adding new code or docs, edit py/ (or docs/) directly. The discovery folders take care of themselves.
.claude/settings.json, .codex/config.toml, and .gemini/settings.json all auto-approve the dc MCP server's tools so users don't get a per-call approval prompt when they open this repo with their AI tool. Anyone uncomfortable with that can override with their personal .claude/settings.local.json, ~/.codex/config.toml, or ~/.gemini/settings.json. Every dc write tool is scoped to the caller's own DC account via their personal API key — pre-approval doesn't widen any blast radius, just removes per-call friction.
This repo is maintained by the Dynamite Circle team. It's read-only for the public — clone it and use it, but don't open PRs. If you spot a bug or want a new feature, contact us through the official DC channels.
MIT — see the LICENSE file for the full text.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.