# Swedish Law Mcp

> Query 717 Swedish statutes, EU cross-references, case law, and preparatory works

- **Type:** MCP server
- **Install:** `agentstack add mcp-ansvar-systems-swedish-law-mcp`
- **Verified:** Yes — security-reviewed for prompt injection and unsafe behavior
- **Seller:** [Ansvar-Systems](https://agentstack.voostack.com/s/ansvar-systems)
- **Installs:** 0
- **Category:** [Integrations](https://agentstack.voostack.com/c/integrations)
- **Latest version:** 1.2.1
- **License:** Apache-2.0
- **Upstream author:** [Ansvar-Systems](https://github.com/Ansvar-Systems)
- **Source:** https://github.com/Ansvar-Systems/Swedish-law-mcp
- **Website:** https://swedish-law-mcp.vercel.app

## Install

```sh
agentstack add mcp-ansvar-systems-swedish-law-mcp
```

Requires the [AgentStack CLI](https://agentstack.voostack.com/docs/cli). Works with Claude Code, Cursor, and any MCP-compatible agent.

## About

# Swedish Law MCP Server

> ### ▶ Try this MCP instantly via Ansvar Gateway
> **50 free queries/day · no card required · OAuth signup at [ansvar.eu/gateway](https://ansvar.eu/gateway)**
>
> One endpoint, one OAuth signup, access from any MCP-compatible client.

### Connect

**Claude Code** (one line):

```bash
claude mcp add ansvar --transport http https://gateway.ansvar.eu/mcp
```

**Claude Desktop / Cursor** — add to `claude_desktop_config.json` (or `mcp.json`):

```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](https://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.

---

## Self-host this MCP

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.**

[](https://registry.modelcontextprotocol.io)
[](https://opensource.org/licenses/Apache-2.0)
[](https://github.com/Ansvar-Systems/swedish-law-mcp)
[](https://github.com/Ansvar-Systems/swedish-law-mcp/actions/workflows/ci.yml)
[](https://github.com/Ansvar-Systems/swedish-law-mcp/actions/workflows/check-updates.yml)
[](docs/EU_INTEGRATION_GUIDE.md)
[](docs/EU_INTEGRATION_GUIDE.md)

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](https://ansvar.eu) -- Stockholm, Sweden

---

## 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 Locally (npm — recommended)

**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:**

### Hosted via Ansvar Gateway (B2B, OAuth)

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](https://gateway.ansvar.eu) — a single MCP endpoint that routes and fans out across the full catalogue. Tier-gated (`premium`, `team`, `company`); requires an Ansvar account.

## 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** | 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.

---

## 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 (18)

See [TOOLS.md](TOOLS.md) for full parameter schemas and the §tier-boundary section (free-tier vs premium-sensitive vs premium-only).

### Core Legal Research Tools (8)

| 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 |

### 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) |

### Versioning Tools (3, premium-only)

| 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 |

### Server Metadata Tools (2)

| Tool | Description |
|------|-------------|
| `list_sources` | Data provenance metadata per source |
| `about` | Server stats, freshness, build date, tier, dataset summary |

---

## EU Law Integration

**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 |

### Most Referenced EU Acts

1. **eIDAS Regulation** (910/2014) - 20 references
2. **E-Signatures Directive** (1999/93) - 15 references
3. **GDPR** (2016/679) - 15 references
4. **Data Protection Directive** (1995/46) - 14 references
5. **Market Surveillance Regulation** (2019/1020) - 14 references

See [EU_INTEGRATION_GUIDE.md](docs/EU_INTEGRATION_GUIDE.md) for detailed documentation and [EU_USAGE_EXAMPLES.md](docs/EU_USAGE_EXAMPLES.md) for practical examples.

---

## Data Sources & Freshness

All content is sourced from authoritative Swedish legal databases:

- **[Riksdagen](https://riksdagen.se/)** -- Swedish Parliament's official legal database
- **[Svensk Forfattningssamling](https://svenskforfattningssamling.se/)** -- Official statute collection
- **[Lagen.nu](https://lagen.nu)** -- Case law database (CC-BY Domstolsverket)
- **[EUR-Lex](https://eur-lex.europa.eu/)** -- Official EU law database (metadata only)

### Automated Freshness Checks (Daily)

A [daily GitHub Actions workflow](.github/workflows/check-updates.yml) 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.

---

## 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](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](DISCLAIMER.md) | [PRIVACY.md](PRIVACY.md)

### Client Confidentiality

Queries go through the Claude API. For privileged or confidential matters, use on-premise deployment. See [PRIVACY.md](PRIVACY.md) for Advokatsamfundet compliance guidance.

---

## Documentation

- **[EU Integration Guide](docs/EU_INTEGRATION_GUIDE.md)** -- Detailed EU cross-reference documentation
- **[EU Usage Examples](docs/EU_USAGE_EXAMPLES.md)** -- Practical EU lookup examples
- **[Security Policy](SECURITY.md)** -- Vulnerability reporting and scanning details
- **[Disclaimer](DISCLAIMER.md)** -- Legal disclaimers and professional use notices
- **[Privacy](PRIVACY.md)** -- Client confidentiality and data handling

---

## Development

### Branching Strategy

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.
- Feature branches are created from `dev`.

### Setup

```bash
git clone https://github.com/Ansvar-Systems/swedish-law-mcp
cd swedish-law-mcp
npm install
npm run build
npm test
```

### Running Locally

```bash
npm run dev                                       # Start MCP server
npx @anthropic/mcp-inspector node dist/index.js   # Test with MCP Inspector
```

### Data Management

```bash
npm run ingest --     # 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
```

### Performance

- **Search Speed:** 
  Built with care in Stockholm, Sweden

## Source & license

This open-source MCP server is cataloged on AgentStack and links to its original source — we do not rehost the code.

- **Author:** [Ansvar-Systems](https://github.com/Ansvar-Systems)
- **Source:** [Ansvar-Systems/Swedish-law-mcp](https://github.com/Ansvar-Systems/Swedish-law-mcp)
- **License:** Apache-2.0
- **Homepage:** https://swedish-law-mcp.vercel.app

Install and usage instructions live in the source repository linked above.

## Pricing

- **Free** — Free

## Versions

- **1.2.1** — security scan: passed — Imported from the upstream source.

## Links

- Listing page: https://agentstack.voostack.com/l/mcp-ansvar-systems-swedish-law-mcp
- Seller: https://agentstack.voostack.com/s/ansvar-systems
- Browse the marketplace: https://agentstack.voostack.com/browse

---
Listed on AgentStack — the marketplace for AI agent skills and MCP servers. Every listing is security-reviewed. Creators keep 70%.
