MCP Hub
Back to servers

German Legal MCP Server

Provides unified access to German federal and state legislation, court decisions, and European Union legal databases for comprehensive legal research. It enables users to search and retrieve full-text laws, parliamentary documents, and judicial rulings directly through the Model Context Protocol.

glama
Updated
Mar 10, 2026

German Legal MCP Server

License: GPL v3 Node.js Version TypeScript MCP

⚠️ WARNING: Work in Progress
This project is currently under active development and not production-ready. APIs may change without notice, and features may be incomplete or unstable. Use at your own risk.

A Model Context Protocol (MCP) server for German legal research, providing unified access to multiple legal databases.

Supported Sources

SourceStatusPrefixAuthentication
Bundes- & Landesrecht✅ Availablelegis:None (public)
Rechtsprechung im Internet✅ Availablerii:None (public)
InfoCuria (CJEU)✅ Availableicu:None (public)
EUR-Lex✅ Availableeul:None (public)
DIP Bundestag✅ Availabledip:Public key included
arXiv✅ Availablearxiv:None (public)

Features

Bundes- & Landesrecht (legis:* tools)

  • Federal and state legislation — BUND (all federal laws) + 16 Länder (all states)
  • No authentication — free public access, no rate limits
  • Unified interface — one set of tools for all jurisdictions
  • Full text search — search across state legislation (Länder only)
  • Resilient input — BUND accepts "§ 823", "823", "Art. 1", "Paragraph 51"
  • Pandoc-compatible Markdown — clean conversion with Turndown
  • Save to filesave_path parameter to avoid context pollution
  • Available states: BUND, BB, BW, BY, BE, HB, HE, HH, MV, NI, NW, RP, SL, SN, ST, SH, TH

Rechtsprechung im Internet (rii:* tools)

  • Federal court decisions — BVerfG, BGH, BVerwG, BFH, BAG, BSG, BPatG (from 2010)
  • Bavarian state courts — AG, LG, OLG, VG, VGH, FG, ArbG, LAG, BayVerfGH via gesetze-bayern.de
  • No authentication — free public access
  • Full text search — search across all federal court decisions
  • Kurztext/Langtext — summary or full text via part parameter
  • Randnummern — formatted as [Rn. 5]{.rn} (pandoc spans)
  • Save to filesave_path parameter to avoid context pollution

InfoCuria — CJEU (icu:* tools)

  • EU Court of Justice case law — judgments, opinions, orders from CJEU and General Court
  • No authentication — free public access via InfoCuria API
  • Multilingual — documents available in all EU languages (default: DE)
  • Flexible case lookup — accepts case numbers (C-476/17), CELEX numbers, or internal IDs
  • Randnummern — formatted as [Rn. 5]{.rn}
  • Partial contentsection parameter for Rn ranges, headings, or line ranges
  • Save to filesave_path parameter to avoid context pollution

EUR-Lex (eul:* tools)

  • EU legislation — directives, regulations, decisions, treaties (TFEU, TEU)
  • No authentication — free public access via Cellar REST API and SPARQL
  • Multilingual — documents available in all EU languages (default: DE)
  • CELEX lookup — retrieve by CELEX number (e.g., "32016R0679" for GDPR)
  • SPARQL search — search by title keywords, filter by resource type
  • Partial contentsection parameter for articles (Art. 5), headings, or line ranges
  • Save to filesave_path parameter to avoid context pollution

DIP Bundestag (dip:* tools)

  • Parliamentary documents — Bundestagsdrucksachen (Gesetzentwürfe, Beschlussempfehlungen, Anfragen)
  • Legislative processes — Vorgänge with status tracking and linked documents
  • Debate transcripts — full text search across Plenarprotokolle (BT and BR)
  • Full text retrieval — extracted text including Gesetzesbegründungen, with section support
  • Public API key included — works out of the box (key expires 2026-06-01, override via env var)
  • Save to filesave_path parameter to avoid context pollution

arXiv (arxiv:* tools)

  • Preprint search — search by keywords, author, title, abstract, or category
  • Metadata + abstract — default response without full text fetch (token-efficient)
  • HTML full text — Markdown conversion for papers from ~2024+ (LaTeXML HTML)
  • PDF fallback — older papers without HTML return abstract + PDF link
  • No authentication — free public API, no rate limits beyond ~1 req/3s
  • Save to filesave_path parameter to avoid context pollution

Quick Start with npx

npx @metaneutrons/german-legal-mcp

or add your MCP client config (e.g., claude_desktop_config.json):

{
  "mcpServers": {
    "german-legal": {
      "command": "npx",
      "args": ["-y", "@metaneutrons/german-legal-mcp"]
    }
  }
}

