/**
* ZenTao MCP 服务器主入口
*/
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
import { z } from 'zod';
import { loadConfig } from './config';
import { ZenTaoClient } from './client';
import { LRUCache } from './utils/cache';
import { Logger, LogLevel } from './utils/logger';
import { registerAllTools } from './tools';
async function main() {
// 初始化日志
const logger = new Logger(LogLevel.INFO);
logger.info('启动 ZenTao MCP 服务器...');
try {
// 加载配置
const config = loadConfig();
logger.info(`配置加载完成: ${config.baseUrl}`);
// 创建禅道客户端
const client = new ZenTaoClient(config, logger);
logger.info('禅道 API 客户端已创建');
// 验证连接
const isConnected = await client.verifyConnection();
if (!isConnected) {
logger.error('无法连接到禅道服务器,请检查配置');
process.exit(1);
}
logger.info('连接验证成功');
// 获取版本信息
const version = await client.getVersion();
logger.info(`禅道版本: ${version}`);
// 创建缓存
const cache = new LRUCache<string, any>({
maxSize: 1000,
defaultTtl: 5 * 60 * 1000, // 5 分钟
enableStats: true,
});
logger.info('LRU 缓存已初始化');
// 创建 MCP 服务器
const server = new McpServer(
{
name: 'zendao-mcp-server',
version: '1.0.0',
}
);
// 注册所有工具
registerAllTools(server, client, cache, logger);
// 使用标准输入输出传输
const transport = new StdioServerTransport();
// 连接服务器
await server.connect(transport);
logger.info('MCP 服务器已启动,等待连接...');
} catch (error: any) {
logger.error('服务器启动失败', error);
process.exit(1);
}
}
// 启动服务器
main().catch((error) => {
console.error('Fatal error:', error);
process.exit(1);
});