Skip to main content
Glama

atlas-mcp-server

ATLAS: Система управления задачами

ATLAS (Adaptive Task & Logic Automation System) — это система управления проектами, знаниями и задачами для агентов LLM.

Построен на основе трехуровневой архитектуры:

+------------------------------------------+ | PROJECT | |------------------------------------------| | id: string | | name: string | | description: string | | status: string | | urls?: Array<{title: string, url: string}>| | completionRequirements: string | | outputFormat: string | | taskType: string | | createdAt: string | | updatedAt: string | +----------------+-------------------------+ | | | | v v +----------------------------------+ +----------------------------------+ | TASK | | KNOWLEDGE | |----------------------------------| |----------------------------------| | id: string | | id: string | | projectId: string | | projectId: string | | title: string | | text: string | | description: string | | tags?: string[] | | priority: string | | domain: string | | status: string | | citations?: string[] | | assignedTo?: string | | createdAt: string | | urls?: Array<{title: string, | | | | url: string}> | | updatedAt: string | | tags?: string[] | | | | completionRequirements: string | | | | outputFormat: string | | | | taskType: string | | | | createdAt: string | | | | updatedAt: string | | | +----------------------------------+ +----------------------------------+

Реализованный как сервер Model Context Protocol (MCP), ATLAS позволяет агентам LLM взаимодействовать с базой данных управления проектами, что позволяет им управлять проектами, задачами и элементами знаний.

Важное примечание к версии : версия 1.5.4 — последняя версия, которая использует SQLite в качестве базы данных. Версия 2.0 и последующие полностью переписаны для использования Neo4j, что требует либо:

  • Самостоятельное размещение с использованием Docker (docker-compose включен в репозиторий)
  • Использование облачного сервиса Neo4j AuraDB: https://neo4j.com/product/auradb/

В версии 2.5.0 представлена новая система из трех узлов (Проекты, Задачи, Знания), которая заменяет предыдущую структуру.

Оглавление

Обзор

ATLAS реализует протокол контекста модели (MCP), обеспечивающий стандартизированную связь между LLM и внешними системами посредством:

  • Клиенты : Claude Desktop, IDE и другие MCP-совместимые клиенты
  • Серверы : инструменты и ресурсы для управления проектами, задачами и знаниями
  • Агенты LLM : модели ИИ, которые используют возможности управления сервера

Системная интеграция

Платформа Atlas объединяет эти компоненты в единую систему:

  • Связь проекта и задачи : проекты содержат задачи, которые представляют собой выполнимые шаги, необходимые для достижения целей проекта. Задачи наследуют контекст родительского проекта, обеспечивая при этом детальное отслеживание отдельных рабочих элементов.
  • Интеграция знаний : как проекты, так и задачи могут быть обогащены элементами знаний, предоставляя членам команды необходимую информацию и контекст.
  • Управление зависимостями : как проекты, так и задачи поддерживают отношения зависимости, что позволяет реализовывать сложные рабочие процессы с предварительными условиями и требованиями к последовательному выполнению.
  • Единый поиск : платформа предоставляет возможности кросс-сущностного поиска, позволяя пользователям находить релевантные проекты, задачи или знания на основе различных критериев.

Функции

Управление проектом

  • Комплексное отслеживание: управление метаданными проекта, статусами и расширенным контентом (заметками, ссылками и т. д.) с помощью встроенной поддержки массовых операций.
  • Обработка зависимостей и отношений: автоматическая проверка и отслеживание межпроектных зависимостей.

Управление задачами

  • Управление жизненным циклом задач: создание, отслеживание и обновление задач на протяжении всего их жизненного цикла.
  • Приоритизация и категоризация: назначайте уровни приоритета и категоризируйте задачи с помощью тегов для лучшей организации.
  • Отслеживание зависимостей: установите зависимости задач для создания структурированных рабочих процессов.

