ATLAS: Aufgabenmanagementsystem
ATLAS (Adaptive Task & Logic Automation System) ist ein Projekt-, Wissens- und Aufgabenmanagementsystem für LLM-Agenten.
Basiert auf einer dreistufigen Architektur:
ATLAS wird als Model Context Protocol (MCP)-Server implementiert und ermöglicht LLM-Agenten die Interaktion mit einer Projektmanagementdatenbank, sodass sie Projekte, Aufgaben und Wissenselemente verwalten können.
Wichtiger Versionshinweis : Version 1.5.4 ist die letzte Version, die SQLite als Datenbank verwendet. Ab Version 2.0 wurde die Verwendung von Neo4j vollständig neu geschrieben. Dies erfordert entweder:
Selbsthosting mit Docker (Docker-Compose im Repository enthalten)
Verwenden des Neo4j AuraDB-Clouddienstes: https://neo4j.com/product/auradb/
Version 2.5.0 führt ein neues 3-Knoten-System (Projekte, Aufgaben, Wissen) ein, das die vorherige Struktur ersetzt.
Inhaltsverzeichnis
Related MCP server: Apollo.io MCP Server
Überblick
ATLAS implementiert das Model Context Protocol (MCP) und ermöglicht so eine standardisierte Kommunikation zwischen LLMs und externen Systemen durch:
Clients : Claude Desktop, IDEs und andere MCP-kompatible Clients
Server : Tools und Ressourcen für Projekt-, Aufgaben- und Wissensmanagement
LLM-Agenten : KI-Modelle, die die Verwaltungsfunktionen des Servers nutzen
Systemintegration
Die Atlas-Plattform integriert diese Komponenten in ein zusammenhängendes System:
Projekt-Aufgaben-Beziehung : Projekte enthalten Aufgaben, die die notwendigen Schritte zum Erreichen der Projektziele darstellen. Aufgaben übernehmen den Kontext ihres übergeordneten Projekts und ermöglichen gleichzeitig eine detaillierte Nachverfolgung einzelner Arbeitselemente.
Wissensintegration : Sowohl Projekte als auch Aufgaben können mit Wissenselementen angereichert werden, wodurch Teammitglieder mit den erforderlichen Informationen und dem Kontext versorgt werden.
Abhängigkeitsverwaltung : Sowohl Projekte als auch Aufgaben unterstützen Abhängigkeitsbeziehungen und ermöglichen so komplexe Arbeitsabläufe mit Voraussetzungen und Anforderungen an die sequenzielle Ausführung.
Einheitliche Suche : Die Plattform bietet entitätsübergreifende Suchfunktionen, mit denen Benutzer relevante Projekte, Aufgaben oder Kenntnisse anhand verschiedener Kriterien finden können.
Merkmale
Projektmanagement
Umfassende Nachverfolgung: Verwalten Sie Projektmetadaten, Status und umfangreiche Inhalte (Notizen, Links usw.) mit integrierter Unterstützung für Massenvorgänge.
Handhabung von Abhängigkeiten und Beziehungen: Automatische Validierung und Verfolgung von Abhängigkeiten zwischen Projekten.
Aufgabenverwaltung
Aufgaben-Lebenszyklus-Management: Erstellen, verfolgen und aktualisieren Sie Aufgaben während ihres gesamten Lebenszyklus.
Priorisierung und Kategorisierung: Weisen Sie Prioritätsstufen zu und kategorisieren Sie Aufgaben mit Tags für eine bessere Organisation.
Abhängigkeitsverfolgung: Legen Sie Aufgabenabhängigkeiten fest, um strukturierte Arbeitsabläufe zu erstellen.
Wissensmanagement
Strukturiertes Wissensrepository: Pflegen Sie ein durchsuchbares Repository mit projektbezogenen Informationen.
Domänenkategorisierung: Organisieren Sie Wissen nach Domänen und Tags, um es leicht wiederzufinden.
Zitatunterstützung: Verfolgen Sie Quellen und Referenzen für Wissenselemente.
Graphdatenbankintegration
Natives Beziehungsmanagement: Nutzen Sie die ACID-konformen Transaktionen und optimierten Abfragen von Neo4j für robuste Datenintegrität.
Erweiterte Suche und Skalierbarkeit: Führen Sie eigenschaftsbasierte Suchen mit Fuzzy-Matching und Platzhaltern durch und behalten Sie dabei die hohe Leistung bei.
Einheitliche Suche
Entitätsübergreifende Suche: Finden Sie relevante Projekte, Aufgaben oder Wissen basierend auf Inhalten, Metadaten oder Beziehungen.
Flexible Abfrageoptionen: Unterstützung für Groß- und Kleinschreibung, unscharfe und erweiterte Filteroptionen.
Installation
Klonen Sie das Repository:
git clone https://github.com/cyanheads/atlas-mcp-server.git cd atlas-mcp-serverInstallieren Sie Abhängigkeiten:
npm installNeo4j konfigurieren: Stellen Sie sicher, dass eine Neo4j-Instanz läuft und zugänglich ist. Sie können eine solche mit der bereitgestellten Docker-Konfiguration starten:
docker-compose up -dAktualisieren Sie Ihre
.envDatei mit den Neo4j-Verbindungsdetails (siehe Konfiguration ).Erstellen Sie das Projekt:
npm run build
Ausführen des Servers
Die meisten MCP-Clients führen den Server automatisch aus, Sie können ihn jedoch auch manuell zu Test- oder Entwicklungszwecken mit den folgenden Befehlen ausführen.
ATLAS MCP Server unterstützt mehrere Transportmechanismen für die Kommunikation:
Standard-E/A (stdio): Dies ist der Standardmodus und wird normalerweise für die direkte Integration mit lokalen MCP-Clients (wie IDE-Erweiterungen) verwendet.
npm run start:stdioDies verwendet die Einstellung
MCP_TRANSPORT_TYPE=stdio.Streamable HTTP: Dieser Modus ermöglicht dem Server, auf MCP-Anfragen über HTTP zu warten, geeignet für Remote-Clients oder webbasierte Integrationen.
npm run start:httpDies verwendet die Einstellung
MCP_TRANSPORT_TYPE=http. Der Server überwacht den in Ihrer.envDatei definierten Host und Port (z. B.MCP_HTTP_HOSTundMCP_HTTP_PORT, standardmäßig127.0.0.1:3010). Stellen Sie sicher, dass Ihre Firewall Verbindungen bei Remote-Zugriffen zulässt.
Web-Benutzeroberfläche (experimentell)
Zum Anzeigen von Projekt-, Aufgaben- und Wissensdetails steht eine einfache Web-Benutzeroberfläche zur Verfügung.
Öffnen der Benutzeroberfläche :
Um die Benutzeroberfläche direkt in Ihrem Browser zu öffnen, führen Sie den folgenden Befehl in Ihrem Terminal aus:
npm run webui
Funktionalität :
Einen Beispiel-Screenshot der Web-Benutzeroberfläche können Sie hier sehen.
Konfiguration
Umgebungsvariablen
Umgebungsvariablen sollten in der Clientkonfiguration in Ihrem MCP-Client oder in einer .env Datei im Projektstamm für die lokale Entwicklung festgelegt werden.
Alle verfügbaren Umgebungsvariablen, ihre Beschreibungen und Standardwerte finden Sie in src/config/index.ts .
MCP-Client-Einstellungen
Die Konfiguration Ihres MCP-Clients hängt vom Client selbst und dem gewählten Transporttyp ab. Eine mcp.json Datei im Projektstamm kann von einigen Clients (z. B. mcp-inspector ) zur Definition von Serverkonfigurationen verwendet werden. Aktualisieren Sie diese bei Bedarf.
Für Stdio-Transport (Beispielkonfiguration):
Für Streamable HTTP (Beispielkonfiguration): Wenn Ihr Client die Verbindung zu einem MCP-Server über Streamable HTTP unterstützt, geben Sie den Endpunkt des Servers (z. B. http://localhost:3010/mcp ) in Ihrer Clientkonfiguration an.
Hinweis: Verwenden Sie bei der Konfiguration von Client-Befehlen immer absolute Pfade für args , wenn sich der Server nicht im unmittelbaren Arbeitsverzeichnis des Clients befindet. Der MCP_AUTH_SECRET_KEY im env des Clients dient lediglich der Veranschaulichung; die tatsächliche Token-Verarbeitung für die Client-Server-Kommunikation hängt von den Fähigkeiten des Clients und dem Authentifizierungsmechanismus des Servers ab (z. B. Senden eines JWT in einem Authorization ).
Projektstruktur
Die Codebasis folgt einer modularen Struktur:
Werkzeuge
ATLAS bietet eine umfassende Suite von Tools für Projekt-, Aufgaben- und Wissensmanagement, die über das Model Context Protocol aufrufbar sind.
Projektbetrieb
Werkzeugname | Beschreibung | Hauptargumente |
| Erstellt neue Projekte (einzeln/in großen Mengen). |
(„Einzeln“/„Massen“),
(optionale vom Client generierte ID für Einzelmodus), Projektdetails (
,
,
,
,
,
,
,
). Verwenden Sie für den Massenmodus
(Array von Projektobjekten).
(„formatiert“/„JSON“, optional, Standard: „formatiert“). |
| Listet Projekte auf (alle/Details). |
(„alle“/„Details“, Standard: „alle“),
(für Detailmodus), Filter (
,
), Paginierung (
,
), Includes (
,
),
(„formatiert“/„json“, optional, Standard: „formatiert“). |
| Aktualisiert vorhandene Projekte (einzeln/massenhaft). |
('Einzel'/'Bulk'),
(für Einzelmodus),
. Verwenden Sie für den Bulk-Modus
(Array von Objekten, jedes mit
und
).
('formatiert'/'json', optional, Standard: 'formatiert'). |
| Löscht Projekte (einzeln/in großen Mengen). |
(,Einzel‘/,Bulk‘),
(für Einzelmodus) oder
(Array für Bulk-Modus).
(,formatiert‘/,JSON‘, optional, Standard: ,formatiert‘). |
Aufgabenvorgänge
Werkzeugname | Beschreibung | Hauptargumente |
| Erstellt neue Aufgaben (einzeln/massenweise). |
(„Einzeln“/„Massen“),
(optionale vom Client generierte ID),
, Aufgabendetails (
,
,
,
,
,
,
,
,
,
,
). Verwenden Sie für den Massenmodus
(Array von Aufgabenobjekten).
(„formatiert“/„JSON“, optional, Standard: „formatiert“). |
| Aktualisiert vorhandene Aufgaben (einzeln/massenhaft). |
('single'/'bulk'),
(für Einzelmodus),
. Verwenden Sie für den Massenmodus
(Array von Objekten, jedes mit
und
).
('formatted'/'json', optional, Standard: 'formatted'). |
| Löscht Aufgaben (einzeln/massenweise). |
(,Einzel‘/,Bulk‘),
(für Einzelmodus) oder
(Array für Bulk-Modus).
(,formatiert‘/,JSON‘, optional, Standard: ,formatiert‘). |
| Listet Aufgaben für ein bestimmtes Projekt auf. |
(erforderlich), Filter (
,
,
,
,
), Sortierung (
,
), Paginierung (
,
),
(,formatiert‘/,json‘, optional, Standard: ,formatiert‘). |
Wissensoperationen
Werkzeugname | Beschreibung | Hauptargumente |
| Fügt neue Wissenselemente hinzu (einzeln/in großen Mengen). |
(,Einzel‘/,Bulk‘),
(optionale vom Client generierte ID),
, Wissensdetails (
,
,
,
). Verwenden Sie für den Bulk-Modus „
(Array von Wissensobjekten).
(,formatiert‘/,JSON‘, optional, Standard: ,formatiert‘). |
| Löscht Wissenselemente (einzeln/in großen Mengen). |
(,Einzel‘/,Bulk‘),
(für Einzelmodus) oder
(Array für Bulk-Modus).
(,formatiert‘/,JSON‘, optional, Standard: ,formatiert‘). |
| Listet Wissenselemente für ein bestimmtes Projekt auf. |
(erforderlich), Filter (
,
,
), Paginierung (
,
),
('formatiert'/'json', optional, Standard: 'formatiert'). |
Suchvorgänge
Werkzeugname | Beschreibung | Hauptargumente |
| Führt eine einheitliche Suche über alle Entitäten hinweg durch. |
(Suchbegriff, erforderlich),
(optional: falls angegeben, wird eine Regex-Suche für diese Eigenschaft durchgeführt; falls weggelassen, wird eine Volltextsuche durchgeführt), Filter (
,
,
), Optionen (
(Standard: true, für Regex),
(Standard: false, für Regex „enthält“ oder Volltext-Lucene-Fuzzy)), Paginierung (
,
),
(„formatiert“/„json“, optional, Standard: „formatiert“). |
Forschungsbetrieb
Werkzeugname | Beschreibung | Hauptargumente |
| Initiiert einen strukturierten, gründlichen Forschungsprozess durch die Erstellung eines hierarchischen Plans innerhalb der Atlas-Wissensdatenbank. |
(erforderlich),
(erforderlich),
(erforderlich),
(optional),
(erforderliches Array von Objekten, jedes mit
(erforderlich),
(optionales Array),
(optional),
(optional),
(optional),
(optional, Standard: ‚todo‘)),
(optional),
(optional),
(optional),
(optional, Standard: true),
(‚formatted‘/‚json‘, optional, Standard: ‚formatted‘). |
Datenbankoperationen
Werkzeugname | Beschreibung | Hauptargumente |
| Destruktiv: Setzt die Datenbank vollständig zurück und entfernt alle Projekte, Aufgaben und Kenntnisse. |
(muss zur Bestätigung auf
gesetzt werden, erforderlich),
(„formatiert“/„json“, optional, Standard: „formatiert“). |
Ressourcen
ATLAS stellt Projekt-, Aufgaben- und Wissensdaten über standardmäßige MCP-Ressourcenendpunkte bereit.
Direkte Ressourcen
Ressourcenname | Beschreibung |
| Liste aller Projekte in der Atlas-Plattform mit Paginierungsunterstützung. |
| Liste aller Aufgaben in der Atlas-Plattform mit Unterstützung für Paginierung und Filterung. |
| Liste aller Wissenselemente in der Atlas-Plattform mit Unterstützung für Seitennummerierung und Filterung. |
Ressourcenvorlagen
Ressourcenname | Beschreibung |
| Ruft ein einzelnes Projekt anhand seiner eindeutigen Kennung (
) ab. |
| Ruft eine einzelne Aufgabe anhand ihrer eindeutigen Kennung (
) ab. |
| Ruft alle Aufgaben ab, die zu einem bestimmten Projekt (
) gehören. |
| Ruft ein einzelnes Wissenselement anhand seiner eindeutigen Kennung (
) ab. |
| Ruft alle Wissenselemente ab, die zu einem bestimmten Projekt (
) gehören. |
Datenbanksicherung und -wiederherstellung
ATLAS bietet Funktionen zum Sichern und Wiederherstellen des Neo4j-Datenbankinhalts. Die Kernlogik befindet sich in src/services/neo4j/backupRestoreService.ts .
Backup-Prozess
Mechanismus : Der Sicherungsvorgang exportiert alle
Project,TaskundKnowledgesowie deren Beziehungen in separate JSON-Dateien. Außerdem wird eine Dateifull-export.jsonmit allen Daten erstellt.Ausgabe : Jedes Backup erstellt ein mit einem Zeitstempel versehenes Verzeichnis (z. B.
atlas-backup-YYYYMMDDHHMMSS) innerhalb des konfigurierten Backup-Pfades (Standard:./atlas-backups/). Dieses Verzeichnis enthältprojects.json,tasks.json,knowledge.json,relationships.jsonundfull-export.json.Manuelle Sicherung : Sie können mit dem bereitgestellten Skript eine manuelle Sicherung auslösen:
npm run db:backupDieser Befehl führt
scripts/db-backup.tsaus, wodurch die FunktionexportDatabaseaufgerufen wird.
Wiederherstellungsprozess
Mechanismus : Der Wiederherstellungsprozess löscht zunächst die vorhandene Neo4j-Datenbank vollständig. Anschließend importiert er Knoten und Beziehungen aus den JSON-Dateien im angegebenen Sicherungsverzeichnis. Sofern verfügbar, wird
full-export.jsonpriorisiert.Warnung : Die Wiederherstellung aus einer Sicherung ist ein destruktiver Vorgang. Alle aktuellen Daten in Ihrer Neo4j-Datenbank werden überschrieben.
Manuelle Wiederherstellung : Um die Datenbank aus einem Sicherungsverzeichnis wiederherzustellen, verwenden Sie das Importskript:
npm run db:import <path_to_backup_directory>Ersetzen Sie
<path_to_backup_directory>durch den tatsächlichen Pfad zum Sicherungsordner (z. B../atlas-backups/atlas-backup-20250326120000). Dieser Befehl führtscripts/db-import.tsaus, wodurch die FunktionimportDatabaseaufgerufen wird.Beziehungsbehandlung : Der Importvorgang versucht, Beziehungen basierend auf den während des Exports in den Knoten gespeicherten
id-Eigenschaften wiederherzustellen. Stellen Sie sicher, dass Ihre Knoten über konsistenteid-Eigenschaften verfügen, damit die Beziehungen korrekt wiederhergestellt werden können.
Beispiele
Das Verzeichnis examples/ enthält praktische Beispiele, die verschiedene Funktionen des ATLAS MCP-Servers demonstrieren.
Backup-Beispiel : Dieses Beispiel befindet sich unter
examples/backup-example/und zeigt die Struktur und das Format der JSON-Dateien, die vom Befehlnpm run db:backupgeneriert werden. Weitere Informationen finden Sie in der README-Datei der Beispiele .Beispiel für eine intensive Recherche : Dieses Beispiel befindet sich unter
examples/deep-research-example/und demonstriert die vom Toolatlas_deep_researchgenerierte Ausgabe und Struktur. Es enthält eine Markdown-Datei (covington_community_grant_research.md) mit einer Zusammenfassung des Forschungsplans und eine JSON-Datei (full-export.json) mit den Rohdaten, die nach der Erstellung des Forschungsplans aus der Datenbank exportiert wurden. Weitere Informationen finden Sie in der README-Datei der Beispiele .
Lizenz
Apache-Lizenz 2.0
Appeared in Searches
- A scheduling engine powered by AI
- A server for data engineering tasks, GPU clustering, nomad setup, and data pipeline management
- A system for task management and integration with AI editors using multiple LLMs
- Tools and Templates for Prompt Management and Workflow Automation
- Information or resources related to 'Prompt'