mcp-chat-connect 1.1.1 → 1.1.3
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/index.js +5 -1
- package/package.json +1 -1
package/index.js
CHANGED
|
@@ -4,6 +4,7 @@ const http = require('http');
|
|
|
4
4
|
const { URL } = require('url');
|
|
5
5
|
const fs = require('fs');
|
|
6
6
|
const path = require('path');
|
|
7
|
+
const crypto = require('crypto');
|
|
7
8
|
const WebSocket = require('ws');
|
|
8
9
|
|
|
9
10
|
// Config file stores auth state between sessions
|
|
@@ -78,7 +79,7 @@ let wsReconnectTimeout = null;
|
|
|
78
79
|
function connectWebSocket() {
|
|
79
80
|
if (!sessionState.connected || !sessionState.token || !sessionState.channelId) return;
|
|
80
81
|
|
|
81
|
-
const wsUrl = `${MCP_CHAT_URL.replace('https://', 'wss://').replace('http://', 'ws://')}/ws?token=${sessionState.token}&channel=${sessionState.channelId}&session
|
|
82
|
+
const wsUrl = `${MCP_CHAT_URL.replace('https://', 'wss://').replace('http://', 'ws://')}/ws?token=${sessionState.token}&channel=${sessionState.channelId}&session=${sessionState.sessionToken}`;
|
|
82
83
|
|
|
83
84
|
if (wsConnection) {
|
|
84
85
|
try { wsConnection.close(); } catch {}
|
|
@@ -218,6 +219,7 @@ let sessionState = {
|
|
|
218
219
|
channelName: null,
|
|
219
220
|
userName: null,
|
|
220
221
|
userId: null,
|
|
222
|
+
sessionToken: null,
|
|
221
223
|
connected: false,
|
|
222
224
|
};
|
|
223
225
|
|
|
@@ -304,12 +306,14 @@ async function handleToolCall(name, args) {
|
|
|
304
306
|
userId = payload.id;
|
|
305
307
|
} catch {}
|
|
306
308
|
|
|
309
|
+
const sessionToken = `mcp-${crypto.randomBytes(16).toString('hex')}`;
|
|
307
310
|
sessionState = {
|
|
308
311
|
token: result.token,
|
|
309
312
|
channelId: result.channelId,
|
|
310
313
|
channelName: result.channelName,
|
|
311
314
|
userName: result.userName,
|
|
312
315
|
userId,
|
|
316
|
+
sessionToken,
|
|
313
317
|
connected: true,
|
|
314
318
|
};
|
|
315
319
|
saveConfig({ token: result.token, userName: result.userName, userId });
|
package/package.json
CHANGED