Berlin Services MCP Server
Enables comprehensive search and browsing of Berlin city services. Also supports PDF form discovery, analysis, and filling with resilient caching.
README
Berlin Services MCP Server - Enhanced
A production-grade Model Context Protocol (MCP) server for Berlin city services (Dienstleistungen). It features resilient caching, advanced search, PDF form discovery, and filling capabilities.
Features
- Comprehensive Tools: Search, browse, and get detailed information on Berlin services.
- Form Management: Discover, analyze, and fill PDF forms for various services.
- Resilient Caching: Optimized for performance with intelligent fallback for offline use.
- Remote Sync: Supports both local and remote (Cloud) deployments.
Technical Architecture
1. Data Sourcing
The server pulls data from the official Berlin City Services API
- Live Fetching: Tools like
search_servicesandget_service_detailshit the live API. - Resilient Caching: Implements a dual-layer cache (Memory + Disk) to ensure high performance and offline reliability.
- Smart Fallback: If the API is down and no cache exists, it falls back to a minimal set of core services to remain functional.
2. Advanced PDF Processing
Powered by PyMuPDF (fitz), the server provides sophisticated document handling:
- Field Extraction: Automatically detects fillable fields in PDF forms hosted on the city's servers.
- Intelligent Filling: Maps user data to PDF fields using smart matching and common translation fragments.
- Loop Protection: Includes a
LoopProtectorto prevent redundant tool executions and LLM loops. - Visual Previews: Can render specific pages of a PDF to JPEG for a quick in-chat snapshot (useful for verification without leaving the chat).
3. Deployment Modes
- Local Mode: Optimized for use with Claude Desktop. In this mode,
open_file_locallycan be used to open filled PDFs directly with your system's default viewer. - Remote/Cloud Mode: Designed for deployment on platforms like Fly.io or Railway. Replaces local file opening with secure synchronization and in-chat previews.
Prerequisites
- Python 3.11 or higher
uv(recommended) orpip
Local Setup
Using uv (Recommended)
- Install dependencies and sync the environment:
uv sync - Run the server as a module:
Note: If you've installed the package viaexport PYTHONPATH=$PYTHONPATH:$(pwd)/src && uv run python -m berlin_mcp.mainuv sync, you can also just run:uv run berlin-mcp
Using pip
- Install dependencies:
pip install -r requirements.txt - Run the server:
export PYTHONPATH=$PYTHONPATH:$(pwd)/src && python -m berlin_mcp.main
Claude Desktop Configuration
Add the following to your Claude Desktop configuration file. Replace /Users/mananshah/Desktop/Berlin-Services-MCP-Server with the actual absolute path to the folder.
macOS
File location: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"berlin-services": {
"command": "uv",
"args": [
"run",
"--directory",
"/Users/YourUser/Desktop/Berlin-Services-MCP-Server",
"python",
"-m",
"berlin_mcp.main"
],
"env": {
"PYTHONPATH": "src"
}
}
}
}
Windows
File location: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"berlin-services": {
"command": "uv",
"args": [
"run",
"--directory",
"C:\\Users\\YourUser\\Desktop\\Berlin-Services-MCP-Server",
"python",
"-m",
"berlin_mcp.main"
],
"env": {
"PYTHONPATH": "src"
}
}
}
}
Tools and Resources
The server exposes the following tools to help you navigate and manage Berlin city services:
| Tool | Description |
|---|---|
search_services |
Advanced search for Berlin services with paging and filters. |
get_service_details |
Get complete details about a service including forms and prerequisites. |
get_service_forms |
Get all forms associated with a service with detailed metadata. |
search_forms |
Search for forms across all services. |
get_forms_by_type |
Get all forms of a specific type across services. |
get_service_prerequisites |
Get all prerequisites and requirements for a service. |
get_service_checklist |
Get a comprehensive checklist for completing a service application. |
analyze_form_for_filling |
Download a PDF form and extract its fillable fields. |
perform_form_filling |
Fill a PDF form and save locally. |
download_filled_form |
Retrieve a filled PDF form. |
get_form_visual_preview |
Render a page of a filled PDF as an image. |
open_file_locally |
Open a file on the user's local system (Local setup only). |
delete_filled_form |
Manually delete a filled form from the server. |
browse_services_by_category |
Browse services by category. |
find_online_services |
Find all services available online. |
get_service_locations |
Get all locations for a service. |
get_api_status |
Get API and cache status diagnostics. |
clear_cache |
Clear the service cache and force refresh. |
Security Note
PDF forms filled on remote servers should be downloaded and then deleted using the delete_filled_form tool to ensure data privacy.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.