Smartschool 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., "@Smartschool MCP Servershow my grades for this term"
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.
Smartschool MCP Server
Connect Claude (and other MCP clients) to your Smartschool account — ask about grades, assignments, messages, and your schedule in plain language.
Tools
Tool | What it does |
| List enrolled courses with teacher info |
| Grades with optional filtering, pagination, and statistics |
| Upcoming assignments organised by date |
| Inbox/sent/trash with search, sender filter, and body retrieval |
| Day schedule by offset (0 = today, 1 = tomorrow, …) |
| Academic terms for the current school year |
| Available report cards |
| Planner items for the next N days |
| School support resources and links |
| List attachments for a specific message |
| Download a specific attachment by message and file ID |
Quick start — Claude Desktop
uvx mcp install smartschool-mcp \
-e SMARTSCHOOL_USERNAME="you" \
-e SMARTSCHOOL_PASSWORD="secret" \
-e SMARTSCHOOL_MAIN_URL="school.smartschool.be" \
-e SMARTSCHOOL_MFA="YYYY-MM-DD"Or add it manually to claude_desktop_config.json:
{
"mcpServers": {
"smartschool": {
"command": "uvx",
"args": ["smartschool-mcp"],
"env": {
"SMARTSCHOOL_USERNAME": "you",
"SMARTSCHOOL_PASSWORD": "secret",
"SMARTSCHOOL_MAIN_URL": "school.smartschool.be",
"SMARTSCHOOL_MFA": "YYYY-MM-DD"
}
}
}
}Config file locations: %APPDATA%\Claude\claude_desktop_config.json (Windows) · ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) · ~/.config/Claude/claude_desktop_config.json (Linux)
Remote / claude.ai
The server supports Streamable HTTP transport for use as a remote integration on claude.ai.
Single-user mode
One server instance, your credentials in environment variables:
export SMARTSCHOOL_USERNAME="..."
export SMARTSCHOOL_PASSWORD="..."
export SMARTSCHOOL_MAIN_URL="school.smartschool.be"
export SMARTSCHOOL_MFA="YYYY-MM-DD"
export MCP_API_KEY="a-long-random-secret" # optional but recommended
smartschool-mcp --transport streamable-http --host 0.0.0.0 --port 8000Add to claude.ai → Settings → Integrations:
URL:
https://your-domain.example.com/mcpAuthorization header:
Bearer <your MCP_API_KEY>(if set)
Universal mode
One hosted server instance serves any Smartschool user — no per-user deployment needed.
smartschool-mcp --transport streamable-http --universal --host 0.0.0.0 --port 8000Credentials are passed on every request:
What | Where | Example |
School URL | URL query param |
|
Date of birth (MFA) | URL query param |
|
Username | OAuth Client ID | your Smartschool username |
Password | OAuth Client Secret | your Smartschool password |
In claude.ai → Settings → Integrations → Add custom connector:
URL:
https://your-domain.example.com/mcp?school=myschool.smartschool.be&mfa=YYYY-MM-DDOAuth Client ID: your Smartschool username
OAuth Client Secret: your Smartschool password
MFA is your date of birth in
YYYY-MM-DDformat. Omit themfaparam if your account does not require it.
Making the server publicly accessible
Claude.ai requires HTTPS. Some options:
Option | Command |
Cloudflare Tunnel |
|
ngrok |
|
VPS | nginx / Caddy with a Let's Encrypt cert |
Environment variables
Variable | CLI flag | Default | Description |
|
|
|
|
|
|
| Bind address (HTTP only) |
|
|
| Port (HTTP only) |
| — | — | Static Bearer token (single-user mode) |
|
| off | Enable universal mode (set to |
| — |
| How long to cache sessions (universal mode) |
| — | — | Your Smartschool username |
| — | — | Your Smartschool password |
| — | — | School hostname, e.g. |
| — | — | Date of birth |
Contributing
PRs are welcome. Run uv sync --extra dev to install dev dependencies, then uv run pytest / uv run ruff check . / uv run mypy smartschool_mcp/ before submitting.
Disclaimer
Unofficial tool, not affiliated with Smartschool. Use in accordance with your school's terms of service.
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/MauroDruwel/Smartschool-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server