Управление знаниями

  • Структурированное хранилище знаний: поддерживайте доступное для поиска хранилище информации, связанной с проектом.
  • Категоризация доменов: организация знаний по доменам и тегам для удобства поиска.
  • Поддержка цитирования: отслеживайте источники и ссылки на элементы знаний.

Интеграция графической базы данных

  • Встроенное управление отношениями: используйте ACID-совместимые транзакции Neo4j и оптимизированные запросы для надежной целостности данных.
  • Расширенный поиск и масштабируемость: выполняйте поиск по свойствам с использованием нечеткого соответствия и подстановочных знаков, сохраняя при этом высокую производительность.

Единый поиск

  • Поиск по нескольким сущностям: находите релевантные проекты, задачи или знания на основе контента, метаданных или связей.
  • Гибкие параметры запроса: поддержка параметров фильтрации без учета регистра, нечеткой и расширенной фильтрации.

Установка

  1. Клонируйте репозиторий:
    git clone https://github.com/cyanheads/atlas-mcp-server.git cd atlas-mcp-server
  2. Установить зависимости:
    npm install
  3. Настройте Neo4j: Убедитесь, что у вас есть запущенный и доступный экземпляр Neo4j. Вы можете запустить его, используя предоставленную конфигурацию Docker:
    docker-compose up -d
    Обновите файл .env , указав сведения о подключении Neo4j (см. Конфигурация ).
  4. Создайте проект:
    npm run build

Запуск сервера

Большинство клиентов MCP запускают сервер автоматически, но вы также можете запустить его вручную для тестирования или разработки, используя следующие команды.

Сервер ATLAS MCP поддерживает несколько транспортных механизмов для связи:

  • Стандартный ввод-вывод (stdio): это режим по умолчанию, который обычно используется для прямой интеграции с локальными клиентами MCP (например, расширениями IDE).
    npm run start:stdio
    Здесь используется настройка MCP_TRANSPORT_TYPE=stdio .
  • Потоковый HTTP: этот режим позволяет серверу прослушивать запросы MCP по протоколу HTTP, подходит для удаленных клиентов или веб-интеграций.
    npm run start:http
    Это использует настройку MCP_TRANSPORT_TYPE=http . Сервер будет прослушивать хост и порт, указанные в вашем файле .env (например, MCP_HTTP_HOST и MCP_HTTP_PORT , по умолчанию 127.0.0.1:3010 ). Убедитесь, что ваш брандмауэр разрешает подключения при удаленном доступе.

Веб-интерфейс (экспериментальный)

Для просмотра сведений о проектах, задачах и знаниях доступен базовый веб-интерфейс.

  • Открытие пользовательского интерфейса :
    • Чтобы открыть пользовательский интерфейс непосредственно в браузере, выполните в терминале следующую команду:
      npm run webui
  • Функциональность :
    • Пример скриншота веб-интерфейса можно увидеть здесь .

Конфигурация

Переменные среды

Переменные среды должны быть установлены в конфигурации клиента MCP или в файле .env в корне проекта для локальной разработки.

