什么是 eu.ansvar/finnish-law-mcp?
可通过Finlex查询芬兰法令,并查看EU交叉引用、判例及立法准备材料。
README
Finnish Law MCP Server
The Finlex alternative for the AI age.
Query Finnish statutes -- from Tietosuojalaki and Rikoslaki to Osakeyhtiölaki, Ympäristönsuojelulaki, and more -- directly from Claude, Cursor, or any MCP-compatible client.
If you're building legal tech, compliance tools, or doing Finnish legal research, this is your verified reference database.
Built by Ansvar Systems -- Helsinki, Finland
Why This Exists
Swedish legal research is scattered across Riksdagen, SFS publications, lagen.nu, and EUR-Lex. Whether you're:
- A lawyer validating citations in a brief or contract
- A compliance officer checking if a statute is still in force
- A legal tech developer building tools on Swedish law
- A researcher tracing legislative history from proposition to statute
...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.
Quick Start
Use Remotely (No Install Needed)
Connect directly to the hosted version — zero dependencies, nothing to install.
Endpoint: https://mcp.ansvar.eu/law-fi/mcp
| Client | How to Connect |
|---|---|
| Claude.ai | Settings > Connectors > Add Integration > paste URL |
| Claude Code | claude mcp add swedish-law --transport http https://mcp.ansvar.eu/law-fi/mcp |
| Claude Desktop | Add to config (see below) |
| GitHub Copilot | Add to VS Code settings (see below) |
Claude Desktop — add to claude_desktop_config.json:
{
"mcpServers": {
"swedish-law": {
"type": "url",
"url": "https://mcp.ansvar.eu/law-fi/mcp"
}
}
}
GitHub Copilot — add to VS Code settings.json:
{
"github.copilot.chat.mcp.servers": {
"swedish-law": {
"type": "http",
"url": "https://mcp.ansvar.eu/law-fi/mcp"
}
}
}
Use Locally (npm)
npx @ansvar/swedish-law-mcp
Claude Desktop — add to claude_desktop_config.json:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"swedish-law": {
"command": "npx",
"args": ["-y", "@ansvar/swedish-law-mcp"]
}
}
}
Cursor / VS Code:
{
"mcp.servers": {
"swedish-law": {
"command": "npx",
"args": ["-y", "@ansvar/swedish-law-mcp"]
}
}
}
Example Queries
Once connected, just ask naturally:
- "What does Dataskyddslagen 3 kap. 5 § say about consent?"
- "Is PUL (1998:204) still in force?"
- "Find provisions about personuppgifter in Swedish law"
- "What EU directives does DSL implement?"
- "Which Swedish laws implement the GDPR?"
- "Get the preparatory works for Dataskyddslagen"
- "Compare incident reporting requirements across NIS2 Swedish implementations"
- "Validate the citation NJA 2020 s. 45"
- "Find Labour Court cases about discrimination from 2020-2023"
What's Included
| Category | Count | Details |
|---|---|---|
| Statutes | 717 laws | Comprehensive Swedish legislation |
| Provisions | 31,198 sections | Full-text searchable with FTS5 |
| Preparatory Works | 3,625 documents | Propositions (Prop.) and SOUs |
| EU Cross-References | 668 references | 228 EU directives and regulations |
| Legal Definitions | 615 terms | Extracted from statute text |
| Database Size | ~70 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.
See It In Action
Why This Works
Verbatim Source Text (No LLM Processing):
- All statute text is ingested from Riksdagen/SFS official sources
- Provisions are returned unchanged from SQLite FTS5 database rows
- Zero LLM summarization or paraphrasing -- the database contains regulation text, not AI interpretations
Smart Context Management:
- Search returns ranked provisions with BM25 scoring (safe for context)
- Provision retrieval gives exact text by SFS number + chapter/section
- Cross-references help navigate without loading everything at once
Technical Architecture:
Riksdagen API → Parse → SQLite → FTS5 snippet() → MCP response
↑ ↑
Provision parser Verbatim database query
Traditional Research vs. This MCP
| 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.
Available Tools (13)
Core Legal Research Tools (8)
| Tool | Description |
|---|---|
search_legislation | FTS5 search on 31,198 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 |
get_preparatory_works | Get linked propositions and SOUs for a statute |
validate_citation | Validate citation against database (zero-hallucination check) |
build_legal_stance | Aggregate citations from statutes, case law, prep works |
format_citation | Format citations per Swedish conventions (full/short/pinpoint) |
check_currency | Check if statute is in force, amended, or repealed |
EU Law Integration Tools (5)
| 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) |
EU Law Integration
668 cross-references linking 49 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 | 49 (68% of database) |
| Directives | 89 |
| Regulations | 139 |
| EUR-Lex Integration | Automated metadata fetching |
Most Referenced EU Acts
- eIDAS Regulation (910/2014) - 20 references
- E-Signatures Directive (1999/93) - 15 references
- GDPR (2016/679) - 15 references
- Data Protection Directive (1995/46) - 14 references
- Market Surveillance Regulation (2019/1020) - 14 references
See EU_INTEGRATION_GUIDE.md for detailed documentation and EU_USAGE_EXAMPLES.md for practical examples.
Data Sources & Freshness
All content is sourced from authoritative Swedish legal databases:
- Riksdagen -- Swedish Parliament's official legal database
- Svensk Forfattningssamling -- Official statute collection
- Lagen.nu -- Case law database (CC-BY Domstolsverket)
- EUR-Lex -- Official EU law database (metadata only)
Automated Freshness Checks (Daily)
A daily GitHub Actions workflow monitors all data sources:
| Source | Check | Method |
|---|---|---|
| Statute amendments | Riksdagen API date comparison | All 717 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.
Security
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.
Important Disclaimers
Legal Advice
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
Client Confidentiality
Queries go through the Claude API. For privileged or confidential matters, use on-premise deployment. See PRIVACY.md for Advokatsamfundet compliance guidance.
Documentation
- EU Integration Guide -- Detailed EU cross-reference documentation
- EU Usage Examples -- Practical EU lookup examples
- Security Policy -- Vulnerability reporting and scanning details
- Disclaimer -- Legal disclaimers and professional use notices
- Privacy -- Client confidentiality and data handling
Development
Setup
git clone https://github.com/Ansvar-Systems/swedish-law-mcp
cd swedish-law-mcp
npm install
npm run build
npm test
Running Locally
npm run dev # Start MCP server
npx @anthropic/mcp-inspector node dist/index.js # Test with MCP Inspector
Data Management
npm run ingest -- <sfs-number> <output.json> # Ingest statute 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
Performance
- Search Speed: <100ms for most FTS5 queries
- Database Size: ~70 MB (efficient, portable)
- Reliability: 100% ingestion success rate
Related Projects: Complete Compliance Suite
This server is part of Ansvar's Compliance Suite -- MCP servers that work together for end-to-end compliance coverage:
@ansvar/eu-regulations-mcp
Query 49 EU regulations directly from Claude -- GDPR, AI Act, DORA, NIS2, MiFID II, eIDAS, and more. Full regulatory text with article-level search. npx @ansvar/eu-regulations-mcp
@ansvar/swedish-law-mcp (This Project)
Query 717 Swedish statutes directly from Claude -- DSL, BrB, ABL, MB, and more. Full provision text with EU cross-references. npx @ansvar/swedish-law-mcp
@ansvar/us-regulations-mcp
Query US federal and state compliance laws -- HIPAA, CCPA, SOX, GLBA, FERPA, and more. npm install @ansvar/us-regulations-mcp
@ansvar/ot-security-mcp
Query IEC 62443, NIST 800-82/53, and MITRE ATT&CK for ICS -- Specialized for OT/ICS environments. npx @ansvar/ot-security-mcp
@ansvar/automotive-cybersecurity-mcp
Query UNECE R155/R156 and ISO 21434 -- Automotive cybersecurity compliance. npx @ansvar/automotive-cybersecurity-mcp
@ansvar/sanctions-mcp
Offline-capable sanctions screening -- OFAC, EU, UN sanctions lists. pip install ansvar-sanctions-mcp
Contributing
Contributions welcome! See CONTRIBUTING.md for guidelines.
Priority areas:
- Court case law expansion (currently limited coverage)
- EU Regulations MCP integration (full EU law text, CJEU case law)
- Historical statute versions and amendment tracking
- Lower court decisions (Tingsrätt, Hovrätt)
Roadmap
- Statute expansion -- 785% growth from 81 to 717 statutes (v1.1.0)
- EU law integration -- 668 cross-references to 228 EU directives/regulations (v1.1.0)
- Court case law expansion (scraper updated, re-ingestion needed for 12K-18K cases)
- Full EU text integration (via @ansvar/eu-regulations-mcp)
- Lower court coverage (Tingsrätt, Hovrätt archives)
- Historical statute versions (amendment tracking)
- English translations for key statutes
- Web API for programmatic access
Citation
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 717 statutes and EU law cross-references}
}
License
Apache License 2.0. See LICENSE for details.
Data Licenses
- Statutes & Propositions: Swedish Government (public domain)
- Case Law: CC-BY Domstolsverket (via lagen.nu)
- EU Metadata: EUR-Lex (EU public domain)
About Ansvar Systems
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 717 statutes shouldn't require a law degree.
ansvar.eu -- Stockholm, Sweden
<p align="center"> <sub>Built with care in Stockholm, Sweden</sub> </p>
常见问题
eu.ansvar/finnish-law-mcp 是什么?
可通过Finlex查询芬兰法令,并查看EU交叉引用、判例及立法准备材料。
相关 Skills
面试体系设计
by alirezarezvani
按岗位、级别和团队设计面试流程,生成能力矩阵、题库与评分标准,分析面试官偏差并校准招聘门槛,适合搭建或优化企业招聘体系。
✎ 团队招人没章法时,用它快速搭建岗位化面试流程、题库与评分标准,还能兼顾校准面试偏差,招聘更稳更准。
交易代理重建工具
by canonxu
当且仅当用户明确提出“重新构建tradeagents”或类似高度相关指令时触发。主要功能为在 ~/TradingAgents 目录下重新创建并激活 Python 虚拟环境,安装包及依赖,最后总结修改并推送到远程仓库。
判例参考
by BytesAgain
Legal precedent reference — stare decisis, case law hierarchy, distinguishing, overruling, persuasive authority. Use when researching binding case law, analyzing judicial reasoning, or building legal arguments.
相关 MCP Server
by boosted-chat
Flight search & booking for AI agents. 400+ airlines, $20-50 cheaper than OTAs.
by jjlabsio
Search company disclosures and financial statements from the Korean market. Retrieve stock profiles, market classifications, and historical trading data across major exchanges. Accelerate equity research with accurate, date-specific insights for Korean securities.
✎ 做韩国股研时,用它能一站查公司披露、财报和历史行情,按日期精确追溯关键信息,比手动翻交易所高效太多。
by jjlabsio
检索韩国市场公司的披露文件与财务报表,并获取股票概况等关键信息。
✎ 想研究韩股公司时,它能一站式拉取披露、财报和股票概况,省去跨站查资料的麻烦,对跨境投研尤其省时。