moodle-connector
Provides a complete Moodle REST API client with batch downloading capabilities, allowing AI agents to list courses, check grades, track assignments, fetch materials, download files, and retrieve announcements and deadlines via Moodle's API.
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., "@moodle-connectorshow my upcoming deadlines"
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.
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 coursesPython Library:
from moodle_connector import MoodleConnectorMCP 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 chromiumQuick Start
1. Configure
cp config.template.json config.json
# Edit config.json: set base_url to your Moodle instance2. Login (SSO / MFA)
MOODLE_CRED_PASSWORD=any-password python moodle_connector.py loginA 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.xIf 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.pyOutput 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.jsNavigate 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.phpIf 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>redirectThe 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 defaultsError 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 automationGit-safe: Never commit
config.jsonwith real tokensNo 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)
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/Jabir-Srj/moodle-connector'
If you have feedback or need assistance with the MCP directory API, please join our Discord server