Skolverket-MCP

mcp
Security Audit
Fail
Health Pass
  • License — License: MIT
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Community trust — 10 GitHub stars
Code Fail
  • network request — Outbound network request in package.json
  • execSync — Synchronous shell command execution in scripts/update-api-types.ts
  • network request — Outbound network request in src/api/base-client.ts
Permissions Pass
  • Permissions — No dangerous permissions requested
Purpose
This is an MCP server that provides AI assistants with access to the Swedish National Agency for Education's (Skolverket) open data APIs. It allows LLMs to seamlessly query, parse, and integrate public educational data, statistics, and school registries.

Security Assessment
The overall risk is Low, though developers should be aware of a few minor code quality details. The server does not request dangerous system permissions or contain hardcoded secrets. Because it is an API wrapper, it naturally makes outbound network requests (located in `src/api/base-client.ts` and `package.json`) to fetch the public Skolverket data. A notable finding is the use of synchronous shell execution (`execSync`) inside `scripts/update-api-types.ts`. While this is standard practice for running local development scripts and building API types, it is important to ensure this script is never inadvertently triggered in a production environment. The server does not access local sensitive data.

Quality Assessment
The project appears to be well-maintained and actively developed, with repository activity as recent as today. It is fully open-source under the standard MIT license, which is highly permissive and safe for integration. Community trust is currently budding; the repository has 10 GitHub stars, indicating it is an early-stage project that has not yet seen widespread community auditing.

Verdict
Safe to use — it is a straightforward, permissively licensed API wrapper, though standard caution applies due to its early-stage community adoption.
SUMMARY

MCP server for Swedish National Agency for Education (Skolverket) open data. Tuned for LLMs to query, parse, and integrate info, data, and stats from three public API endpoints.

README.md
Skolverket MCP logo

Skolverket MCP Server

MCP Registry
MCP Protocol
License

En Model Context Protocol (MCP) server som ger AI-assistenter tillgång till alla Skolverkets öppna API:er – Läroplan API, Skolenhetsregistret och Planned Educations API. Genom att ansluta till MCP-servern kan du med hjälp av AI söka, hitta, jämföra och analysera all data och statistik som finns tillgängligt i Skolverkets öppna databaser.


Snabbstart

Installera lokalt enligt guide nedan. Servern körs via stdio-transport och integreras sedan i din MCP-klient (Claude Desktop, Claude Code, Codex, Gemini, Cursor m.fl.).

Installation från källkod

git clone https://github.com/isakskogstad/Skolverket-MCP.git
cd Skolverket-MCP
npm install
npm run build

Notera sökvägen till dist/index.js — den används i klientkonfigurationerna nedan.

Klientkonfiguration Claude Desktop
  1. I Claude Desktop: Settings → Developer (inte Connectors!)
  2. Klicka "Edit Config"
  3. Lägg till i JSON-filen:
{
  "mcpServers": {
    "skolverket": {
      "command": "node",
      "args": ["/absolut/sökväg/till/Skolverket-MCP/dist/index.js"]
    }
  }
}
  1. Spara och starta om Claude Desktop.

Notera: Lokal installation använder stdio-transport via Developer-sektionen, inte Connectors.

Claude Code
claude mcp add skolverket node /absolut/sökväg/till/Skolverket-MCP/dist/index.js

Verifiera: claude mcp list

OpenAI Codex

~/.codex/config.toml:

[mcp.skolverket]
command = "node"
args = ["/absolut/sökväg/till/Skolverket-MCP/dist/index.js"]
transport = "stdio"

Windows:

[mcp.skolverket]
command = "node"
args = ["C:\\Users\\username\\Skolverket-MCP\\dist\\index.js"]
transport = "stdio"
Google Gemini / Cursor / övriga stdio-klienter

Använd samma mönster — peka klienten på node med argumentet /absolut/sökväg/till/Skolverket-MCP/dist/index.js och transport stdio.

{
  "mcpServers": {
    "skolverket": {
      "command": "node",
      "args": ["/absolut/sökväg/till/Skolverket-MCP/dist/index.js"]
    }
  }
}
claudecode openaicodex googlegemini

Funktioner

Servern kopplar till tre av Skolverkets öppna API:er:

1. Syllabus API
Läroplaner (LGR22, GY25 m.m.), ämnen, kurser, gymnasieprogram med kunskapskrav och centralt innehåll.

2. Skolenhetsregistret
Sök och filtrera skolor, förskolor och andra skolenheter. Inkluderar aktiva, nedlagda och vilande enheter.

3. Planned Educations API
Yrkeshögskola, SFI, Komvux och andra vuxenutbildningar med startdatum, platser och studietakt.

Verktyg (tools)

MCP-servern implementerar MCP-protokollet med stöd för:

  • 41 verktyg – 17 Syllabus API, 4 School Units, 17 Planned Educations (inkl. gymnasieutbildningar, statistik, dokument), 3 Support Data, 1 diagnostik
  • 4 resurser – API-info, skoltyper, läroplanstyper, kurs- och ämneskoder
  • 5 promptmallar – Kursanalys, versionsjämförelser, vuxenutbildning, studievägledning, kursplanering

Användningsområden

För Lärare

  • Kursplanering: "Jämför kunskapskraven E och A för Svenska 1 och ge förslag på bedömningsuppgifter"
  • Tematiskt arbete: "Hitta alla kurser i gymnasiet som har hållbarhet i sitt centrala innehåll"
  • Bedömning: "Visa alla kunskapskrav för betyg C i Biologi 1 och förklara skillnaderna mot B"

För elever & föräldrar

  • Programval: "Jämför Naturvetenskapsprogrammet och Teknikprogrammet - vilka kurser är obligatoriska?"
  • Kursval: "Vilka matematikkurser finns på gymnasiet och vilka bygger på varandra?"
  • Betygskriterier: "Vad krävs för att få A i Historia 1a1?"

För undersökningar & analyser

  • Skolregister: "Hitta alla aktiva gymnasieskolor i Stockholms län"
  • Kursutbud: "Vilka skolor erbjuder Ekonomiprogrammet i Malmö?"
  • Läroplansanalys: "Analysera hur begreppet 'programmering' har utvecklats i läroplaner 2011-2025"

https://github.com/user-attachments/assets/8eefa26c-4162-49a5-adf0-82677a663b19


Övrigt

Skapad av: Isak SkogstadX/Twitter

Data från Skolverkets öppna API:er.

Villkor: Fri användning


Reviews (0)

No results found