Universal MCP Server
A universal MCP server with a modular plugin architecture.
Universal MCP Server
Универсальный MCP сервер с модульной архитектурой плагинов. Позволяет легко добавлять новые инструменты без изменения основного кода.
⚙️ Установка и настройка
1. Установка зависимостей
npm install
2. Настройка переменных окружения
Создайте файл .env в корне проекта на основе .env.example:
cp .env.example .env
Заполните необходимые переменные:
# Telegram Bot Configuration
TELEGRAM_BOT_TOKEN=your_bot_token_here
TELEGRAM_CHAT_ID=your_chat_id_here
# Server Configuration
PORT=8080
# Database Configuration
DATABASE_URL=postgresql://username:password@localhost:5432/timelix
# Example for local development:
# DATABASE_URL=postgresql://postgres:password@localhost:5432/timelix
# Example for production with SSL:
# DATABASE_URL=postgresql://username:password@host:5432/database?sslmode=require
🏠 Локальная разработка
Для локальной разработки используйте Docker Compose с пробросом порта:
# Запуск для разработки (с портом 8080 наружу)
docker-compose -f docker-compose.local.yml up --build
# Запуск в фоне
docker-compose -f docker-compose.local.yml up --build -d
# Остановка
docker-compose -f docker-compose.local.yml down
Сервер будет доступен на http://localhost:8080 с SSE endpoint на /sse.
Альтернативно через npm (для разработки с hot reload):
npm run dev
🚀 Продакшн деплой
На сервере используйте обычный Docker Compose:
# На сервере - деплой в продакшн
docker-compose up --build -d
# Остановка
docker-compose down
# Обновление (пересборка)
docker-compose down
docker-compose up --build -d
🚀 Особенности
- Модульная архитектура: добавляйте новые инструменты, просто создавая файлы в папке
src/tools/ - Автоматическая загрузка: система автоматически обнаруживает и регистрирует все инструменты
- TypeScript: полная типизация для безопасности и удобства разработки
- Docker поддержка: готовые Docker и Docker Compose конфигурации
- Готовые инструменты: 4 встроенных инструмента для различных задач
Получение токена Telegram бота:
- Найдите бота @BotFather в Telegram
- Отправьте команду
/newbot - Следуйте инструкциям для создания бота
- Скопируйте полученный токен
Получение Chat ID:
- Запустите вашего бота
- Отправьте ему любое сообщение
- Перейдите по ссылке:
https://api.telegram.org/bot<YOUR_BOT_TOKEN>/getUpdates - Найдите значение
chat.idв ответе
Важно:
docker-compose.local.yml- для локальной разработки (порт 8080 наружу)docker-compose.yml- для продакшена (без проброса портов, с Coolify лейблами)
🔧 Настройка Claude Desktop
Отредактируйте файл конфигурации Claude Desktop:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Добавьте следующую конфигурацию:
{
"mcpServers": {
"Universal MCP Server": {
"url": "http://localhost:8080/sse"
}
}
}
После изменения конфигурации перезапустите Claude Desktop.
🛠️ Создание новых инструментов
Чтобы добавить новый инструмент, создайте файл в папке src/tools/ следующего формата:
import { z } from 'zod'
import type { ToolDefinition } from '../types/tool.js'
export const toolDefinition: ToolDefinition = {
name: 'myNewTool',
description: 'Описание нового инструмента',
inputSchema: z.object({
parameter1: z.string().describe('Описание параметра'),
parameter2: z.number().optional().describe('Опциональный параметр'),
}),
handler: async (args) => {
// Логика инструмента
return {
success: true,
result: 'Результат работы инструмента',
}
},
}
Система автоматически обнаружит и зарегистрирует новый инструмент при следующем запуске сервера.
📁 Структура проекта
Universal-MCP-Server/
├── src/
│ ├── tools/ # 🔧 Папка с инструментами
│ │ ├── README.md # Документация для разработчиков
│ │ ├── messages.ts # Telegram сообщения
│ │ ├── http-requests.ts # HTTP запросы
│ │ ├── file-operations.ts # Файловые операции
│ │ └── database-tool.ts # SQL запросы
│ ├── types/
│ │ └── tool.ts # TypeScript интерфейсы
│ ├── utils/
│ │ └── tool-loader.ts # Автозагрузчик инструментов
│ └── main.ts # Главный файл сервера
├── dist/ # Скомпилированные файлы
├── docker-compose.yml # Docker Compose для продакшена
├── docker-compose.local.yml # Docker Compose для локальной разработки
├── Dockerfile # Docker образ
├── .env # Переменные окружения
├── .env.example # Пример переменных окружения
└── README.md # Эта документация
📚 Доступные инструменты
📱 sendTelegramMessage
Отправка сообщений в Telegram
// Параметры:
{
text: string // Текст сообщения
}
🌐 httpRequest
Выполнение HTTP запросов к внешним API
// Параметры:
{
url: string, // URL для запроса
method?: "GET" | "POST" | "PUT" | "DELETE", // HTTP метод (по умолчанию GET)
headers?: object, // HTTP заголовки
body?: string // Тело запроса (для POST/PUT)
}
🧮 calculator
Математические вычисления
// Параметры:
{
expression: string // Математическое выражение
}
🗂️ manageBlocks
Универсальное управление блоками - полный CRUD функционал
// Параметры:
{
operation: "list" | "create" | "update" | "delete" | "get", // Тип операции
userId: string, // ID пользователя
blockId?: string, // ID блока (для get, update, delete)
parentId?: string, // ID родительского блока
type?: "text" | "todo" | "media" | "link" | "container" | "unit_ref" | "calendar" | "database", // Тип блока
title?: string, // Заголовок блока
content?: object, // Содержимое блока (JSON)
style?: object, // Стили блока (JSON)
position?: object, // Позиция блока (JSON)
order?: number, // Порядок блока
archived?: boolean, // Архивирован ли блок
tags?: any[] // Теги блока
}
✅ createTodo
Создать новую задачу (тудушку)
// Параметры:
{
title: string, // Название задачи (обязательно)
description?: string, // Описание задачи
priority?: "high" | "medium" | "low", // Приоритет задачи
dueDate?: string, // Срок выполнения (ISO строка)
tags?: string[], // Теги задачи
projectId?: string // ID проекта
}
📖 readTodos
Читать задачи (тудушки) - по ID, позиции, поиску или список всех
// Параметры:
{
todoId?: string, // Точный ID задачи (если известен)
position?: number, // Номер задачи в списке (1, 2, 3...)
titleSearch?: string // Поиск по части названия задачи
}
✏️ updateTodo
Обновить существующую задачу (тудушку)
// Параметры:
{
// Поиск задачи для обновления (один из параметров):
todoId?: string, // Точный ID задачи
position?: number, // Номер задачи в списке
titleSearch?: string, // Поиск по части названия
// Поля для обновления:
title?: string, // Новое название задачи
description?: string, // Новое описание задачи
completed?: boolean, // Новый статус выполнения
priority?: "high" | "medium" | "low", // Новый приоритет
dueDate?: string, // Новый срок выполнения
tags?: string[], // Новые теги задачи
projectId?: string // Новый ID проекта
}
🗑️ deleteTodo
Удалить задачу (тудушку) - мягкое удаление
// Параметры:
{
todoId?: string, // Точный ID задачи (если известен)
position?: number, // Номер задачи в списке (1, 2, 3...)
titleSearch?: string // Поиск по части названия задачи
}
🤖 manageUnits
Универсальное управление агентами (ИИ ассистенты) - полный CRUD функционал
// Параметры:
{
operation: "list" | "create" | "update" | "delete" | "get", // Тип операции
userId: string, // ID пользователя
unitId?: string, // ID агента (для get, update, delete)
name?: string, // Имя агента
description?: string, // Описание агента
avatar?: string, // Аватар агента
model?: string, // Модель ИИ (например, gpt-4, claude-3)
systemPrompt?: string, // Системный промпт агента
tools?: any[], // Инструменты агента
isDefault?: boolean, // Агент по умолчанию
avatarUrl?: string, // URL аватара агента
unitType?: "assistant" | "human" | "timelix" | "system", // Тип агента
nameSearch?: string // Поиск по части имени агента
}
🔧 Технические особенности
- ES Modules: современная модульная система JavaScript
- TypeScript: полная типизация с компиляцией в ES2020
- Express.js: HTTP сервер для MCP протокола
- Server-Sent Events (SSE): для MCP коммуникации
- Zod: валидация схем для безопасности типов
- Автоматическая загрузка: переменные окружения через dotenv
🐳 Docker
Проект включает готовые Docker конфигурации:
Dockerfile- образ для сборки приложенияdocker-compose.yml- для продакшен деплоя (без проброса портов)docker-compose.local.yml- для локальной разработки (с портом 8080 наружу)
Локальная разработка:
docker-compose -f docker-compose.local.yml up --build -d
Продакшн деплой:
docker-compose up --build -d
🤝 Вклад в проект
- Форкните репозиторий
- Создайте ветку для новой функции
- Добавьте свои инструменты в
src/tools/ - Протестируйте изменения
- Создайте Pull Request
📄 Лицензия
MIT License. Смотрите файл LICENSE для деталей.
Создано с ❤️ для упрощения работы с MCP инструментами
Servidores relacionados
Alpha Vantage MCP Server
patrocinadorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
MCP Server on Cloudflare
A template for deploying a remote MCP server on Cloudflare Workers without authentication.
CodeClone
Structural code quality analysis for Python with baseline-aware CI governance, canonical reports, and a triage-first MCP control surface for agents and IDEs.
Sverklo
Local-first code intelligence MCP server. Hybrid BM25 + ONNX vector search, symbol-level impact analysis, diff-aware PR review with risk scoring, and persistent memory tied to git state. 20 tools, MIT licensed.
mobile-device-mcp
MCP server for AI-powered mobile device control — 26 tools for screenshots, UI inspection, touch interaction, and AI visual analysis. Supports Anthropic Claude & Google Gemini.
LLM API Benchmark MCP Server
Benchmark LLM APIs for throughput and Time To First Token (TTFT) under various concurrency levels.
Code Sync MCP Server
Hot reload remote containerized Python applications directly from your IDE.
Remote MCP Server (Authless)
An example of a remote MCP server without authentication, deployable on Cloudflare Workers.
AntBot MCP Server
A TypeScript MCP server for integrating with the AntBot AI-based RPA platform, handling tool listing and execution.
MCP VSCode Cline
A guide for using the Cline VSCode extension to interact with Model Context Protocol (MCP) servers.
Web3 MCP
Interact with multiple blockchains including Solana, Ethereum, THORChain, XRP Ledger, TON, Cardano, and UTXO chains.