@xingyuchen/mysql-mcp-server 4.0.1 → 4.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +66 -2
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -55,7 +55,7 @@ function extractDatabaseConfigsFromHeaders(req) {
|
|
|
55
55
|
function createMCPServer(dbManager) {
|
|
56
56
|
const server = new Server({
|
|
57
57
|
name: "mysql-mcp-server",
|
|
58
|
-
version: "4.0.
|
|
58
|
+
version: "4.0.2"
|
|
59
59
|
}, {
|
|
60
60
|
capabilities: {
|
|
61
61
|
tools: {}
|
|
@@ -123,6 +123,7 @@ app.get("/health", (_req, res) => {
|
|
|
123
123
|
});
|
|
124
124
|
});
|
|
125
125
|
// ==================== MCP Endpoint ====================
|
|
126
|
+
// POST: 处理请求和响应
|
|
126
127
|
app.post("/mcp", async (req, res) => {
|
|
127
128
|
const sessionIdHeader = req.headers["mcp-session-id"];
|
|
128
129
|
const body = req.body;
|
|
@@ -200,12 +201,75 @@ app.post("/mcp", async (req, res) => {
|
|
|
200
201
|
}
|
|
201
202
|
}
|
|
202
203
|
});
|
|
204
|
+
// GET: 处理 SSE 流(用于服务器推送通知)
|
|
205
|
+
app.get("/mcp", async (req, res) => {
|
|
206
|
+
const sessionIdHeader = req.headers["mcp-session-id"];
|
|
207
|
+
if (!sessionIdHeader || !sessions.has(sessionIdHeader)) {
|
|
208
|
+
return res.status(400).json({
|
|
209
|
+
jsonrpc: "2.0",
|
|
210
|
+
error: { code: -32000, message: "Session not found or invalid" },
|
|
211
|
+
id: null
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
const session = sessions.get(sessionIdHeader);
|
|
215
|
+
session.lastActivity = new Date();
|
|
216
|
+
try {
|
|
217
|
+
// 使用 transport 处理 SSE 流请求
|
|
218
|
+
await session.transport.handleRequest(req, res);
|
|
219
|
+
}
|
|
220
|
+
catch (error) {
|
|
221
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
222
|
+
console.error(`❌ SSE 流处理失败:`, err.message);
|
|
223
|
+
if (!res.headersSent) {
|
|
224
|
+
return res.status(500).json({
|
|
225
|
+
jsonrpc: "2.0",
|
|
226
|
+
error: { code: -32000, message: err.message },
|
|
227
|
+
id: null
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
});
|
|
232
|
+
// DELETE: 关闭会话
|
|
233
|
+
app.delete("/mcp", async (req, res) => {
|
|
234
|
+
const sessionIdHeader = req.headers["mcp-session-id"];
|
|
235
|
+
if (!sessionIdHeader || !sessions.has(sessionIdHeader)) {
|
|
236
|
+
return res.status(400).json({
|
|
237
|
+
jsonrpc: "2.0",
|
|
238
|
+
error: { code: -32000, message: "Session not found" },
|
|
239
|
+
id: null
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
const session = sessions.get(sessionIdHeader);
|
|
243
|
+
try {
|
|
244
|
+
// 断开数据库连接
|
|
245
|
+
await session.dbManager.disconnectAll();
|
|
246
|
+
// 关闭 transport
|
|
247
|
+
await session.transport.close();
|
|
248
|
+
// 删除会话
|
|
249
|
+
sessions.delete(sessionIdHeader);
|
|
250
|
+
console.log(`🗑️ 会话已关闭: ${sessionIdHeader}`);
|
|
251
|
+
return res.status(200).json({
|
|
252
|
+
jsonrpc: "2.0",
|
|
253
|
+
result: { success: true },
|
|
254
|
+
id: null
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
catch (error) {
|
|
258
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
259
|
+
console.error(`❌ 关闭会话失败:`, err.message);
|
|
260
|
+
return res.status(500).json({
|
|
261
|
+
jsonrpc: "2.0",
|
|
262
|
+
error: { code: -32000, message: err.message },
|
|
263
|
+
id: null
|
|
264
|
+
});
|
|
265
|
+
}
|
|
266
|
+
});
|
|
203
267
|
// ==================== 启动服务器 ====================
|
|
204
268
|
app.listen(PORT, () => {
|
|
205
269
|
console.log(`
|
|
206
270
|
╔═══════════════════════════════════════════════════════════╗
|
|
207
271
|
║ ║
|
|
208
|
-
║ 🚀 MySQL MCP Server v4.0.
|
|
272
|
+
║ 🚀 MySQL MCP Server v4.0.2 已启动 ║
|
|
209
273
|
║ ║
|
|
210
274
|
║ 📡 MCP Endpoint: http://localhost:${PORT}/mcp ║
|
|
211
275
|
║ 💚 Health Check: http://localhost:${PORT}/health ║
|