Corregir errores de TypeScript en servidor MCP Gitea
- Usar McpServer en vez de Server - Corregir import de StreamableHTTPServerTransport - Ajustar estructura del servidor según SDK oficial - Compilación exitosa verificada localmente
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
import { Server } from '@modelcontextprotocol/sdk/server/index.js';
|
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
||||||
import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamablehttp.js';
|
import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';
|
||||||
import express from 'express';
|
import express from 'express';
|
||||||
import { z } from 'zod';
|
import { z } from 'zod';
|
||||||
|
|
||||||
@@ -33,17 +33,10 @@ async function giteaRequest(endpoint: string, options: RequestInit = {}) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Crear servidor MCP
|
// Crear servidor MCP
|
||||||
const server = new Server(
|
const server = new McpServer({
|
||||||
{
|
name: 'gitea-server',
|
||||||
name: 'mcp-gitea-server',
|
version: '1.0.0'
|
||||||
version: '1.0.0',
|
});
|
||||||
},
|
|
||||||
{
|
|
||||||
capabilities: {
|
|
||||||
tools: {},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
// ==================== HERRAMIENTA 1: gitea_repos ====================
|
// ==================== HERRAMIENTA 1: gitea_repos ====================
|
||||||
server.registerTool(
|
server.registerTool(
|
||||||
@@ -402,9 +395,10 @@ server.registerTool(
|
|||||||
|
|
||||||
// ==================== SERVIDOR EXPRESS ====================
|
// ==================== SERVIDOR EXPRESS ====================
|
||||||
const app = express();
|
const app = express();
|
||||||
|
app.use(express.json());
|
||||||
|
|
||||||
// Health check
|
// Health check
|
||||||
app.get('/health', (_req, res) => {
|
app.get('/health', (req, res) => {
|
||||||
res.json({
|
res.json({
|
||||||
status: 'ok',
|
status: 'ok',
|
||||||
service: 'mcp-gitea-server',
|
service: 'mcp-gitea-server',
|
||||||
@@ -413,23 +407,41 @@ app.get('/health', (_req, res) => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// Endpoint MCP
|
// Endpoint MCP (escucha en / porque Traefik hace StripPrefix de /mcp)
|
||||||
app.post('/mcp', async (req, res) => {
|
app.post('/', async (req, res) => {
|
||||||
const transport = new StreamableHTTPServerTransport({
|
try {
|
||||||
sessionId: `session-${Date.now()}`,
|
const transport = new StreamableHTTPServerTransport({
|
||||||
req,
|
sessionIdGenerator: undefined,
|
||||||
res,
|
enableJsonResponse: true
|
||||||
server,
|
});
|
||||||
});
|
|
||||||
|
|
||||||
await transport.start();
|
res.on('close', () => {
|
||||||
await transport.runLoop();
|
transport.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
await server.connect(transport);
|
||||||
|
await transport.handleRequest(req, res, req.body);
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Error handling MCP request:', error);
|
||||||
|
if (!res.headersSent) {
|
||||||
|
res.status(500).json({
|
||||||
|
jsonrpc: '2.0',
|
||||||
|
error: {
|
||||||
|
code: -32603,
|
||||||
|
message: 'Internal server error'
|
||||||
|
},
|
||||||
|
id: null
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Iniciar servidor
|
|
||||||
app.listen(PORT, '0.0.0.0', () => {
|
app.listen(PORT, '0.0.0.0', () => {
|
||||||
console.log(`MCP Gitea Server corriendo en http://0.0.0.0:${PORT}/mcp`);
|
console.log(`MCP Gitea Server corriendo en http://0.0.0.0:${PORT}/mcp`);
|
||||||
console.log(`Health check disponible en http://0.0.0.0:${PORT}/health`);
|
console.log(`Health check disponible en http://0.0.0.0:${PORT}/health`);
|
||||||
console.log(`Gitea URL: ${GITEA_URL}`);
|
console.log(`Gitea URL: ${GITEA_URL}`);
|
||||||
console.log(`Token configurado: ${GITEA_TOKEN ? 'Sí' : 'No'}`);
|
console.log(`Token configurado: ${GITEA_TOKEN ? 'Sí' : 'No'}`);
|
||||||
|
}).on('error', error => {
|
||||||
|
console.error('Error del servidor:', error);
|
||||||
|
process.exit(1);
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user