dimetrics-mcp-server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@dimetrics-mcp-serverlist all apps"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Dimetrics, Werkportal & PPMC MCP Server - Multi-API Integration
Ein Model Context Protocol (MCP) Server der Dimetrics, Werkportal und PPMC APIs unterstützt.
🎯 Services
Dimetrics MCP Server
Port: 5201
Container: dimetrics-mcp-server
Werkportal MCP Server
Port: 5202
Container: werkportal-mcp-server
PPMC MCP Server
Port: 5203
Container: ppmc-mcp-server
Related MCP server: Dialpad Universal MCP Server
🚀 Verwendung
# Alle Services starten
docker-compose up -d
# Einzelne Services
docker-compose up -d dimetrics-mcp-server
docker-compose up -d werkportal-mcp-server
docker-compose up -d ppmc-mcp-server
# Kombinationen
docker-compose up -d dimetrics-mcp-server werkportal-mcp-serverDimetrics MCP Server - Vollständige API-Integration
Ein Model Context Protocol (MCP) Server basierend auf dem offiziellen FastMCP Python SDK, der eine vollständige Integration mit der Dimetrics Web-API bietet. Ermöglicht GitHub Copilot die natürlichsprachige Verwaltung von Apps, Services, Resources, Attributen und echten Daten.
✨ Features
🏗️ App Management: Vollständiges CRUD für Apps
⚙️ Service Management: Vollständiges CRUD für Services mit App-Verknüpfung
📊 Resource Management: Vollständiges CRUD für Resources mit Service-Verknüpfung
🔧 Attribute Management: Vollständiges CRUD für Attribute mit 25+ unterstützten Typen
💾 Generics API (Data CRUD): Vollständiges CRUD für echte Daten in Resources
🔍 Erweiterte Abfragen: Directus-ähnliche Filter, Aggregationen, Volltext-Suche
🚀 FastMCP Integration: Basiert auf dem offiziellen MCP Python SDK
🔑 Flexible Authentifizierung: Token-basierte API-Authentifizierung
📋 Natürlichsprachliche Steuerung: GitHub Copilot Integration
🛠️ Verfügbare Tools (35 Tools)
📱 App Management
Tool | Beschreibung | Parameter |
| Erstellt eine neue App |
|
| Listet alle Apps auf |
|
| Holt App-Details |
|
| Aktualisiert eine App |
|
| Löscht eine App |
|
📂 Category Management
Tool | Beschreibung | Parameter |
| Erstellt eine neue Category |
|
| Listet alle Categories auf |
|
| Holt Category-Details |
|
| Aktualisiert eine Category |
|
| Löscht eine Category |
|
⚙️ Service Management
Tool | Beschreibung | Parameter |
| Erstellt einen neuen Service |
|
| Listet alle Services auf |
|
| Holt Service-Details |
|
| Aktualisiert einen Service |
|
| Löscht einen Service |
|
📊 Resource Management
Tool | Beschreibung | Parameter |
| Erstellt eine neue Resource |
|
| Listet alle Resources auf |
|
| Holt Resource-Details |
|
| Aktualisiert eine Resource |
|
| Löscht eine Resource |
|
🔧 Attribute Management
Tool | Beschreibung | Parameter |
| Listet Attribute einer Resource |
|
| Holt Attribut-Details |
|
| Erstellt ein neues Attribut |
|
| Aktualisiert ein Attribut |
|
| Löscht ein Attribut |
|
| Erstellt mehrere Attribute |
|
💾 Generics API (Data CRUD)
Tool | Beschreibung | Parameter |
| Listet Einträge mit Filter/Aggregation |
|
| Erstellt einen neuen Eintrag |
|
| Holt einen spezifischen Eintrag |
|
| Aktualisiert einen Eintrag (PATCH) |
|
| Löscht einen Eintrag |
|
🎯 Erweiterte Features
Directus-ähnliche Filter
# Beispiele für directus_filter_json
'{"state": {"_eq": "ok"}}' # Gleichheit
'{"amount": {"_gte": 10}}' # Größer gleich
'{"name": {"_contains": "Marathon"}}' # Textsuche
'{"_and": [{"state": {"_eq": "ok"}}, {"amount": {"_gte": 25}}]}' # UND-VerknüpfungAggregationen
# Beispiele für aggregate_json
'{"sum": "amount"}' # Summe
'{"count": "name"}' # Anzahl
'{"avg": "distance_km"}' # Durchschnitt
'{"sum": "amount", "count": "name", "avg": "amount"}' # Mehrere gleichzeitigVolltext-Suche
# search Parameter
search="Marathon" # Sucht in allen Textfeldern
search="Dauerlauf" # Findet passende Einträge🚀 Schnellstart
1. Installation
# Abhängigkeiten installieren
pip install -r requirements.txt2. Konfiguration
# .env Datei erstellen
cp .env.example .env
# API-Zugangsdaten eintragen
DIMETRICS_API_URL=https://dimetrics.api.nc.released.services/api
DIMETRICS_API_KEY=your_token_here3. Tests
# Grundfunktionalität testen
python3 test_minimal_new.py
# CRUD-Operationen testen
python3 test_generics_crud.py
# MCP-Tools testen
python3 test_mcp_generics_crud.py
# Aggregationen und Filter testen
python3 test_aggregations.py
python3 test_directus_filters.py4. MCP Server starten
# Server starten
python3 -m dimetrics_mcp_server
# Mit uv (falls installiert)
uv run mcp dev dimetrics_mcp_server/__main__.py5. GitHub Copilot Integration
{
"mcpServers": {
"dimetrics": {
"command": "python3",
"args": ["-m", "dimetrics_mcp_server"],
"cwd": "/path/to/dimetrics-mcp-server",
"env": {
"DIMETRICS_API_URL": "https://dimetrics.api.nc.released.services/api",
"DIMETRICS_API_KEY": "your_token_here"
}
}
}
}📈 Projekt-Status
✅ Vollständig Implementiert
Apps Management: Alle CRUD-Operationen funktional
Categories Management: Alle CRUD-Operationen funktional
Services Management: Alle CRUD-Operationen funktional
Resources Management: Alle CRUD-Operationen funktional
Attributes Management: Alle CRUD-Operationen funktional
Generics API: Vollständiges CRUD mit erweiterten Features
Filter-System: Directus-kompatible Filter
Aggregationen: Sum, Count, Average und mehr
Volltext-Suche: Durchsuchung aller Textfelder
🎯 Erfolgreiche Test-Implementierung
Das System wurde mit einer vollständigen Lauftagebuch-App getestet:
App: Lauftagebuch
├── Service: Laufaktivitäten
└── Resource: Läufe
├── name (INPUT_FIELD)
├── state (DROPDOWN_FIELD)
├── distance_km (NUMERIC_FIELD)
├── duration_minutes (NUMERIC_FIELD)
├── date_created (TIMESTAMP_FIELD)
├── notes (TEXT_FIELD)
├── weather (DROPDOWN_FIELD)
└── amount (NUMERIC_FIELD)Erfolgreiche CRUD-Tests:
✅ Erstellung von Einträgen mit allen Attributen
✅ Filtern nach Status, Distanz, Datum
✅ Aggregationen (Summe der Distanzen, Durchschnitt, etc.)
✅ Updates von Einträgen (PATCH)
✅ Sichere Löschung mit Bestätigung
✅ Volltext-Suche in Namen und Notizen
📚 Dokumentation
GENERICS_CRUD.md: Vollständige CRUD-Dokumentation mit Beispielen
AGGREGATIONS_SEARCH.md: Filter, Aggregationen und Suche
DIRECTUS_FILTERS.md: Directus-Filter Referenz
Lauftagebuch_Documentation.md: Test-App Dokumentation
🔧 Technische Details
Architektur
FastMCP: Offizieller MCP Python SDK
httpx: Asynchroner HTTP Client für API-Kommunikation
pydantic: Datenvalidierung und -serialisierung
python-dotenv: Umgebungsvariablen Management
API-Endpunkte
Apps:
/api/apps/Categories:
/api/categories/Services:
/api/services/Resources:
/api/resources/Attributes:
/api/attributes/{resource_name}/Generics:
/api/generics/{resource_name}/
Authentifizierung
headers = {
"Authorization": f"Token {api_key}",
"Content-Type": "application/json"
}🤝 Verwendung mit GitHub Copilot
Beispiel-Prompts
# App-Verwaltung
"Erstelle eine App namens 'Projektmanagement'"
"Liste alle Apps auf"
"Lösche die App mit ID abc-123"
# Service-Verwaltung
"Erstelle einen Service 'Tasks' in der App 'Projektmanagement'"
"Aktualisiere den Service-Titel zu 'Aufgaben'"
# Resource-Verwaltung
"Erstelle eine Resource 'Tickets' im Service 'Tasks'"
"Liste alle Resources auf"
# Daten-Management
"Erstelle einen neuen Laufeintrag mit 5km Distanz"
"Zeige alle Läufe über 10km"
"Berechne die Gesamtdistanz aller Läufe"
"Lösche den Eintrag mit ID xyz-789"🚨 Wichtige Hinweise
Sicherheitsfeatures
Lösch-Bestätigung: Alle DELETE-Operationen erfordern explizite Bestätigung
Datenvalidierung: Vollständige Validierung aller Ein- und Ausgaben
Fehlerbehandlung: Umfassende Fehlerbehandlung mit aussagekräftigen Meldungen
Bekannte Einschränkungen
Attribut-Details (
get_attribute_details): API-Berechtigungsproblem (403 Forbidden)Namens-Validierung: Dimetrics API lehnt lange Namen mit Underscores ab
Prefix-Limite: Maximal 5 Zeichen für automatisch generierte Prefixes
Status: 🟢 Production Ready - Vollständige API-Integration mit 35 funktionalen Tools
4. Server starten
# MCP Server starten
python3 -m dimetrics_mcp_server🔧 GitHub Copilot Integration
Fügen Sie diese Konfiguration zu Ihrem MCP Client hinzu:
{
"mcpServers": {
"dimetrics": {
"command": "python3",
"args": ["-m", "dimetrics_mcp_server"],
"cwd": "/path/to/mcp-server",
"env": {
"DIMETRICS_API_URL": "https://dimetrics.api.nc.released.services/api",
"DIMETRICS_API_KEY": "your_token_here"
}
}
}
}💬 Beispiel-Anweisungen
"Erstelle eine App namens 'Stromverträge' mit dem Prefix 'power_'"
"Liste alle Apps auf, die 'MCP' enthalten"
"Zeige mir die Details der App mit ID xyz"
"Lösche die App mit der ID xyz"🏗️ API Struktur
Der Server interagiert mit folgenden Dimetrics API Endpunkten:
# App erstellen
POST /apps/
{
"name": "App Name",
"title": "App Name",
"prefix": "app_",
"description": "Beschreibung"
}
# Apps auflisten
GET /apps/?search=suchbegriff
# App Details
GET /apps/{object_id}
# App löschen
DELETE /apps/{object_id}/🧪 Entwicklung
Tests ausführen
# Minimaler Test (ohne API)
python3 test_minimal_new.py
# Vollständiger API Test
python3 test_dimetrics_api.pyNeue Tools hinzufügen
Erweitern Sie
api_client.pyfür neue API-EndpunkteFügen Sie neue
@mcp.tool()Funktionen in__main__.pyhinzuTesten Sie mit den Testskripten
� Basiert auf
📝 Nächste Schritte
Dieses minimale Beispiel kann schrittweise erweitert werden um:
📊 Tabellen Management (create_table, list_tables)
🔧 Attribut Management (create_attribute, list_attributes)
💾 Daten Management (CRUD-Operationen)
🎯 Erweiterte Features (Bulk-Operationen, Templates)
🎯 Status: Minimal-Implementation abgeschlossen
✅ App Management funktionsfähig
🔧 Bereit für schrittweise Erweiterung
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/fellnerd/dimetrics-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server