# Neo4j Configuration NEO4J_URI=bolt://localhost:7687 NEO4J_USER=neo4j NEO4J_PASSWORD=password2 # Application Configuration MCP_LOG_LEVEL=debug # Minimum logging level. Options: emerg, alert, crit, error, warning, notice, info, debug. Default: "debug". LOGS_DIR=./logs # Directory for log files. Default: "./logs" in project root. NODE_ENV=development # 'development' or 'production'. Default: "development". # MCP Transport Configuration MCP_TRANSPORT_TYPE=stdio # 'stdio' or 'http'. Default: "stdio". MCP_HTTP_HOST=127.0.0.1 # Host for HTTP transport. Default: "127.0.0.1". MCP_HTTP_PORT=3010 # Port for HTTP transport. Default: 3010. # MCP_ALLOWED_ORIGINS=http://localhost:someport,https://your-client.com # Optional: Comma-separated list of allowed origins for HTTP CORS. # MCP Security Configuration # MCP_AUTH_SECRET_KEY=your_very_long_and_secure_secret_key_min_32_chars # Optional: Secret key (min 32 chars) for JWT authentication if HTTP transport is used. CRITICAL for production. *Note: Production environment use has not been tested yet.* MCP_RATE_LIMIT_WINDOW_MS=60000 # Rate limit window in milliseconds. Default: 60000 (1 minute). MCP_RATE_LIMIT_MAX_REQUESTS=100 # Max requests per window per IP for HTTP transport. Default: 100. # Database Backup Configuration BACKUP_MAX_COUNT=10 # Maximum number of backup sets to keep. Default: 10. BACKUP_FILE_DIR=./atlas-backups # Directory where backup files will be stored (relative to project root). Default: "./atlas-backups". # OpenRouter LLM Configuration (Optional - additional parameters present in `src/config/index.ts`) # OPENROUTER_API_KEY=your_openrouter_api_key # API key for OpenRouter services. LLM_DEFAULT_MODEL="google/gemini-2.5-flash-preview:thinking" # Default LLM model.

Все доступные переменные среды, их описания и значения по умолчанию можно найти в файле src/config/index.ts .

Настройки клиента MCP

То, как вы настраиваете свой клиент MCP, зависит от самого клиента и выбранного типа транспорта. Файл mcp.json в корне проекта может использоваться некоторыми клиентами (например, mcp-inspector ) для определения конфигураций сервера; обновляйте по мере необходимости.

Для Stdio Transport (пример конфигурации):

{ "mcpServers": { "atlas-mcp-server-stdio": { "command": "node", "args": ["/full/path/to/atlas-mcp-server/dist/index.js"], "env": { "NEO4J_URI": "bolt://localhost:7687", "NEO4J_USER": "neo4j", "NEO4J_PASSWORD": "password2", "MCP_LOG_LEVEL": "info", "NODE_ENV": "production", "MCP_TRANSPORT_TYPE": "stdio" } } } }

