@memo-code/memo 0.8.5 → 0.8.7
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/web/server/main.cjs +145359 -0
- package/package.json +2 -1
- package/dist/web/server/app.controller.d.ts +0 -6
- package/dist/web/server/app.controller.js +0 -33
- package/dist/web/server/app.module.d.ts +0 -4
- package/dist/web/server/app.module.js +0 -61
- package/dist/web/server/auth/access-token.guard.d.ts +0 -9
- package/dist/web/server/auth/access-token.guard.js +0 -53
- package/dist/web/server/auth/auth.controller.d.ts +0 -18
- package/dist/web/server/auth/auth.controller.js +0 -75
- package/dist/web/server/auth/auth.module.d.ts +0 -2
- package/dist/web/server/auth/auth.module.js +0 -24
- package/dist/web/server/auth/auth.service.d.ts +0 -15
- package/dist/web/server/auth/auth.service.js +0 -146
- package/dist/web/server/auth/auth.types.d.ts +0 -26
- package/dist/web/server/auth/auth.types.js +0 -2
- package/dist/web/server/auth/public.decorator.d.ts +0 -2
- package/dist/web/server/auth/public.decorator.js +0 -7
- package/dist/web/server/chat/chat.controller.d.ts +0 -30
- package/dist/web/server/chat/chat.controller.js +0 -150
- package/dist/web/server/chat/chat.module.d.ts +0 -2
- package/dist/web/server/chat/chat.module.js +0 -26
- package/dist/web/server/chat/chat.service.d.ts +0 -61
- package/dist/web/server/chat/chat.service.js +0 -847
- package/dist/web/server/chat/chat.types.d.ts +0 -38
- package/dist/web/server/chat/chat.types.js +0 -2
- package/dist/web/server/common/constants.d.ts +0 -1
- package/dist/web/server/common/constants.js +0 -4
- package/dist/web/server/common/filters/api-error.filter.d.ts +0 -7
- package/dist/web/server/common/filters/api-error.filter.js +0 -95
- package/dist/web/server/common/interceptors/api-response.interceptor.d.ts +0 -15
- package/dist/web/server/common/interceptors/api-response.interceptor.js +0 -51
- package/dist/web/server/common/middleware/request-logging.middleware.d.ts +0 -7
- package/dist/web/server/common/middleware/request-logging.middleware.js +0 -42
- package/dist/web/server/config/memo-config.service.d.ts +0 -7
- package/dist/web/server/config/memo-config.service.js +0 -106
- package/dist/web/server/config/memo-config.types.d.ts +0 -6
- package/dist/web/server/config/memo-config.types.js +0 -2
- package/dist/web/server/config/server-config.module.d.ts +0 -2
- package/dist/web/server/config/server-config.module.js +0 -22
- package/dist/web/server/config/server-config.service.d.ts +0 -14
- package/dist/web/server/config/server-config.service.js +0 -326
- package/dist/web/server/config/server-config.service.test.d.ts +0 -1
- package/dist/web/server/config/server-config.service.test.js +0 -193
- package/dist/web/server/config/server-config.types.d.ts +0 -27
- package/dist/web/server/config/server-config.types.js +0 -2
- package/dist/web/server/main.d.ts +0 -1
- package/dist/web/server/main.js +0 -19
- package/dist/web/server/mcp/mcp.controller.d.ts +0 -38
- package/dist/web/server/mcp/mcp.controller.js +0 -126
- package/dist/web/server/mcp/mcp.module.d.ts +0 -2
- package/dist/web/server/mcp/mcp.module.js +0 -22
- package/dist/web/server/mcp/mcp.service.d.ts +0 -25
- package/dist/web/server/mcp/mcp.service.js +0 -56
- package/dist/web/server/server.d.ts +0 -18
- package/dist/web/server/server.js +0 -142
- package/dist/web/server/sessions/sessions.controller.d.ts +0 -8
- package/dist/web/server/sessions/sessions.controller.js +0 -59
- package/dist/web/server/sessions/sessions.module.d.ts +0 -2
- package/dist/web/server/sessions/sessions.module.js +0 -24
- package/dist/web/server/sessions/sessions.service.d.ts +0 -22
- package/dist/web/server/sessions/sessions.service.js +0 -217
- package/dist/web/server/sessions/sessions.types.d.ts +0 -18
- package/dist/web/server/sessions/sessions.types.js +0 -2
- package/dist/web/server/skills/skills.controller.d.ts +0 -31
- package/dist/web/server/skills/skills.controller.js +0 -86
- package/dist/web/server/skills/skills.module.d.ts +0 -2
- package/dist/web/server/skills/skills.module.js +0 -24
- package/dist/web/server/skills/skills.service.d.ts +0 -38
- package/dist/web/server/skills/skills.service.js +0 -97
- package/dist/web/server/stream/stream.module.d.ts +0 -2
- package/dist/web/server/stream/stream.module.js +0 -20
- package/dist/web/server/stream/stream.service.d.ts +0 -26
- package/dist/web/server/stream/stream.service.js +0 -166
- package/dist/web/server/tsconfig.build.tsbuildinfo +0 -1
- package/dist/web/server/workspaces/workspaces.module.d.ts +0 -2
- package/dist/web/server/workspaces/workspaces.module.js +0 -20
- package/dist/web/server/workspaces/workspaces.service.d.ts +0 -38
- package/dist/web/server/workspaces/workspaces.service.js +0 -378
- package/dist/web/server/workspaces/workspaces.types.d.ts +0 -1
- package/dist/web/server/workspaces/workspaces.types.js +0 -2
- package/dist/web/server/workspaces/workspaces.utils.d.ts +0 -1
- package/dist/web/server/workspaces/workspaces.utils.js +0 -9
- package/dist/web/server/ws/rpc-router.service.d.ts +0 -20
- package/dist/web/server/ws/rpc-router.service.js +0 -275
- package/dist/web/server/ws/session-runtime-registry.service.d.ts +0 -37
- package/dist/web/server/ws/session-runtime-registry.service.js +0 -118
- package/dist/web/server/ws/ws-event-bus.service.d.ts +0 -5
- package/dist/web/server/ws/ws-event-bus.service.js +0 -27
- package/dist/web/server/ws/ws-gateway.module.d.ts +0 -2
- package/dist/web/server/ws/ws-gateway.module.js +0 -42
- package/dist/web/server/ws/ws-gateway.service.d.ts +0 -42
- package/dist/web/server/ws/ws-gateway.service.js +0 -473
- package/dist/web/server/ws/ws.errors.d.ts +0 -8
- package/dist/web/server/ws/ws.errors.js +0 -16
- package/dist/web/server/ws/ws.types.d.ts +0 -34
- package/dist/web/server/ws/ws.types.js +0 -2
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var StreamService_1;
|
|
9
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
-
exports.StreamService = void 0;
|
|
11
|
-
const common_1 = require("@nestjs/common");
|
|
12
|
-
const ws_1 = require("ws");
|
|
13
|
-
function matchSessionStreamPath(pathname) {
|
|
14
|
-
const match = pathname.match(/^\/api\/chat\/sessions\/([^/]+)\/stream$/);
|
|
15
|
-
if (!match)
|
|
16
|
-
return null;
|
|
17
|
-
const sessionId = match[1]?.trim();
|
|
18
|
-
return sessionId && sessionId.length > 0
|
|
19
|
-
? decodeURIComponent(sessionId)
|
|
20
|
-
: null;
|
|
21
|
-
}
|
|
22
|
-
function readBearerTokenFromHeader(authorization) {
|
|
23
|
-
if (!authorization)
|
|
24
|
-
return null;
|
|
25
|
-
const raw = Array.isArray(authorization) ? authorization[0] : authorization;
|
|
26
|
-
if (!raw)
|
|
27
|
-
return null;
|
|
28
|
-
const [scheme, token] = raw.split(' ');
|
|
29
|
-
if (scheme !== 'Bearer' || !token)
|
|
30
|
-
return null;
|
|
31
|
-
const trimmed = token.trim();
|
|
32
|
-
return trimmed.length > 0 ? trimmed : null;
|
|
33
|
-
}
|
|
34
|
-
let StreamService = StreamService_1 = class StreamService {
|
|
35
|
-
logger = new common_1.Logger(StreamService_1.name);
|
|
36
|
-
socketsBySession = new Map();
|
|
37
|
-
listenersBySession = new Map();
|
|
38
|
-
globalListeners = new Set();
|
|
39
|
-
wsServer = null;
|
|
40
|
-
attached = false;
|
|
41
|
-
attach(options) {
|
|
42
|
-
if (this.attached)
|
|
43
|
-
return;
|
|
44
|
-
this.attached = true;
|
|
45
|
-
this.wsServer = new ws_1.WebSocketServer({ noServer: true });
|
|
46
|
-
options.httpServer.on('upgrade', (request, socket, head) => {
|
|
47
|
-
const requestUrl = new URL(request.url ?? '/', 'http://127.0.0.1');
|
|
48
|
-
const sessionId = matchSessionStreamPath(requestUrl.pathname);
|
|
49
|
-
if (!sessionId || !this.wsServer)
|
|
50
|
-
return;
|
|
51
|
-
const queryToken = requestUrl.searchParams.get('accessToken')?.trim() ?? null;
|
|
52
|
-
const headerToken = readBearerTokenFromHeader(request.headers.authorization);
|
|
53
|
-
const accessToken = headerToken ?? queryToken;
|
|
54
|
-
if (!accessToken) {
|
|
55
|
-
socket.write('HTTP/1.1 401 Unauthorized\\r\\n\\r\\n');
|
|
56
|
-
socket.destroy();
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
void options
|
|
60
|
-
.verifyAccessToken(accessToken)
|
|
61
|
-
.then(() => {
|
|
62
|
-
this.wsServer?.handleUpgrade(request, socket, head, (ws) => {
|
|
63
|
-
this.registerSocket(sessionId, ws);
|
|
64
|
-
});
|
|
65
|
-
})
|
|
66
|
-
.catch(() => {
|
|
67
|
-
socket.write('HTTP/1.1 401 Unauthorized\\r\\n\\r\\n');
|
|
68
|
-
socket.destroy();
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
broadcast(sessionId, payload) {
|
|
73
|
-
if (this.globalListeners.size > 0) {
|
|
74
|
-
for (const listener of this.globalListeners) {
|
|
75
|
-
listener(sessionId, payload);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
const listeners = this.listenersBySession.get(sessionId);
|
|
79
|
-
if (listeners && listeners.size > 0) {
|
|
80
|
-
for (const listener of listeners) {
|
|
81
|
-
listener(payload);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const sockets = this.socketsBySession.get(sessionId);
|
|
85
|
-
if (!sockets || sockets.size === 0)
|
|
86
|
-
return;
|
|
87
|
-
const message = JSON.stringify(payload);
|
|
88
|
-
for (const socket of sockets) {
|
|
89
|
-
if (socket.readyState === socket.OPEN) {
|
|
90
|
-
socket.send(message);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
disconnectSession(sessionId) {
|
|
95
|
-
const sockets = this.socketsBySession.get(sessionId);
|
|
96
|
-
if (!sockets)
|
|
97
|
-
return;
|
|
98
|
-
for (const socket of sockets) {
|
|
99
|
-
socket.close(1000, 'session closed');
|
|
100
|
-
}
|
|
101
|
-
this.socketsBySession.delete(sessionId);
|
|
102
|
-
}
|
|
103
|
-
subscribe(sessionId, listener) {
|
|
104
|
-
let listeners = this.listenersBySession.get(sessionId);
|
|
105
|
-
if (!listeners) {
|
|
106
|
-
listeners = new Set();
|
|
107
|
-
this.listenersBySession.set(sessionId, listeners);
|
|
108
|
-
}
|
|
109
|
-
listeners.add(listener);
|
|
110
|
-
return () => {
|
|
111
|
-
const target = this.listenersBySession.get(sessionId);
|
|
112
|
-
if (!target)
|
|
113
|
-
return;
|
|
114
|
-
target.delete(listener);
|
|
115
|
-
if (target.size === 0) {
|
|
116
|
-
this.listenersBySession.delete(sessionId);
|
|
117
|
-
}
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
subscribeAll(listener) {
|
|
121
|
-
this.globalListeners.add(listener);
|
|
122
|
-
return () => {
|
|
123
|
-
this.globalListeners.delete(listener);
|
|
124
|
-
};
|
|
125
|
-
}
|
|
126
|
-
async onModuleDestroy() {
|
|
127
|
-
if (this.wsServer) {
|
|
128
|
-
for (const [, sockets] of this.socketsBySession) {
|
|
129
|
-
for (const socket of sockets) {
|
|
130
|
-
socket.close(1001, 'server shutdown');
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
this.socketsBySession.clear();
|
|
134
|
-
this.listenersBySession.clear();
|
|
135
|
-
this.globalListeners.clear();
|
|
136
|
-
await new Promise((resolve) => {
|
|
137
|
-
this.wsServer?.close(() => resolve());
|
|
138
|
-
});
|
|
139
|
-
this.wsServer = null;
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
registerSocket(sessionId, socket) {
|
|
143
|
-
let sockets = this.socketsBySession.get(sessionId);
|
|
144
|
-
if (!sockets) {
|
|
145
|
-
sockets = new Set();
|
|
146
|
-
this.socketsBySession.set(sessionId, sockets);
|
|
147
|
-
}
|
|
148
|
-
sockets.add(socket);
|
|
149
|
-
socket.on('close', () => {
|
|
150
|
-
const target = this.socketsBySession.get(sessionId);
|
|
151
|
-
if (!target)
|
|
152
|
-
return;
|
|
153
|
-
target.delete(socket);
|
|
154
|
-
if (target.size === 0) {
|
|
155
|
-
this.socketsBySession.delete(sessionId);
|
|
156
|
-
}
|
|
157
|
-
});
|
|
158
|
-
socket.on('error', (error) => {
|
|
159
|
-
this.logger.warn(`socket error for session=${sessionId}: ${error.message}`);
|
|
160
|
-
});
|
|
161
|
-
}
|
|
162
|
-
};
|
|
163
|
-
exports.StreamService = StreamService;
|
|
164
|
-
exports.StreamService = StreamService = StreamService_1 = __decorate([
|
|
165
|
-
(0, common_1.Injectable)()
|
|
166
|
-
], StreamService);
|