@vuer-ai/vuer-rtc-server 0.1.1 → 0.1.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/serve.js +4 -4
- package/dist/serve.js.map +1 -1
- package/dist/transport/RTCServer.d.ts.map +1 -1
- package/dist/transport/RTCServer.js +21 -22
- package/dist/transport/RTCServer.js.map +1 -1
- package/package.json +1 -1
- package/src/serve.ts +4 -4
- package/src/transport/RTCServer.ts +21 -22
- package/tests/e2e/helpers/createTestServer.ts +2 -2
package/dist/serve.js
CHANGED
|
@@ -36,7 +36,7 @@ function ensureRoomDocument(roomId) {
|
|
|
36
36
|
if (existing)
|
|
37
37
|
return existing.id;
|
|
38
38
|
const docId = await journalService.createDocument(roomId, 'system');
|
|
39
|
-
console.log(`[journal] created document ${docId} for room "${roomId}"`);
|
|
39
|
+
// console.log(`[journal] created document ${docId} for room "${roomId}"`);
|
|
40
40
|
return docId;
|
|
41
41
|
})());
|
|
42
42
|
}
|
|
@@ -153,7 +153,7 @@ async function handleApi(req, res) {
|
|
|
153
153
|
try {
|
|
154
154
|
const docId = await docPromise;
|
|
155
155
|
await journalService.clearDocument(docId);
|
|
156
|
-
console.log(`[api] cleared document ${docId} for room "${targetRoomId}"`);
|
|
156
|
+
// console.log(`[api] cleared document ${docId} for room "${targetRoomId}"`);
|
|
157
157
|
}
|
|
158
158
|
catch (e) {
|
|
159
159
|
console.warn(`[api] clear doc error:`, e);
|
|
@@ -161,7 +161,7 @@ async function handleApi(req, res) {
|
|
|
161
161
|
}
|
|
162
162
|
// Broadcast room-reset AFTER state is fully cleared
|
|
163
163
|
rtcServer.broadcastControl(targetRoomId, { mtype: 'room-reset' });
|
|
164
|
-
console.log(`[api] cleared room "${targetRoomId}"`);
|
|
164
|
+
// console.log(`[api] cleared room "${targetRoomId}"`);
|
|
165
165
|
json(res, { ok: true, roomId: targetRoomId });
|
|
166
166
|
return;
|
|
167
167
|
}
|
|
@@ -206,6 +206,6 @@ wss.on('connection', (ws, req) => {
|
|
|
206
206
|
.catch((err) => console.error(`[state-transfer] room="${roomId}":`, err));
|
|
207
207
|
});
|
|
208
208
|
server.listen(PORT, () => {
|
|
209
|
-
console.log(`vuer-rtc server listening on http://localhost:${PORT}`);
|
|
209
|
+
// console.log(`vuer-rtc server listening on http://localhost:${PORT}`);
|
|
210
210
|
});
|
|
211
211
|
//# sourceMappingURL=serve.js.map
|
package/dist/serve.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serve.js","sourceRoot":"","sources":["../src/serve.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,EAAE,YAAY,EAA6C,MAAM,MAAM,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;AAC9C,MAAM,MAAM,GAAG,kBAAkB,EAAE,CAAC;AAEpC,MAAM,MAAM,GAAG,IAAI,cAAc,EAAE,CAAC;AACpC,MAAM,cAAc,GAAG,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;AAElD,gCAAgC;AAChC,0EAA0E;AAC1E,uEAAuE;AAEvE,+EAA+E;AAC/E,MAAM,eAAe,GAAG,IAAI,GAAG,EAA2B,CAAC;AAE3D,SAAS,kBAAkB,CAAC,MAAc;IACxC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;QACjC,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,KAAK,IAAI,EAAE;YACtC,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;YAC9E,IAAI,QAAQ;gBAAE,OAAO,QAAQ,CAAC,EAAE,CAAC;YACjC,MAAM,KAAK,GAAG,MAAM,cAAc,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACpE,
|
|
1
|
+
{"version":3,"file":"serve.js","sourceRoot":"","sources":["../src/serve.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RTCServer.d.ts","sourceRoot":"","sources":["../../src/transport/RTCServer.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAA4B,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAE/E,OAAO,KAAK,EAAE,UAAU,EAAoB,MAAM,oBAAoB,CAAC;AACvE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAE1D,yDAAyD;AACzD,KAAK,UAAU,GAAG,UAAU,GAAG,WAAW,GAAG,MAAM,CAAC;AAEpD,qEAAqE;AACrE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;IACtC,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,KAAK,IAAI,GAAG,IAAI,CAAC;IACzE,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,GAAG,IAAI,CAAC;CAC/C;AAoBD,qBAAa,SAAS;IAWlB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,OAAO;IAXjB,wDAAwD;IACxD,OAAO,CAAC,cAAc,CAAoC;IAE1D,mEAAmE;IACnE,OAAO,CAAC,WAAW,CAA4C;IAE/D,iDAAiD;IACjD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAU;gBAG5C,MAAM,EAAE,UAAU,EAClB,OAAO,GAAE,cAAc,GAAG,IAAW;IAG/C;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAuE/E;;;;OAIG;IACG,mBAAmB,CAAC,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAc9E;;;OAGG;IACH;;;OAGG;IACH,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,GAAG,IAAI;IAUxD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAQhC;;;;OAIG;IACH,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM/B;;OAEG;IACG,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;QAC1C,YAAY,EAAE,MAAM,CAAC;QACrB,OAAO,EAAE,KAAK,CAAC;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,SAAS,EAAE,OAAO,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC7E,CAAC;
|
|
1
|
+
{"version":3,"file":"RTCServer.d.ts","sourceRoot":"","sources":["../../src/transport/RTCServer.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAA4B,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAE/E,OAAO,KAAK,EAAE,UAAU,EAAoB,MAAM,oBAAoB,CAAC;AACvE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAE1D,yDAAyD;AACzD,KAAK,UAAU,GAAG,UAAU,GAAG,WAAW,GAAG,MAAM,CAAC;AAEpD,qEAAqE;AACrE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;IACtC,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,KAAK,IAAI,GAAG,IAAI,CAAC;IACzE,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,GAAG,IAAI,CAAC;CAC/C;AAoBD,qBAAa,SAAS;IAWlB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,OAAO;IAXjB,wDAAwD;IACxD,OAAO,CAAC,cAAc,CAAoC;IAE1D,mEAAmE;IACnE,OAAO,CAAC,WAAW,CAA4C;IAE/D,iDAAiD;IACjD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAU;gBAG5C,MAAM,EAAE,UAAU,EAClB,OAAO,GAAE,cAAc,GAAG,IAAW;IAG/C;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAuE/E;;;;OAIG;IACG,mBAAmB,CAAC,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAc9E;;;OAGG;IACH;;;OAGG;IACH,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,GAAG,IAAI;IAUxD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAQhC;;;;OAIG;IACH,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM/B;;OAEG;IACG,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;QAC1C,YAAY,EAAE,MAAM,CAAC;QACrB,OAAO,EAAE,KAAK,CAAC;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,SAAS,EAAE,OAAO,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC7E,CAAC;YAcY,iBAAiB;IAgC/B,OAAO,CAAC,YAAY;IAgBpB;;;;;;OAMG;IACH,OAAO,CAAC,oBAAoB;IAM5B;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAkCzB,OAAO,CAAC,eAAe;CAYxB"}
|
|
@@ -23,14 +23,13 @@ function toUint8Array(data) {
|
|
|
23
23
|
}
|
|
24
24
|
return null; // string — not binary
|
|
25
25
|
}
|
|
26
|
-
/** Summarize a CRDTMessage's ops for logging. */
|
|
27
|
-
function summarizeOps(msg) {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}
|
|
26
|
+
// /** Summarize a CRDTMessage's ops for logging. */
|
|
27
|
+
// function summarizeOps(msg: CRDTMessage): string {
|
|
28
|
+
// if (!msg.ops || msg.ops.length === 0) return 'empty';
|
|
29
|
+
// const first = msg.ops[0];
|
|
30
|
+
// const summary = `${first.otype} ${first.key}.${first.path}`;
|
|
31
|
+
// return msg.ops.length > 1 ? `${summary} (+${msg.ops.length - 1} more)` : summary;
|
|
32
|
+
// }
|
|
34
33
|
export class RTCServer {
|
|
35
34
|
broker;
|
|
36
35
|
journal;
|
|
@@ -50,7 +49,7 @@ export class RTCServer {
|
|
|
50
49
|
* Call this once per connection after the WS upgrade completes.
|
|
51
50
|
*/
|
|
52
51
|
handleConnection(ws, roomId, sessionId) {
|
|
53
|
-
console.log(`[connect] room=${roomId} session=${sessionId}`);
|
|
52
|
+
// console.log(`[connect] room=${roomId} session=${sessionId}`);
|
|
54
53
|
// Track this socket for control broadcasts (e.g. room-reset)
|
|
55
54
|
if (!this.roomSockets.has(roomId)) {
|
|
56
55
|
this.roomSockets.set(roomId, new Set());
|
|
@@ -95,13 +94,13 @@ export class RTCServer {
|
|
|
95
94
|
this.handleSyncRequest(ws, roomId, sessionId, data);
|
|
96
95
|
return;
|
|
97
96
|
}
|
|
98
|
-
if (data.mtype === '
|
|
97
|
+
if (data.mtype === 'crdt') {
|
|
99
98
|
msgQueue = msgQueue.then(() => this.handleCRDTMessage(ws, roomId, data.msg));
|
|
100
99
|
}
|
|
101
100
|
});
|
|
102
101
|
// Cleanup on close
|
|
103
102
|
ws.on('close', () => {
|
|
104
|
-
console.log(`[disconnect] room=${roomId} session=${sessionId}`);
|
|
103
|
+
// console.log(`[disconnect] room=${roomId} session=${sessionId}`);
|
|
105
104
|
unsubscribe();
|
|
106
105
|
this.roomSockets.get(roomId)?.delete(ws);
|
|
107
106
|
this.broker.setMember(roomId, sessionId, {
|
|
@@ -123,7 +122,7 @@ export class RTCServer {
|
|
|
123
122
|
const state = await this.journal.getStateForClient(roomId);
|
|
124
123
|
if (!state)
|
|
125
124
|
return;
|
|
126
|
-
console.log(`[state-transfer] room=${roomId} journal=${state.journal.length} msgs`);
|
|
125
|
+
// console.log(`[state-transfer] room=${roomId} journal=${state.journal.length} msgs`);
|
|
127
126
|
ws.send(serialize({
|
|
128
127
|
mtype: 'state',
|
|
129
128
|
snapshot: state.snapshot,
|
|
@@ -143,13 +142,13 @@ export class RTCServer {
|
|
|
143
142
|
if (!sockets || sockets.size === 0)
|
|
144
143
|
return;
|
|
145
144
|
const payload = serialize(msg);
|
|
146
|
-
console.log(`[broadcast-control] room=${roomId} type=${msg.mtype} clients=${sockets.size}`);
|
|
145
|
+
// console.log(`[broadcast-control] room=${roomId} type=${msg.mtype} clients=${sockets.size}`);
|
|
147
146
|
for (const ws of sockets) {
|
|
148
147
|
ws.send(payload);
|
|
149
148
|
}
|
|
150
149
|
}
|
|
151
150
|
deleteRoom(roomId) {
|
|
152
|
-
console.log(`[delete-room] room=${roomId} history=${this.messageHistory.get(roomId)?.length ?? 0} msgs`);
|
|
151
|
+
// console.log(`[delete-room] room=${roomId} history=${this.messageHistory.get(roomId)?.length ?? 0} msgs`);
|
|
153
152
|
this.messageHistory.delete(roomId);
|
|
154
153
|
// Note: roomSockets is NOT cleared here — sockets are still needed for
|
|
155
154
|
// broadcastControl (e.g. room-reset). They get cleaned up naturally
|
|
@@ -161,8 +160,8 @@ export class RTCServer {
|
|
|
161
160
|
* so existing clients can continue operating after they reset.
|
|
162
161
|
*/
|
|
163
162
|
clearRoom(roomId) {
|
|
164
|
-
const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
165
|
-
console.log(`[clear-room] room=${roomId} history=${historyLen} msgs`);
|
|
163
|
+
// const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
164
|
+
// console.log(`[clear-room] room=${roomId} history=${historyLen} msgs`);
|
|
166
165
|
this.messageHistory.set(roomId, []);
|
|
167
166
|
}
|
|
168
167
|
/**
|
|
@@ -182,7 +181,7 @@ export class RTCServer {
|
|
|
182
181
|
}
|
|
183
182
|
// ── Private ──────────────────────────────────────────────
|
|
184
183
|
async handleCRDTMessage(ws, roomId, msg) {
|
|
185
|
-
console.log(`[msg] room=${roomId} session=${msg.sessionId} lamport=${msg.lamportTime} ${summarizeOps(msg)}`);
|
|
184
|
+
// console.log(`[msg] room=${roomId} session=${msg.sessionId} lamport=${msg.lamportTime} ${summarizeOps(msg)}`);
|
|
186
185
|
// Persist / dedup if journal is available
|
|
187
186
|
if (this.journal) {
|
|
188
187
|
const result = await this.journal.processMessage(roomId, msg);
|
|
@@ -198,8 +197,8 @@ export class RTCServer {
|
|
|
198
197
|
await this.broker.publish(roomId, sequenced);
|
|
199
198
|
// Store in history for sync reconciliation
|
|
200
199
|
this.storeMessage(roomId, msg);
|
|
201
|
-
const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
202
|
-
console.log(`[broadcast] room=${roomId} msgId=${msg.id.slice(0, 12)}... seq=${serverSeq} history=${historyLen}`);
|
|
200
|
+
// const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
201
|
+
// console.log(`[broadcast] room=${roomId} msgId=${msg.id.slice(0, 12)}... seq=${serverSeq} history=${historyLen}`);
|
|
203
202
|
// Ack back to sender
|
|
204
203
|
ws.send(serialize({ mtype: 'ack', msgId: msg.id, serverSeq }));
|
|
205
204
|
}
|
|
@@ -214,7 +213,7 @@ export class RTCServer {
|
|
|
214
213
|
if (history.length > RTCServer.MAX_HISTORY_PER_ROOM) {
|
|
215
214
|
const keep = Math.floor(RTCServer.MAX_HISTORY_PER_ROOM / 2);
|
|
216
215
|
this.messageHistory.set(roomId, history.slice(-keep));
|
|
217
|
-
console.log(`[history-trim] room=${roomId} trimmed to ${keep} msgs`);
|
|
216
|
+
// console.log(`[history-trim] room=${roomId} trimmed to ${keep} msgs`);
|
|
218
217
|
}
|
|
219
218
|
}
|
|
220
219
|
/**
|
|
@@ -237,7 +236,7 @@ export class RTCServer {
|
|
|
237
236
|
handleSyncRequest(ws, roomId, sessionId, data) {
|
|
238
237
|
const history = this.messageHistory.get(roomId);
|
|
239
238
|
if (!history || history.length === 0) {
|
|
240
|
-
console.log(`[sync] room=${roomId} session=${sessionId} no history`);
|
|
239
|
+
// console.log(`[sync] room=${roomId} session=${sessionId} no history`);
|
|
241
240
|
return;
|
|
242
241
|
}
|
|
243
242
|
const clientClock = data.vectorClock ?? {};
|
|
@@ -259,7 +258,7 @@ export class RTCServer {
|
|
|
259
258
|
retransmitted++;
|
|
260
259
|
}
|
|
261
260
|
}
|
|
262
|
-
console.log(`[sync] room=${roomId} session=${sessionId} clientMsgs=${data.count} history=${history.length} retransmitted=${retransmitted}`);
|
|
261
|
+
// console.log(`[sync] room=${roomId} session=${sessionId} clientMsgs=${data.count} history=${history.length} retransmitted=${retransmitted}`);
|
|
263
262
|
}
|
|
264
263
|
handleHeartbeat(roomId, sessionId, vectorClock) {
|
|
265
264
|
this.broker.setMember(roomId, sessionId, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RTCServer.js","sourceRoot":"","sources":["../../src/transport/RTCServer.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAGH,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAcxE,wDAAwD;AACxD,SAAS,YAAY,CAAC,IAAyB;IAC7C,IAAI,IAAI,YAAY,UAAU;QAAE,OAAO,IAAI,CAAC;IAC5C,IAAI,IAAI,YAAY,WAAW;QAAE,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;IAC7D,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QAC3D,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,IAAI,CAAC,CAAC,sBAAsB;AACrC,CAAC;AAED,
|
|
1
|
+
{"version":3,"file":"RTCServer.js","sourceRoot":"","sources":["../../src/transport/RTCServer.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/src/serve.ts
CHANGED
|
@@ -41,7 +41,7 @@ function ensureRoomDocument(roomId: string): Promise<string> {
|
|
|
41
41
|
const existing = await prisma.document.findFirst({ where: { name: roomId } });
|
|
42
42
|
if (existing) return existing.id;
|
|
43
43
|
const docId = await journalService.createDocument(roomId, 'system');
|
|
44
|
-
console.log(`[journal] created document ${docId} for room "${roomId}"`);
|
|
44
|
+
// console.log(`[journal] created document ${docId} for room "${roomId}"`);
|
|
45
45
|
return docId;
|
|
46
46
|
})());
|
|
47
47
|
}
|
|
@@ -172,14 +172,14 @@ async function handleApi(req: IncomingMessage, res: ServerResponse): Promise<voi
|
|
|
172
172
|
try {
|
|
173
173
|
const docId = await docPromise;
|
|
174
174
|
await journalService.clearDocument(docId);
|
|
175
|
-
console.log(`[api] cleared document ${docId} for room "${targetRoomId}"`);
|
|
175
|
+
// console.log(`[api] cleared document ${docId} for room "${targetRoomId}"`);
|
|
176
176
|
} catch (e: any) {
|
|
177
177
|
console.warn(`[api] clear doc error:`, e);
|
|
178
178
|
}
|
|
179
179
|
}
|
|
180
180
|
// Broadcast room-reset AFTER state is fully cleared
|
|
181
181
|
rtcServer.broadcastControl(targetRoomId, { mtype: 'room-reset' });
|
|
182
|
-
console.log(`[api] cleared room "${targetRoomId}"`);
|
|
182
|
+
// console.log(`[api] cleared room "${targetRoomId}"`);
|
|
183
183
|
json(res, { ok: true, roomId: targetRoomId });
|
|
184
184
|
return;
|
|
185
185
|
}
|
|
@@ -236,5 +236,5 @@ wss.on('connection', (ws, req) => {
|
|
|
236
236
|
});
|
|
237
237
|
|
|
238
238
|
server.listen(PORT, () => {
|
|
239
|
-
console.log(`vuer-rtc server listening on http://localhost:${PORT}`);
|
|
239
|
+
// console.log(`vuer-rtc server listening on http://localhost:${PORT}`);
|
|
240
240
|
});
|
|
@@ -37,13 +37,13 @@ function toUint8Array(data: BinaryData | string): Uint8Array | null {
|
|
|
37
37
|
return null; // string — not binary
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
/** Summarize a CRDTMessage's ops for logging. */
|
|
41
|
-
function summarizeOps(msg: CRDTMessage): string {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
40
|
+
// /** Summarize a CRDTMessage's ops for logging. */
|
|
41
|
+
// function summarizeOps(msg: CRDTMessage): string {
|
|
42
|
+
// if (!msg.ops || msg.ops.length === 0) return 'empty';
|
|
43
|
+
// const first = msg.ops[0];
|
|
44
|
+
// const summary = `${first.otype} ${first.key}.${first.path}`;
|
|
45
|
+
// return msg.ops.length > 1 ? `${summary} (+${msg.ops.length - 1} more)` : summary;
|
|
46
|
+
// }
|
|
47
47
|
|
|
48
48
|
export class RTCServer {
|
|
49
49
|
/** Per-room message history for sync reconciliation. */
|
|
@@ -66,7 +66,7 @@ export class RTCServer {
|
|
|
66
66
|
* Call this once per connection after the WS upgrade completes.
|
|
67
67
|
*/
|
|
68
68
|
handleConnection(ws: MinimalWebSocket, roomId: string, sessionId: string): void {
|
|
69
|
-
console.log(`[connect] room=${roomId} session=${sessionId}`);
|
|
69
|
+
// console.log(`[connect] room=${roomId} session=${sessionId}`);
|
|
70
70
|
|
|
71
71
|
// Track this socket for control broadcasts (e.g. room-reset)
|
|
72
72
|
if (!this.roomSockets.has(roomId)) {
|
|
@@ -115,7 +115,7 @@ export class RTCServer {
|
|
|
115
115
|
return;
|
|
116
116
|
}
|
|
117
117
|
|
|
118
|
-
if (data.mtype === '
|
|
118
|
+
if (data.mtype === 'crdt') {
|
|
119
119
|
msgQueue = msgQueue.then(() =>
|
|
120
120
|
this.handleCRDTMessage(ws, roomId, data.msg)
|
|
121
121
|
);
|
|
@@ -124,7 +124,7 @@ export class RTCServer {
|
|
|
124
124
|
|
|
125
125
|
// Cleanup on close
|
|
126
126
|
ws.on('close', () => {
|
|
127
|
-
console.log(`[disconnect] room=${roomId} session=${sessionId}`);
|
|
127
|
+
// console.log(`[disconnect] room=${roomId} session=${sessionId}`);
|
|
128
128
|
unsubscribe();
|
|
129
129
|
this.roomSockets.get(roomId)?.delete(ws);
|
|
130
130
|
this.broker.setMember(roomId, sessionId, {
|
|
@@ -147,7 +147,7 @@ export class RTCServer {
|
|
|
147
147
|
const state = await this.journal.getStateForClient(roomId);
|
|
148
148
|
if (!state) return;
|
|
149
149
|
|
|
150
|
-
console.log(`[state-transfer] room=${roomId} journal=${state.journal.length} msgs`);
|
|
150
|
+
// console.log(`[state-transfer] room=${roomId} journal=${state.journal.length} msgs`);
|
|
151
151
|
ws.send(serialize({
|
|
152
152
|
mtype: 'state',
|
|
153
153
|
snapshot: state.snapshot,
|
|
@@ -167,14 +167,14 @@ export class RTCServer {
|
|
|
167
167
|
const sockets = this.roomSockets.get(roomId);
|
|
168
168
|
if (!sockets || sockets.size === 0) return;
|
|
169
169
|
const payload = serialize(msg);
|
|
170
|
-
console.log(`[broadcast-control] room=${roomId} type=${msg.mtype} clients=${sockets.size}`);
|
|
170
|
+
// console.log(`[broadcast-control] room=${roomId} type=${msg.mtype} clients=${sockets.size}`);
|
|
171
171
|
for (const ws of sockets) {
|
|
172
172
|
ws.send(payload);
|
|
173
173
|
}
|
|
174
174
|
}
|
|
175
175
|
|
|
176
176
|
deleteRoom(roomId: string): void {
|
|
177
|
-
console.log(`[delete-room] room=${roomId} history=${this.messageHistory.get(roomId)?.length ?? 0} msgs`);
|
|
177
|
+
// console.log(`[delete-room] room=${roomId} history=${this.messageHistory.get(roomId)?.length ?? 0} msgs`);
|
|
178
178
|
this.messageHistory.delete(roomId);
|
|
179
179
|
// Note: roomSockets is NOT cleared here — sockets are still needed for
|
|
180
180
|
// broadcastControl (e.g. room-reset). They get cleaned up naturally
|
|
@@ -187,8 +187,8 @@ export class RTCServer {
|
|
|
187
187
|
* so existing clients can continue operating after they reset.
|
|
188
188
|
*/
|
|
189
189
|
clearRoom(roomId: string): void {
|
|
190
|
-
const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
191
|
-
console.log(`[clear-room] room=${roomId} history=${historyLen} msgs`);
|
|
190
|
+
// const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
191
|
+
// console.log(`[clear-room] room=${roomId} history=${historyLen} msgs`);
|
|
192
192
|
this.messageHistory.set(roomId, []);
|
|
193
193
|
}
|
|
194
194
|
|
|
@@ -212,13 +212,12 @@ export class RTCServer {
|
|
|
212
212
|
}
|
|
213
213
|
|
|
214
214
|
// ── Private ──────────────────────────────────────────────
|
|
215
|
-
|
|
216
215
|
private async handleCRDTMessage(
|
|
217
216
|
ws: MinimalWebSocket,
|
|
218
217
|
roomId: string,
|
|
219
218
|
msg: CRDTMessage,
|
|
220
219
|
): Promise<void> {
|
|
221
|
-
console.log(`[msg] room=${roomId} session=${msg.sessionId} lamport=${msg.lamportTime} ${summarizeOps(msg)}`);
|
|
220
|
+
// console.log(`[msg] room=${roomId} session=${msg.sessionId} lamport=${msg.lamportTime} ${summarizeOps(msg)}`);
|
|
222
221
|
|
|
223
222
|
// Persist / dedup if journal is available
|
|
224
223
|
if (this.journal) {
|
|
@@ -238,8 +237,8 @@ export class RTCServer {
|
|
|
238
237
|
// Store in history for sync reconciliation
|
|
239
238
|
this.storeMessage(roomId, msg);
|
|
240
239
|
|
|
241
|
-
const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
242
|
-
console.log(`[broadcast] room=${roomId} msgId=${msg.id.slice(0, 12)}... seq=${serverSeq} history=${historyLen}`);
|
|
240
|
+
// const historyLen = this.messageHistory.get(roomId)?.length ?? 0;
|
|
241
|
+
// console.log(`[broadcast] room=${roomId} msgId=${msg.id.slice(0, 12)}... seq=${serverSeq} history=${historyLen}`);
|
|
243
242
|
|
|
244
243
|
// Ack back to sender
|
|
245
244
|
ws.send(serialize({ mtype: 'ack', msgId: msg.id, serverSeq }));
|
|
@@ -257,7 +256,7 @@ export class RTCServer {
|
|
|
257
256
|
if (history.length > RTCServer.MAX_HISTORY_PER_ROOM) {
|
|
258
257
|
const keep = Math.floor(RTCServer.MAX_HISTORY_PER_ROOM / 2);
|
|
259
258
|
this.messageHistory.set(roomId, history.slice(-keep));
|
|
260
|
-
console.log(`[history-trim] room=${roomId} trimmed to ${keep} msgs`);
|
|
259
|
+
// console.log(`[history-trim] room=${roomId} trimmed to ${keep} msgs`);
|
|
261
260
|
}
|
|
262
261
|
}
|
|
263
262
|
|
|
@@ -286,7 +285,7 @@ export class RTCServer {
|
|
|
286
285
|
): void {
|
|
287
286
|
const history = this.messageHistory.get(roomId);
|
|
288
287
|
if (!history || history.length === 0) {
|
|
289
|
-
console.log(`[sync] room=${roomId} session=${sessionId} no history`);
|
|
288
|
+
// console.log(`[sync] room=${roomId} session=${sessionId} no history`);
|
|
290
289
|
return;
|
|
291
290
|
}
|
|
292
291
|
|
|
@@ -309,7 +308,7 @@ export class RTCServer {
|
|
|
309
308
|
}
|
|
310
309
|
}
|
|
311
310
|
|
|
312
|
-
console.log(`[sync] room=${roomId} session=${sessionId} clientMsgs=${data.count} history=${history.length} retransmitted=${retransmitted}`);
|
|
311
|
+
// console.log(`[sync] room=${roomId} session=${sessionId} clientMsgs=${data.count} history=${history.length} retransmitted=${retransmitted}`);
|
|
313
312
|
}
|
|
314
313
|
|
|
315
314
|
private handleHeartbeat(
|
|
@@ -144,7 +144,7 @@ export function createTestServer(): TestServer {
|
|
|
144
144
|
const store = createGraph({
|
|
145
145
|
sessionId,
|
|
146
146
|
onSend: (msg: CRDTMessage) => {
|
|
147
|
-
clientWs.send(serialize({ mtype: '
|
|
147
|
+
clientWs.send(serialize({ mtype: 'crdt', msg }));
|
|
148
148
|
},
|
|
149
149
|
});
|
|
150
150
|
|
|
@@ -175,7 +175,7 @@ export function createTestServer(): TestServer {
|
|
|
175
175
|
const retryUnacked = () => {
|
|
176
176
|
const unacked = getUnackedMessages(store.getState());
|
|
177
177
|
for (const msg of unacked) {
|
|
178
|
-
clientWs.send(serialize({ mtype: '
|
|
178
|
+
clientWs.send(serialize({ mtype: 'crdt', msg }));
|
|
179
179
|
}
|
|
180
180
|
};
|
|
181
181
|
|