Query Danish laws and regulations, EU cross-references, case law, and preparatory works
Query Danish laws and regulations, EU cross-references, case law, and preparatory works
Valid MCP server (2 strong, 2 medium validity signals). 1 known CVE in dependencies (0 critical, 1 high severity) Package registry verified. Imported from the Official MCP Registry. Trust signals: trusted author (118/118 approved).
5 files analyzed · 2 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Add this to your MCP configuration file:
{
"mcpServers": {
"eu-ansvar-danish-law-mcp": {
"args": [
"-y",
"@ansvar/danish-law-mcp"
],
"command": "npx"
}
}
}From the project's GitHub README.
▶ Try this MCP instantly via Ansvar Gateway
50 free queries/day · no card required · OAuth signup at ansvar.eu/gateway
One endpoint, one OAuth signup, access from any MCP-compatible client.
Claude Code (one line):
claude mcp add ansvar --transport http https://gateway.ansvar.eu/mcp
Claude Desktop / Cursor — add to claude_desktop_config.json (or mcp.json):
{
"mcpServers": {
"ansvar": {
"type": "url",
"url": "https://gateway.ansvar.eu/mcp"
}
}
}
Claude.ai — Settings → Connectors → Add custom connector → paste https://gateway.ansvar.eu/mcp
First request opens an OAuth flow at ansvar.eu/gateway. After signup, your client is bound to your account; tier (free / premium / team / company) determines fan-out, quota, and which downstream MCPs are reachable.
You can also clone this repo and build the corpus yourself. The schema, fetcher, and tool implementations all live here. What is not in the repo is the pre-built database — TDM and standards-licensing constraints on the upstream sources mean we host the corpus on Ansvar infrastructure rather than redistribute it as a public artifact.
Build your own: run this repo's ingestion script (entry-point varies per
repo — typically scripts/ingest.sh, npm run ingest, or make ingest;
check the repo root).
The Retsinformation alternative for the AI age.
Query 62,764 Danish laws -- from Databeskyttelsesloven and Straffeloven to Selskabsloven, Forvaltningsloven, and more -- directly from Claude, Cursor, or any MCP-compatible client.
If you're building legal tech, compliance tools, or doing Danish legal research, this is your verified reference database.
Built by Ansvar Systems -- Stockholm, Sweden
Danish legal research means navigating retsinformation.dk, cross-referencing between lovbekendtgørelser (consolidated laws), forslag (bills), betænkninger (committee reports), and EUR-Lex. Whether you're:
...you shouldn't need dozens of browser tabs and manual PDF cross-referencing. Ask Claude. Get the exact provision. With context.
This MCP server makes Danish law searchable, cross-referenceable, and AI-readable.
Once connected, just ask naturally -- in Danish or English:
| Category | Count | Details |
|---|---|---|
| Laws | 62,764 laws | Complete corpus from retsinformation.dk |
| Provisions | 620,940 sections | Full-text searchable with FTS5 |
| Premium: Case Law | 3,918 rulings | Højesteret, Landsretter decisions |
| Premium: Preparatory Works | 4,412 documents | Lovforslag, betænkninger |
| Database Size | 1.6 GB | Optimized SQLite, hosted on Fly.io |
| Daily Updates | Automated | Freshness checks against retsinformation.dk |
Verified data only -- every citation is validated against official sources (retsinformation.dk). Zero LLM-generated content.
Verbatim Source Text (No LLM Processing):
Smart Context Management:
Technical Architecture:
retsinformation.dk API --> Parse --> SQLite --> FTS5 snippet() --> MCP response
^ ^
Provision parser Verbatim database query
| Traditional Approach | This MCP Server |
|---|---|
| Search retsinformation.dk by document number | Search by plain Danish: "personoplysninger samtykke" |
| Navigate multi-paragraph statutes manually | Get the exact provision with context |
| Manual cross-referencing between laws | build_legal_stance aggregates across sources |
| "Er denne lov stadig i kraft?" → check manually | check_currency tool → answer in seconds |
| Find EU basis → dig through EUR-Lex | get_eu_basis → linked EU directives instantly |
| Check multiple sites for amendments | Daily automated freshness checks |
| No API, no integration | MCP protocol → AI-native |
Traditional: Search retsinformation.dk → Download PDF → Ctrl+F → Cross-reference with betænkning → Check EUR-Lex for EU basis → Repeat
This MCP: "Hvad er EU-retsgrundlaget for Databeskyttelsesloven § 5 om samtykke?" → Done.
| Tool | Description |
|---|---|
search_legislation | FTS5 search on 620,940 provisions with BM25 ranking. Supports quoted phrases, boolean operators, prefix wildcards |
get_provision | Retrieve specific provision by law identifier + paragraph/section (e.g., "Straffeloven" + "263") |
check_currency | Check if a law is in force, amended, or repealed |
validate_citation | Validate citation against database -- zero-hallucination check. Supports "Straffelovens § 263", "Databeskyttelsesloven § 5" |
build_legal_stance | Aggregate citations from multiple laws for a legal topic |
format_citation | Format citations per Danish conventions (full/short/pinpoint) |
list_sources | List all available laws with metadata, coverage scope, and data provenance |
about | Server info, capabilities, dataset statistics, and coverage summary |
| Tool | Description |
|---|---|
get_eu_basis | Get EU directives/regulations that a Danish statute transposes (e.g., Databeskyttelsesloven → GDPR) |
get_danish_implementations | Find Danish laws implementing a specific EU act |
search_eu_implementations | Search EU documents with Danish implementation counts |
get_provision_eu_basis | Get EU law references for a specific provision |
validate_eu_compliance | Check transposition status of Danish statutes against EU directives |
Denmark is a full EU member state. Danish law directly transposes EU directives into national legislation:
| Danish Law | EU Basis |
|---|---|
| Databeskyttelsesloven | GDPR (Regulation 2016/679) |
| Implementeret e-Privacy | ePrivacy Directive (2002/58/EC) |
| Konkurrenceretten | EU Treaty Articles 101-102 (TFEU) |
The EU integration tools support bi-directional lookup: find which EU act a Danish statute transposes, or find all Danish laws implementing a given EU regulation.
Denmark and EU opt-outs: Denmark maintains opt-outs from certain EU policy areas (including Justice and Home Affairs, under Protocol 22 to the Maastricht Treaty). However, data protection law (GDPR), commercial law, and competition law are all fully aligned with EU frameworks. The EU tools in this MCP reflect full transposition coverage for these areas.
See EU_INTEGRATION_GUIDE.md for detailed documentation and EU_USAGE_EXAMPLES.md for practical examples.
All content is sourced from authoritative Danish legal databases:
| Field | Value |
|---|---|
| Authority | Danish Ministry of Justice / Retsinformation |
| Retrieval method | Bulk download from retsinformation.dk API |
| Language | Danish (primary) |
| License | DK-Statutory-PD — Danish statutory public domain (Ophavsretsloven §9) |
| Coverage | All 62,764 consolidated Danish laws |
| Last ingested | 2026-02-22 |
A daily GitHub Actions workflow monitors retsinformation.dk for changes:
| Source | Check | Method |
|---|---|---|
| Law amendments | retsinformation.dk API date comparison | All 62,764 laws checked |
| New laws | retsinformation.dk publications (90-day window) | Diffed against database |
| Case law | Court portal entry count | Compared to database |
| Preparatory works | Lovforslag API (30-day window) | New proposals detected |
| EU reference staleness | Git commit timestamps | Flagged if >90 days old |
The workflow supports auto_update: true dispatch for automated sync, rebuild, version bump, and npm publishing.
The premium tier adds version history, amendment tracking, and extended case law coverage:
| Feature | Free | Premium |
|---|---|---|
| Full statute corpus (62,764 laws) | Yes | Yes |
| Full-text search (620,940 provisions) | Yes | Yes |
| EU law cross-references | Yes | Yes |
| Citation validation | Yes | Yes |
| Case law (3,918 rulings) | No | Yes |
| Preparatory works (4,412 documents) | No | Yes |
Amendment history (get_*_history) | No | Yes |
Version diff (diff_*) | No | Yes |
Recent changes (get_recent_changes) | No | Yes |
Premium is enabled via the PREMIUM_ENABLED environment variable. Contact hello@ansvar.ai for access.
This project uses multiple layers of automated security scanning:
| Scanner | What It Does | Schedule |
|---|---|---|
| CodeQL | Static analysis for security vulnerabilities | Weekly + PRs |
| Semgrep | SAST scanning (OWASP top 10, secrets, TypeScript) | Every push |
| Gitleaks | Secret detection across git history | Every push |
| Trivy | CVE scanning on filesystem and npm dependencies | Daily |
| Docker Security | Container image scanning + SBOM generation | Daily |
| Socket.dev | Supply chain attack detection | PRs |
| OSSF Scorecard | OpenSSF best practices scoring | Weekly |
| Dependabot | Automated dependency updates | Weekly |
See SECURITY.md for the full policy and vulnerability reporting.
THIS TOOL IS NOT LEGAL ADVICE
Statute text is sourced from official retsinformation.dk publications (Danish Ministry of Justice). However:
- This is a research tool, not a substitute for professional legal counsel
- Court case coverage in the free tier is limited -- do not rely solely on this for case law research
- Verify critical citations against primary sources for court filings
- EU cross-references are extracted from Danish statute text and EUR-Lex metadata, not substitute for full EUR-Lex legal text
- Municipal and regional regulations are not included -- this covers national Danish law only
Before using professionally, read: DISCLAIMER.md | PRIVACY.md
Queries go through the Claude API. For privileged or confidential matters, use on-premise deployment. See PRIVACY.md for Advokatsamfundet (Danish Bar Association) compliance guidance.
git clone https://github.com/Ansvar-Systems/Denmark-law-mcp
cd Denmark-law-mcp
npm install
npm run build
npm test
npm run dev # Start MCP server
npx @anthropic/mcp-inspector node dist/index.js # Test with MCP Inspector
npm run ingest # Ingest laws from retsinformation.dk
npm run ingest:auto-all -- --scope all-laws --dry-run # Coverage audit
npm run ingest:auto-all -- --scope all-laws # Ingest full corpus
npm run ingest:cases:full-archive # Ingest case law (full archive)
npm run sync:cases # Ingest case law (incremental)
npm run sync:prep-works # Sync preparatory works
npm run extract:definitions # Extract legal definitions
npm run build:db # Rebuild SQLite database
npm run check-updates # Check for amendments
npm run drift:detect # Run drift detection
Full fleet at ansvar.eu/gateway.
Contributions welcome! See CONTRIBUTING.md for guidelines.
Priority areas:
If you use this MCP server in academic research:
@software{danish_law_mcp_2026,
author = {Ansvar Systems AB},
title = {Danish Law MCP Server: Production-Grade Legal Research Tool},
year = {2026},
url = {https://github.com/Ansvar-Systems/Denmark-law-mcp},
note = {Comprehensive Danish legal database with 62,764 laws and 620,940 provisions from retsinformation.dk}
}
Apache License 2.0. See LICENSE for details.
DK-Statutory-PD — Danish statutory public domain. Ophavsretsloven §9 excludes laws, administrative orders, regulations, court decisions, and similar acts issued by a public authority from copyright protection. Verified verbatim 2026-05-17 — see docs/audits/2026-05-17-eu-copyright-statutory-works-batch-1a-AT-BE-DK-FI-FR.md. Catalog entry: DK-Statutory-PD in infrastructure/attribution-licenses.json.We build AI-accelerated compliance and legal research tools for the European market. This MCP server started as our internal reference tool for Danish law -- turns out everyone building for the Danish and Nordic markets has the same research frustrations.
So we're open-sourcing it. Navigating 62,764 laws on retsinformation.dk shouldn't require a law degree.
ansvar.eu -- Stockholm, Sweden
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.