Environment Variables

Provider Enablement

VariableDefaultDescription
GLMCP_LEGIS_ENABLEDtrueBundes- & Landesrecht
GLMCP_RII_ENABLEDtrueRechtsprechung im Internet
GLMCP_ICU_ENABLEDtrueInfoCuria (CJEU)
GLMCP_EUL_ENABLEDtrueEUR-Lex
GLMCP_DIP_ENABLEDtrueDIP Bundestag (auto-disabled after 2026-06-01 without own key)
GLMCP_DIP_API_KEYPublic keyOverride the bundled public API key
GLMCP_ARXIV_ENABLEDtruearXiv preprint search

Tools

Bundes- & Landesrecht

ToolDescription
legis:searchSearch federal and state legislation. Parameter: query, state (e.g., "BW", "BE"), limit. Note: BUND does not support search.
legis:getRetrieve a specific law/norm. BUND: id = "law/section" (e.g., "bgb/823"). Länder: id from search results. Optional save_path.
legis:tocCompact table of contents for a law — section numbers and headings. Supports from/to range and depth filter. BUND: id = law abbreviation (e.g., "bgb").
legis:statesList available jurisdictions with implementation status.

Rechtsprechung im Internet

ToolDescription
rii:searchSearch for court decisions. Returns list with doc IDs, titles, and snippets. Use source: "BY" for Bavarian state courts.
rii:get_decisionRetrieve full text of a court decision by doc ID. part: K (Kurztext) or L (Langtext, default). Optional save_path to save to file. Use source: "BY" for gesetze-bayern.de IDs.

InfoCuria — CJEU

ToolDescription
icu:searchSearch CJEU decisions and opinions. Returns case numbers, ECLI, dates, and document IDs.
icu:get_documentRetrieve full text by case number (C-476/17) or CELEX number. Supports section (Rn ranges, headings, line ranges) and save_path.

EUR-Lex

ToolDescription
eul:searchSearch EU legislation via SPARQL. Filter by type (directive, regulation, decision, treaty).
eul:get_documentRetrieve EU legislation by CELEX number (e.g., "32016R0679" for GDPR). Supports section (Art. 5, Artikel 5-10, headings, line ranges) and save_path.

DIP Bundestag

ToolDescription
dip:searchSearch Bundestagsdrucksachen by title. Filter by type (Gesetzentwurf, Anfrage, etc.), Wahlperiode, date range.
dip:getRetrieve full text of a Drucksache by Dokumentnummer (e.g., "19/27426"). Supports section and save_path.
dip:search_vorgangSearch legislative processes (Vorgänge) with status and linked Drucksachen.
dip:search_plenarprotokollFull text search across parliamentary debate transcripts (BT and BR).

arXiv

ToolDescription
arxiv:searchSearch preprints by keywords, author, title, abstract, or category. Returns metadata + abstract.
arxiv:getRetrieve paper by arXiv ID. Default: metadata + abstract. With section or save_path: HTML full text as Markdown (~2024+, older: PDF link).

Two-Phase Document Retrieval

All document tools use a two-phase approach to avoid flooding the LLM context:

  1. Outline — first call returns title, metadata, table of contents, and a preview
  2. Section — request specific parts by Randnummer, heading, or line range (served from cache)
  3. Save to file — write full document to disk, return metadata only

Section formats: "Rn 5", "Rn 5-12", "lines:100-200", or any heading text (fuzzy match).

Markdown Output

Documents are converted to pandoc-compatible Markdown:

  • Randnummern: [Rn. 5]{.rn} (bracketed spans)
  • Footnotes: [^1] references with [^1]: text definitions

Development

npm test              # Run tests
npm run test:watch    # Watch mode
npm run test:coverage # Coverage report

MCP Inspector

npx @modelcontextprotocol/inspector node dist/index.js

Commit Convention

This repo uses Conventional Commits enforced via Husky + commitlint.

Types: feat, fix, docs, style, refactor, perf, test, chore, ci, build, revert

Scopes: legis, rii, icu, eul, dip, core, deps, config

Architecture

  • Dynamic provider loading — providers auto-discovered from src/providers/*/
  • Cheerio + Turndown for HTML → pandoc Markdown conversion
  • Zod for input validation
  • Axios for HTTP requests (Legis, RII, InfoCuria, EUR-Lex, DIP, arXiv)
  • Tools namespaced by source (legis:, rii:, icu:, eul:, dip:, arxiv:)

License

GPL-3.0 - See LICENSE for details.

Reviews

No reviews yet

Sign in to write a review