Для потокового HTTP (пример конфигурации): если ваш клиент поддерживает подключение к серверу MCP через потоковый HTTP, вы указываете конечную точку сервера (например, http://localhost:3010/mcp ) в конфигурации клиента.

{ "mcpServers": { "atlas-mcp-server-http": { "command": "node", "args": ["/full/path/to/atlas-mcp-server/dist/index.js"], "env": { "NEO4J_URI": "bolt://localhost:7687", "NEO4J_USER": "neo4j", "NEO4J_PASSWORD": "password2", "MCP_LOG_LEVEL": "info", "NODE_ENV": "production", "MCP_TRANSPORT_TYPE": "http", "MCP_HTTP_PORT": "3010", "MCP_HTTP_HOST": "127.0.0.1" // "MCP_AUTH_SECRET_KEY": "your-secure-token" // If authentication is enabled on the server } } } }

Примечание: Всегда используйте абсолютные пути для args при настройке клиентских команд, если сервер не находится в непосредственном рабочем каталоге клиента. MCP_AUTH_SECRET_KEY в блоке env клиента является иллюстративным; фактическая обработка токенов для клиент-серверной связи будет зависеть от возможностей клиента и механизма аутентификации сервера (например, отправка JWT в заголовке Authorization ).

Структура проекта

Кодовая база имеет модульную структуру:

src/ ├── config/ # Configuration management (index.ts) ├── index.ts # Main server entry point ├── mcp/ # MCP server implementation (server.ts) │ ├── resources/ # MCP resource handlers (index.ts, types.ts, knowledge/, projects/, tasks/) │ └── tools/ # MCP tool handlers (individual tool directories) ├── services/ # Core application services │ ├── llm-providers/ # LLM provider integrations (e.g., OpenRouter) │ └── neo4j/ # Neo4j database services (index.ts, driver.ts, backupRestoreService.ts, etc.) ├── types/ # Shared TypeScript type definitions (errors.ts, mcp.ts, tool.ts) └── utils/ # Utility functions and internal services (e.g., logger, errorHandler, sanitization)

Инструменты

ATLAS предоставляет комплексный набор инструментов для управления проектами, задачами и знаниями, вызываемых через протокол контекста модели.

Операции проекта

Название инструментаОписаниеКлючевые аргументы
atlas_project_createСоздает новые проекты (отдельные/групповые).mode ('single'/'bulk'), id (необязательный идентификатор, сгенерированный клиентом для single mode), сведения о проекте ( name , description , status , urls , completionRequirements , dependencies , outputFormat , taskType ). Для bulk mode используйте projects (массив объектов проекта). responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_project_listСписок проектов (все/подробно).mode ('all'/'details', по умолчанию: 'all'), id (для подробного режима), фильтры ( status , taskType ), пагинация ( page , limit ), включает ( includeKnowledge , includeTasks ), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_project_updateОбновляет существующие проекты (отдельные/массовые).mode ('single'/'bulk'), id (для single mode), updates объект. Для bulk mode используйте projects (массив объектов, каждый с id и updates ). responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_project_deleteУдаляет проекты (отдельные/массово).mode («single»/«bulk»), id (для одиночного режима) или projectIds (массив для массового режима). responseFormat («formatted»/«json», необязательно, по умолчанию: «formatted»).

Операции по задачам

Название инструментаОписаниеКлючевые аргументы
atlas_task_createСоздает новые задачи (одиночные/групповые).mode ('single'/'bulk'), id (необязательно, сгенерированный клиентом идентификатор), projectId , сведения о задаче ( title , description , priority , status , assignedTo , urls , tags , completionRequirements , dependencies , outputFormat , taskType ). Для массового режима используйте tasks (массив объектов задач). responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_task_updateОбновляет существующие задачи (отдельные/массовые).mode ('single'/'bulk'), id (для single mode), updates object. Для bulk mode используйте tasks (массив объектов, каждый с id и updates ). responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_task_deleteУдаляет задачи (отдельные/групповые).mode («single»/«bulk»), id (для одиночного режима) или taskIds (массив для массового режима). responseFormat («formatted»/«json», необязательно, по умолчанию: «formatted»).
atlas_task_listПеречисляет задачи для конкретного проекта.projectId (обязательно), фильтры ( status , assignedTo , priority , tags , taskType ), сортировка ( sortBy , sortDirection ), разбиение на страницы ( page , limit ), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').

Операции со знаниями

Название инструментаОписаниеКлючевые аргументы
atlas_knowledge_addДобавляет новые элементы знаний (отдельные/групповые).mode ('single'/'bulk'), id (необязательно, сгенерированный клиентом ID), projectId , сведения о знаниях ( text , tags , domain , citations ). Для массового режима используйте knowledge (массив объектов знаний). responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').
atlas_knowledge_deleteУдаляет элементы знаний (отдельные/групповые).mode («single»/«bulk»), id (для одиночного режима) или knowledgeIds (массив для массового режима). responseFormat («formatted»/«json», необязательно, по умолчанию: «formatted»).
atlas_knowledge_listПеречисляет элементы знаний для конкретного проекта.projectId (обязательно), фильтры ( tags , domain , search ), пагинация ( page , limit ), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').

Поисковые операции

Название инструментаОписаниеКлючевые аргументы
atlas_unified_searchВыполняет унифицированный поиск по всем сущностям.value (поисковый запрос, обязательно), property (необязательно: если указано, выполняется поиск по этому свойству с помощью регулярного выражения; если пропущено, выполняется полнотекстовый поиск), фильтры ( entityTypes , taskType , assignedToUserId ), параметры ( caseInsensitive (по умолчанию: true, для регулярного выражения), fuzzy (по умолчанию: false, для регулярного выражения «содержит» или полнотекстового Lucene fuzzy)), разбиение на страницы ( page , limit ), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').

Научно-исследовательские работы

Название инструментаОписаниеКлючевые аргументы
atlas_deep_researchИнициирует структурированный глубокий процесс исследования путем создания иерархического плана в базе знаний Атласа.projectId (обязательно), researchTopic (обязательно), researchGoal (обязательно), scopeDefinition (необязательно), subTopics (обязательный массив объектов, каждый с question (обязательно), initialSearchQueries (необязательный массив), nodeId (необязательно), priority (необязательно), assignedTo (необязательно), initialStatus (необязательно, по умолчанию: 'todo')), researchDomain (необязательно), initialTags (необязательно), planNodeId (необязательно), createTasks (необязательно, по умолчанию: true), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').

Операции с базами данных

Название инструментаОписаниеКлючевые аргументы
atlas_database_cleanРазрушительный: полностью сбрасывает базу данных, удаляя все проекты, задачи и знания.acknowledgement (должно быть установлено значение true для подтверждения, обязательно), responseFormat ('formatted'/'json', необязательно, по умолчанию: 'formatted').

Ресурсы

ATLAS предоставляет данные о проектах, задачах и знаниях через стандартные конечные точки ресурсов MCP.

Прямые Ресурсы

Имя ресурсаОписание
atlas://projectsСписок всех проектов на платформе Atlas с поддержкой пагинации.
atlas://tasksСписок всех задач на платформе Atlas с поддержкой пагинации и фильтрации.
atlas://knowledgeСписок всех элементов знаний на платформе Atlas с поддержкой пагинации и фильтрации.

Шаблоны ресурсов

Имя ресурсаОписание
atlas://projects/{projectId}Извлекает один проект по его уникальному идентификатору ( projectId ).
atlas://tasks/{taskId}Извлекает одну задачу по ее уникальному идентификатору ( taskId ).
atlas://projects/{projectId}/tasksИзвлекает все задачи, относящиеся к определенному проекту ( projectId ).
atlas://knowledge/{knowledgeId}Извлекает отдельный элемент знаний по его уникальному идентификатору ( knowledgeId ).
atlas://projects/{projectId}/knowledgeИзвлекает все элементы знаний, относящиеся к определенному проекту ( projectId ).

Резервное копирование и восстановление базы данных

ATLAS предоставляет функциональность для резервного копирования и восстановления содержимого базы данных Neo4j. Основная логика находится в src/services/neo4j/backupRestoreService.ts .

Процесс резервного копирования

  • Механизм : Процесс резервного копирования экспортирует все узлы Project , Task и Knowledge вместе с их связями в отдельные файлы JSON. Также создается файл full-export.json содержащий все данные.
  • Вывод : Каждая резервная копия создает каталог с меткой времени (например, atlas-backup-YYYYMMDDHHMMSS ) в настроенном пути резервной копии (по умолчанию: ./atlas-backups/ ). Этот каталог содержит projects.json , tasks.json , knowledge.json , relationships.json и full-export.json .
  • Ручное резервное копирование : вы можете запустить ручное резервное копирование с помощью предоставленного скрипта:
    npm run db:backup
    Эта команда выполняет scripts/db-backup.ts , который вызывает функцию exportDatabase .

Процесс восстановления

  • Механизм : Процесс восстановления сначала полностью очищает существующую базу данных Neo4j. Затем он импортирует узлы и связи из файлов JSON, расположенных в указанном каталоге резервных копий. Он отдает приоритет full-export.json если он доступен.
  • Предупреждение : Восстановление из резервной копии — разрушительная операция. Она перезапишет все текущие данные в вашей базе данных Neo4j.
  • Ручное восстановление : чтобы восстановить базу данных из резервной копии, используйте скрипт импорта:
    npm run db:import <path_to_backup_directory>
    Замените <path_to_backup_directory> фактическим путем к папке резервной копии (например, ./atlas-backups/atlas-backup-20250326120000 ). Эта команда выполняет scripts/db-import.ts , который вызывает функцию importDatabase .
  • Обработка отношений : процесс импорта пытается воссоздать отношения на основе свойств id , сохраненных в узлах во время экспорта. Убедитесь, что ваши узлы имеют согласованные свойства id для правильного восстановления отношений.

Примеры

Каталог examples/ содержит практические примеры, демонстрирующие различные функции сервера ATLAS MCP.

  • Пример резервного копирования : Расположенный в examples/backup-example/ , он показывает структуру и формат файлов JSON, созданных командой npm run db:backup . Подробнее см. в README примеров .
  • Пример глубокого исследования : Расположенный в examples/deep-research-example/ , он демонстрирует вывод и структуру, сгенерированные инструментом atlas_deep_research . Он включает файл markdown ( covington_community_grant_research.md ), обобщающий план исследования, и файл JSON ( full-export.json ), содержащий необработанные данные, экспортированные из базы данных после создания плана исследования. Подробнее см. в README примеров .

Лицензия

Лицензия Apache 2.0


Install Server
A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

ATLAS (Adaptive Task & Logic Automation System) — сервер Model Context Protocol, который предоставляет иерархические возможности управления задачами для больших языковых моделей. Этот инструмент предоставляет LLM структуру и контекст, необходимые для управления сложными задачами и зависимостями.

  1. Оглавление
    1. Обзор
      1. Системная интеграция
    2. Функции
      1. Управление проектом
      2. Управление задачами
      3. Управление знаниями
      4. Интеграция графической базы данных
      5. Единый поиск
    3. Установка
      1. Запуск сервера
        1. Веб-интерфейс (экспериментальный)
          1. Конфигурация
            1. Переменные среды
            2. Настройки клиента MCP
          2. Структура проекта
            1. Инструменты
              1. Операции проекта
              2. Операции по задачам
              3. Операции со знаниями
              4. Поисковые операции
              5. Научно-исследовательские работы
              6. Операции с базами данных
            2. Ресурсы
              1. Прямые Ресурсы
              2. Шаблоны ресурсов
            3. Резервное копирование и восстановление базы данных
              1. Процесс резервного копирования
              2. Процесс восстановления
            4. Примеры
              1. Лицензия

                Related MCP Servers

                • A
                  security
                  A
                  license
                  A
                  quality
                  An official AI Model Context Protocol server that enables AI assistants to interact with Dart project management by creating/managing tasks and documents through prompts and tools.
                  Last updated -
                  15
                  1,524
                  86
                  TypeScript
                  MIT License
                  • Linux
                  • Apple
                • A
                  security
                  F
                  license
                  A
                  quality
                  A Model Context Protocol server that enables AI assistants like Claude to access and search Atlassian Confluence content, allowing integration with your organization's knowledge base.
                  Last updated -
                  5
                  382
                  10
                  TypeScript
                  • Apple
                • A
                  security
                  A
                  license
                  A
                  quality
                  A Model Context Protocol server implementation that enables AI assistants to interact with Apollo.io data, performing operations like people/organization enrichment, searching, and retrieving job postings through natural language commands.
                  Last updated -
                  7
                  3
                  TypeScript
                  MIT License
                • -
                  security
                  A
                  license
                  -
                  quality
                  A Model Context Protocol server that enables AI assistants to interact with MongoDB Atlas resources through natural language, supporting database operations and Atlas management functions.
                  Last updated -
                  3,669
                  342
                  TypeScript
                  Apache 2.0
                  • Apple
                  • Linux

                View all related MCP servers

                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/cyanheads/atlas-mcp-server'

                If you have feedback or need assistance with the MCP directory API, please join our Discord server