moodle-connector
Moodle REST API client with batch downloading and MCP protocol support for Claude Code and OpenCode, enabling course management, grade checking, assignment tracking, file downloads, and more.
README
name: moodle-connector description: "Moodle REST API client, batch downloader, and MCP server for Claude Code integration" metadata: { "author": "Jabir Iliyas Suraj-Deen, Sebastian Guevara M.", "license": "MIT", "homepage": "https://github.com/Jabir-Srj/moodle-connector", "repository": "https://github.com/Jabir-Srj/moodle-connector.git", "tags": ["moodle", "education", "lms", "api", "batch-download", "mcp", "claude-code"] }
English | Español
Moodle Connector
Full-featured Moodle REST API client with batch downloading and MCP protocol support for Claude Code and OpenCode.
Features
Complete Moodle API Access
- List courses, check grades, track assignments
- Fetch materials, deadlines, announcements
- Download files with aggressive caching
Microsoft SSO / MFA Support
- Automated Mobile Launch Flow (same as the official Moodle app)
- Works with any SSO provider: Microsoft Azure AD, Google, SAML, etc.
- Browser opens for interactive login - closes automatically once token is captured
Multiple Integration Modes
- CLI:
python moodle_connector.py courses - Python Library:
from moodle_connector import MoodleConnector - MCP Protocol: Native integration with Claude Code, OpenCode, and OpenClaw
Generic Batch Downloader
- JSON-driven configuration (zero code modification)
- Works with any Moodle module
- Auto-organized by course name
Security
- Encrypted credentials (PBKDF2 + Fernet)
- Token management built-in
- No secrets in git history
- MIT licensed
Installation
Once installed via clawhub install moodle-connector:
cd ./skills/moodle-connector
pip install -r requirements.txt
python -m playwright install chromium
Quick Start
1. Configure
cp config.template.json config.json
# Edit config.json: set base_url to your Moodle instance
2. Login (SSO / MFA)
MOODLE_CRED_PASSWORD=any-password python moodle_connector.py login
A browser window will open. Complete your Microsoft (or other SSO) login and MFA normally - the window closes automatically once the token is captured. You should see:
# ✅ Authentication Successful
- User: Your Name
- Site: Your Moodle Site
- Moodle version: 4.x.x
If your instance allows direct username/password login (no SSO), you can also run:
python moodle_connector.py login --username you@email.com --user-password yourpassword
3. Use CLI
python moodle_connector.py courses # List all courses
python moodle_connector.py grades # Check grades
python moodle_connector.py assignments # View assignments with deadlines
python moodle_connector.py announcements # Course announcements
python moodle_connector.py materials --course-id 12345
python moodle_connector.py deadlines # Upcoming calendar events
python moodle_connector.py download "https://your-moodle-site.example.com/..." --output myfile.pdf
python moodle_connector.py summary # Full markdown export (all data)
4. Use Python Library
from moodle_connector import MoodleConnector
from pathlib import Path
connector = MoodleConnector(
config_path=Path('config.json'),
password='encryption-password'
)
courses = connector.courses()
grades = connector.grades()
assignments = connector.assignments()
materials = connector.materials()
deadlines = connector.deadlines()
announcements = connector.announcements()
content = connector.summary()
# Download with caching
file_content = connector.download("https://...")
5. Batch Download (Any Module)
cp downloads.example.json downloads.json
# Edit downloads.json to add modules and file URLs
python batch_downloader.py
Output Structure:
downloads/
├── Your_Module_Name_1/
│ ├── file1.pdf
│ ├── file2.zip
│ └── ...
└── Your_Module_Name_2/
├── lecture.pdf
└── ...
Tampermonkey Token Helper
If the connector is running on a headless server (no display), get the token from a PC or Mac with a browser and copy it over. Install the included userscript on that machine:
- Install Tampermonkey in your browser
- Open Tampermonkey - Create new script - paste the contents of
moodle_token_helper.user.js - Navigate to your Moodle site while logged in
- Click the "Get Token" button (bottom right corner)
- Copy the token and paste it into
config.jsonunderweb_service_token
The script uses GM_xmlhttpRequest to call the Mobile Launch endpoint with your active session cookies and intercepts the moodlemobile:// redirect without leaving the page.
To support additional Moodle instances, add @match and @connect lines to the script header.
How Authentication Works
This connector uses Moodle's Mobile Launch Flow - the same mechanism used by the official Moodle mobile app. It works with any SSO provider without needing API credentials or special server configuration.
Flow:
- Browser navigates to
/admin/tool/mobile/launch.php - If no session exists, Moodle redirects to the SSO provider (e.g. Microsoft)
- User completes login + MFA interactively
- SSO redirects back to Moodle, which issues a
moodlemobile://token=<base64>redirect - The connector intercepts this redirect, decodes the token, and closes the browser
The token is cached in an encrypted file (credentials.enc) and reused until it expires.
MCP Integration (Claude Code / OpenCode / OpenClaw)
REQUIRED: Set MOODLE_CRED_PASSWORD environment variable before starting Claude Code.
Add to your claude_desktop_config.json:
{
"mcpServers": {
"moodle-connector": {
"command": "python",
"args": ["./skills/moodle-connector/mcp_server.py"],
"env": {
"MOODLE_CRED_PASSWORD": "your-encryption-password"
}
}
}
}
Important: Replace your-encryption-password with the actual password used when running login.
Restart Claude Code. All 8 Moodle functions are now available as native MCP tools:
courses()- List enrolled coursesgrades()- Get gradesassignments()- Get assignmentsmaterials()- Get course materialsdeadlines()- Get upcoming deadlinesannouncements()- Get course newsdownload(url, output?)- Download filessummary()- Get complete data export
Configuration
Moodle Token (config.json)
{
"moodle": {
"base_url": "https://your-moodle-site.example.com",
"web_service_token": ""
},
"cache": {
"api_ttl_seconds": 300
}
}
Leave web_service_token empty to use the automated SSO login flow. Set it manually if you already have a token.
Batch Downloader (downloads.json)
{
"downloads": [
{
"module": "Machine Learning",
"course_id": 44864,
"files": [
{
"name": "Week1.zip",
"url": "https://your-moodle-site.example.com/webservice/pluginfile.php/..."
}
]
}
]
}
Requirements
- Python 3.10+
- requests ≥2.31.0
- cryptography ≥41.0.0
- playwright ≥1.40.0
- mcp ≥0.1.0 (for MCP server)
Supported Moodle Instances
Tested with:
- Taylor's University (mytimes.taylors.edu.my)
- Universidad Técnica Federico Santa María (aula.usm.cl) - Microsoft Azure AD SSO
- Should work with any Moodle 3.x+ instance
Security Notes
- Environment-enforced:
MOODLE_CRED_PASSWORDis required - no hardcoded defaults - Error sanitization: MCP server sanitizes errors, no internal details leaked to clients
- Encrypted credentials: PBKDF2 (480K iterations) + Fernet encryption
- Safe for headless: Use
MOODLE_CRED_PASSWORDenv var for automation - Git-safe: Never commit
config.jsonwith real tokens - No telemetry: No external data transmission or logging
Troubleshooting
Browser opens but never closes
The token redirect was not captured. Check if your University allows the usage of Moodle App.
"Invalid parameter value detected" for calendar API
Use assignments() instead - gets same deadline info.
Token expired / login required again
Delete credentials.enc and run python moodle_connector.py login again.
File download stuck
Check network. Increase timeout in code or clear cache: rm -rf cache/
License
MIT - See LICENSE file for details. You are free to use, modify, and distribute this software.
Contributing
Contributions welcome! Please:
- Fork the repository
- Create a feature branch
- Submit a pull request
- Agree to license your work under GPLv3
Authors
Jabir Iliyas Suraj-Deen - original author
- GitHub: https://github.com/Jabir-Srj
- Email: jabirsrj8@protonmail.com
- Taylor's University, Kuala Lumpur, Malaysia
Sebastian Guevara M. - SSO Mobile Launch Flow, multi-instance support
- GitHub: https://github.com/SebaG20xx
- Email: contacto@sebag20xx.cl
- Universidad Técnica Federico Santa María, Viña del Mar, Chile
GitHub: https://github.com/Jabir-Srj/moodle-connector Release: v1.1.0 (March 26, 2026)
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.