Query 750+ Swedish statutes, EU cross-references, case law, and preparatory works
Query 750+ Swedish statutes, 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 (186/188 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-swedish-law-mcp": {
"args": [
"-y",
"@ansvar/swedish-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 Riksdagen alternative for the AI age.
Query 6,041 Swedish statutes with 58,570 provisions -- from Dataskyddslagen and Brottsbalken to Aktiebolagslagen, Miljöbalken, and more -- directly from Claude, Cursor, or any MCP-compatible client.
If you're building legal tech, compliance tools, or doing Swedish legal research, this is your verified reference database.
Built by Ansvar Systems -- Stockholm, Sweden
Swedish legal research is scattered across Riksdagen, SFS publications, lagen.nu, and EUR-Lex. Whether you're:
...you shouldn't need 47 browser tabs and manual PDF cross-referencing. Ask Claude. Get the exact provision. With context.
This MCP server makes Swedish law searchable, cross-referenceable, and AI-readable.
Claude Desktop — add to claude_desktop_config.json:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Cursor / VS Code:
For organisations that want a single OAuth-gated endpoint covering this MCP plus the rest of the Ansvar fleet (multi-jurisdiction law, EU regulations, sector regulators, case law), use the Ansvar Gateway — a single MCP endpoint that routes and fans out across the full catalogue. Tier-gated (premium, team, company); requires an Ansvar account.
Once connected, just ask naturally:
| Category | Count | Details |
|---|---|---|
| Statutes | 6,041 statutes | Comprehensive Swedish legislation |
| Provisions | 58,570 sections | Full-text searchable with FTS5 |
| Preparatory Works | 6,735 documents | Propositions (Prop.) and SOUs |
| EU Cross-References | 668 references | 228 EU directives and regulations |
| Legal Definitions | 0 (free tier) | Table reserved, extraction not enabled in current free build |
| Database Size | ~125 MB | Optimized SQLite, portable |
| Daily Updates | Automated | Freshness checks against Riksdagen |
Verified data only -- every citation is validated against official sources (Riksdagen, lagen.nu, EUR-Lex). Zero LLM-generated content.
Verbatim Source Text (No LLM Processing):
Smart Context Management:
Technical Architecture:
Riksdagen API → Parse → SQLite → FTS5 snippet() → MCP response
↑ ↑
Provision parser Verbatim database query
| Traditional Approach | This MCP Server |
|---|---|
| Search Riksdagen by SFS number | Search by plain Swedish: "personuppgifter samtycke" |
| Navigate multi-chapter statutes manually | Get the exact provision with context |
| Manual cross-referencing between laws | build_legal_stance aggregates across sources |
| "Is this statute still in force?" → check manually | check_currency tool → answer in seconds |
| Find EU basis → dig through EUR-Lex | get_eu_basis → linked EU directives instantly |
| Check 5+ sites for updates | Daily automated freshness checks |
| No API, no integration | MCP protocol → AI-native |
Traditional: Search Riksdagen → Download SFS PDF → Ctrl+F → Cross-reference with proposition → Check EUR-Lex for EU basis → Repeat
This MCP: "What EU law is the basis for DSL 3 kap. 5 § about consent?" → Done.
See TOOLS.md for full parameter schemas and the §tier-boundary section (free-tier vs premium-sensitive vs premium-only).
| Tool | Description |
|---|---|
search_legislation | FTS5 search on 58,570 provisions with BM25 ranking |
get_provision | Retrieve specific provision by SFS + chapter/section |
search_case_law | FTS5 search on case law with court/date filters (premium-sensitive) |
get_preparatory_works | Get linked propositions and SOUs for a statute (premium-sensitive) |
validate_citation | Validate citation against database (zero-hallucination check) |
build_legal_stance | Aggregate citations from statutes, case law, prep works (premium-sensitive) |
format_citation | Format citations per Swedish conventions (full/short/pinpoint) |
check_currency | Check if statute is in force, amended, or repealed |
| Tool | Description |
|---|---|
get_eu_basis | Get EU directives/regulations for Swedish statute |
get_swedish_implementations | Find Swedish laws implementing EU act |
search_eu_implementations | Search EU documents with Swedish implementation counts |
get_provision_eu_basis | Get EU law references for specific provision |
validate_eu_compliance | Check implementation status (future, requires EU MCP) |
| Tool | Description |
|---|---|
get_provision_history | Provision version history showing amendments over time |
diff_provision | Diff two versions of a provision |
get_recent_changes | Recent statute changes within a time window |
| Tool | Description |
|---|---|
list_sources | Data provenance metadata per source |
about | Server stats, freshness, build date, tier, dataset summary |
668 cross-references linking 309 Swedish statutes to EU law, with bi-directional lookup.
| Metric | Value |
|---|---|
| EU References | 668 cross-references |
| EU Documents | 228 unique directives and regulations |
| Swedish Statutes with EU Refs | 309 (12.8% of statutes) |
| Directives | 89 |
| Regulations | 139 |
| EUR-Lex Integration | Automated metadata fetching |
See EU_INTEGRATION_GUIDE.md for detailed documentation and EU_USAGE_EXAMPLES.md for practical examples.
All content is sourced from authoritative Swedish legal databases:
A daily GitHub Actions workflow monitors all data sources:
| Source | Check | Method |
|---|---|---|
| Statute amendments | Riksdagen API date comparison | All 6,041 statutes checked |
| New statutes | Riksdagen SFS publications (90-day window) | Diffed against database |
| Case law | lagen.nu feed entry count | Compared to database |
| Preparatory works | Riksdagen proposition API (30-day window) | New props 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.
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 Riksdagen/SFS publications. However:
- This is a research tool, not a substitute for professional legal counsel
- Court case coverage 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 Swedish statute text, not EUR-Lex full text
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 compliance guidance.
This repository uses a dev integration branch. Do not push directly to main.
feature-branch → PR to dev → verify on dev → PR to main → deploy
main is production-ready. Only receives merges from dev via PR.dev is the integration branch. All changes land here first.dev.git clone https://github.com/Ansvar-Systems/swedish-law-mcp
cd swedish-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 -- <sfs-number> <output.json> # Ingest statute from Riksdagen
npm run ingest:auto-all -- --scope all-laws --dry-run # Coverage audit against Riksdagen
npm run ingest:auto-all -- --scope all-laws # Ingest full law-like corpus from Riksdagen
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
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{swedish_law_mcp_2025,
author = {Ansvar Systems AB},
title = {Swedish Law MCP Server: Production-Grade Legal Research Tool},
year = {2025},
url = {https://github.com/Ansvar-Systems/swedish-law-mcp},
note = {Comprehensive Swedish legal database with 6,041 statutes and EU law cross-references}
}
Apache License 2.0. See LICENSE for details.
SE-Statutory-PD -- Swedish statutory public domain. Upphovsrättslagen (1960:729) §9 excludes författningar (laws and regulations), beslut av myndighet (decisions of public authorities), yttranden av svensk myndighet (official statements), and official translations of these works from copyright protection. Verified verbatim 2026-05-17 -- see docs/audits/2026-05-17-eu-copyright-statutory-works-batch-3-BG-HR-SK-SI-SE.md. Catalog entry: SE-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 Swedish law -- turns out everyone building for the Swedish market has the same research frustrations.
So we're open-sourcing it. Navigating 6,041 statutes 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.