Stefan Lohmaier fc50afa3c8 security: OAuth Auth-Bypass schliessen (client_secret + PKCE jetzt Pflicht)
KRITISCH: /token akzeptierte authorization_code OHNE client_secret
('rely on PKCE alone'-Zweig) und ueberging PKCE wenn code_challenge leer war.
Da client_id nur der Benutzername ist (z.B. 'stefan', steht in der Subdomain),
konnte jeder mit ratbarem Namen einen 30-Tage-Vollzugriffs-Token holen
(verifiziert ausnutzbar). Token galt zudem fuer alle 5 MCP-Dienste.

Fix:
- /authorize: code_challenge (PKCE) PFLICHT
- /token: client_secret PFLICHT (_resolve_client) UND PKCE-Verifikation PFLICHT,
  Bypass-Zweige entfernt.
claude.ai sendet beides (client_secret_post + S256-PKCE, per Audit verifiziert)
-> kein erneutes Verbinden noetig, bestehende Tokens bleiben gueltig.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-18 10:02:10 +02:00

mcp-home

Self-hosted MCP servers for Claude. Gives Claude access to your email, calendar, contacts, files, and notes — all running on your own hardware, behind OAuth.

Services & Tools

  • Maillist_accounts, list_folders, search_mail (full text), read_mail (lists attachments), read_attachment (image/PDF/text), create_draft
  • Calendar + Taskslist_calendars, get_events, search_events, list_task_lists, get_tasks, create_event (travel time + geocoding + reminders), create_task
  • Contactssearch_contacts, get_contact (with photo), create_contact, set_contact_photo
  • Fileslist_files, read_file (image/document/text), file_info, search_files, write_file, create_folder, delete_file, move_file
  • Noteslist_notebooks, list_notes, search_notes, read_note, create_note, list_note_resources, read_resource (attachments)

Setup

python3 -m venv venv
venv/bin/pip install mcp[cli] httpx vobject python-dateutil pytest
cp tokens.json.example tokens.json      # set OAuth client secrets
cp config.json.example config.json      # set backend credentials

Notes needs joplin-cli sync clients exposing the Data API (see /opt/joplin-mcp/).

Usage with claude.ai

Settings → Integrations → Custom MCP Server:

  • URL: https://<service>.mcp.your-domain/mcp (mail, calendar, contacts, files, notes)
  • OAuth Client ID: your username (e.g. stefan)
  • OAuth Client Secret: from tokens.json

claude.ai runs the OAuth Authorization Code + PKCE flow automatically.

Tests

venv/bin/python -m pytest tests/test_all.py -v

54 integration tests (OAuth, all tools, CRUD in isolated test collections). Run daily via mcp-tests.timer.

License

MIT

S
Description
Self-hosted MCP servers for Claude — Mail, Calendar, Contacts, Files, Notes via CalDAV/CardDAV/WebDAV/IMAP
Readme 345 KiB
Languages
Python 99.1%
Shell 0.9%