TutorClaw MCP
Provides tools for upgrading learner tiers via Stripe checkout sessions and webhook verification, enabling payment-based feature unlocks.
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., "@TutorClaw MCPGuide me through predict step for chapter 1."
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.
TutorClaw MCP
An MCP server built for OpenClaw that turns the learner's OpenClaw instance into a programming tutor. Learners progress through chapters using the PRIMM-Lite pedagogy — Predict → Run → Investigate → Modify → Make — while TutorClaw tracks state, serves content, gates tiers, and handles Stripe upgrades.
TutorClaw follows the platform-inversion model: OpenClaw provides the compute, messaging, and agent orchestration on the learner's side; TutorClaw provides only tools, content, and teaching logic — no database, no cloud, just JSON and markdown on disk.
Features
9 MCP tools covering learner state, content delivery, pedagogy, code execution, and billing
PRIMM-Lite methodology — stage-appropriate prompts and assessment built into the tools
Local-first storage — learners and progress in JSON, chapters in markdown, exercises in JSON
Tier gating — free tier caps (chapters 1–5, 50 exchanges/day, 10 code submissions/day); paid tier unlimited
Stripe integration —
get_upgrade_urlcreates a checkout session;/webhookendpoint verifiescheckout.session.completedand flips the learner to paidSandboxed code execution — blocks
os,subprocess,shutil,open(); 5-second timeout per submissionStreamable-HTTP transport — stateless, FastMCP, port 8000
Related MCP server: 6DuckLearn MCP
The 9 Tools
Tool | Purpose |
| Create a new learner and return their ID + API key |
| Read chapter, stage, confidence, tier, exchanges remaining |
| Advance chapter/stage and apply a confidence delta |
| Fetch chapter markdown, optionally narrowed to a section |
| Return practice problems, optionally filtered by weak areas |
| Produce a stage-appropriate code excerpt and teaching system prompt |
| Score a learner's answer against expected concepts |
| Execute Python code in a sandbox with import and builtin restrictions |
| Create a Stripe checkout session for a free-tier learner |
Project Layout
tutorclaw-mcp/
├── src/tutorclaw/
│ ├── server.py # FastMCP server, tool registration, /webhook route
│ ├── store.py # JSON persistence, tier checks, quota tracking
│ ├── webhook.py # Stripe checkout.session.completed handler
│ └── tools/
│ ├── learners.py # register_learner, get_learner_state, update_progress
│ ├── content.py # get_chapter_content, get_exercises
│ ├── guidance.py # generate_guidance
│ ├── assessment.py # assess_response
│ ├── execution.py # submit_code (sandboxed)
│ └── billing.py # get_upgrade_url
├── content/
│ ├── chapters/ # 01-variables.md … 05-files.md (free), 06+ (paid)
│ └── exercises/ # 01-exercises.json … 05-exercises.json
├── data/ # Runtime state (gitignored): learners.json, learner_state.json
├── tests/ # Per-tool unit tests + integration + payment-flow suites
├── AGENTS.md # Agent instructions: session-start + tutoring flow
├── CLAUDE.md # Build rules (uv, flat Annotated params, streamable-http)
└── pyproject.tomlRequirements
Python 3.14+
uv for dependency management
A Stripe account (test mode is fine) for the upgrade flow
Setup
# Clone
git clone https://github.com/mohsinsheikhani/tutorclaw-mcp.git
cd tutorclaw-mcp
# Install dependencies
uv sync
# Configure Stripe (required only for get_upgrade_url and /webhook)
cp .env.example .env
# Edit .env and fill in:
# STRIPE_SECRET_KEY=sk_test_...
# STRIPE_PRICE_ID_PAID=price_...
# STRIPE_WEBHOOK_SECRET=whsec_...Running the Server
uv run tutorclawThe server starts on http://0.0.0.0:8000 with streamable-HTTP stateless transport. The MCP endpoint is /mcp and the Stripe webhook is /webhook.
Connect with MCP Inspector
npx @modelcontextprotocol/inspectorPoint it at http://localhost:8000/mcp and explore the 9 tools.
Stripe webhook (local testing)
stripe listen --forward-to localhost:8000/webhook
# Copy the printed whsec_... into .env as STRIPE_WEBHOOK_SECRET
stripe trigger checkout.session.completedTier Gating
Limit | Free | Paid |
Chapters accessible | 1–5 | All |
Exchanges per day | 50 | Unlimited |
Code submissions per day | 10 | Unlimited |
Daily counters reset automatically at the first request after the reset date rolls over. Tools raise a ValueError with an upgrade hint when any gate trips.
Storage Model
data/learners.json—{learner_id: {name, email, tier, api_key, created_at}}data/learner_state.json—{learner_id: {chapter, stage, confidence, exchanges_remaining, exchanges_reset_date, code_submissions_today, weak_areas}}
Writes are atomic (temp-file + os.replace). Both files are gitignored.
Testing
uv run pytestThe suite covers every tool with both unit and integration tests, plus a full payment-flow test (checkout session creation → webhook verification → tier upgrade). All tests use isolated tmp_path fixtures, so the production data/ directory is never touched.
Agent Usage
Drop AGENTS.md into the agent's context — it defines the session-start protocol, the tutoring flow, and the tool-selection rules:
On first message:
get_learner_state→register_learnerif missing.For a lesson:
get_chapter_content→generate_guidance→ present →assess_response→update_progress.For practice:
get_exercises.For code:
submit_code(neverassess_response).On tier block:
get_upgrade_url.
License
MIT
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
- 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/mohsinsheikhani/tutorclaw-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server