@silicaclaw/cli 2026.3.20-2 → 2026.3.20-21
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/CHANGELOG.md +108 -0
- package/INSTALL.md +13 -7
- package/README.md +60 -12
- package/VERSION +1 -1
- package/apps/local-console/dist/apps/local-console/src/server.d.ts +139 -3
- package/apps/local-console/dist/apps/local-console/src/server.js +1029 -92
- package/apps/local-console/dist/packages/core/src/index.d.ts +2 -0
- package/apps/local-console/dist/packages/core/src/index.js +2 -0
- package/apps/local-console/dist/packages/core/src/privateCrypto.d.ts +17 -0
- package/apps/local-console/dist/packages/core/src/privateCrypto.js +40 -0
- package/apps/local-console/dist/packages/core/src/privateMessage.d.ts +23 -0
- package/apps/local-console/dist/packages/core/src/privateMessage.js +74 -0
- package/apps/local-console/dist/packages/core/src/profile.js +2 -0
- package/apps/local-console/dist/packages/core/src/publicProfileSummary.d.ts +4 -0
- package/apps/local-console/dist/packages/core/src/publicProfileSummary.js +3 -0
- package/apps/local-console/dist/packages/core/src/types.d.ts +40 -0
- package/apps/local-console/dist/packages/network/src/relayPreview.d.ts +12 -0
- package/apps/local-console/dist/packages/network/src/relayPreview.js +108 -8
- package/apps/local-console/dist/packages/network/src/types.d.ts +4 -0
- package/apps/local-console/dist/packages/storage/src/repos.d.ts +27 -1
- package/apps/local-console/dist/packages/storage/src/repos.js +35 -1
- package/apps/local-console/public/app/app.js +502 -11
- package/apps/local-console/public/app/events.js +21 -0
- package/apps/local-console/public/app/network.js +144 -32
- package/apps/local-console/public/app/overview.js +57 -27
- package/apps/local-console/public/app/social.js +342 -105
- package/apps/local-console/public/app/styles.css +149 -43
- package/apps/local-console/public/app/template.js +196 -100
- package/apps/local-console/public/app/translations.js +438 -316
- package/apps/local-console/src/server.ts +1177 -90
- package/apps/public-explorer/public/app/template.js +2 -2
- package/apps/public-explorer/public/app/translations.js +36 -36
- package/docs/NEW_USER_OPERATIONS.md +5 -5
- package/docs/OPENCLAW_BRIDGE.md +7 -7
- package/docs/OPENCLAW_BRIDGE_ZH.md +6 -6
- package/node_modules/@silicaclaw/core/dist/packages/core/src/index.d.ts +2 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/index.js +2 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/privateCrypto.d.ts +17 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/privateCrypto.js +40 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/privateMessage.d.ts +23 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/privateMessage.js +74 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/profile.js +2 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/publicProfileSummary.d.ts +4 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/publicProfileSummary.js +3 -0
- package/node_modules/@silicaclaw/core/dist/packages/core/src/types.d.ts +40 -0
- package/node_modules/@silicaclaw/core/package.json +2 -2
- package/node_modules/@silicaclaw/core/src/index.ts +2 -0
- package/node_modules/@silicaclaw/core/src/privateCrypto.ts +57 -0
- package/node_modules/@silicaclaw/core/src/privateMessage.ts +101 -0
- package/node_modules/@silicaclaw/core/src/profile.ts +2 -0
- package/node_modules/@silicaclaw/core/src/publicProfileSummary.ts +7 -0
- package/node_modules/@silicaclaw/core/src/types.ts +44 -0
- package/node_modules/@silicaclaw/network/dist/packages/network/src/relayPreview.d.ts +12 -0
- package/node_modules/@silicaclaw/network/dist/packages/network/src/relayPreview.js +108 -8
- package/node_modules/@silicaclaw/network/dist/packages/network/src/types.d.ts +4 -0
- package/node_modules/@silicaclaw/network/src/relayPreview.ts +120 -10
- package/node_modules/@silicaclaw/network/src/types.ts +2 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/index.d.ts +2 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/index.js +2 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/privateCrypto.d.ts +17 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/privateCrypto.js +40 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/privateMessage.d.ts +23 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/privateMessage.js +74 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/profile.js +2 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/publicProfileSummary.d.ts +4 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/publicProfileSummary.js +3 -0
- package/node_modules/@silicaclaw/storage/dist/packages/core/src/types.d.ts +40 -0
- package/node_modules/@silicaclaw/storage/dist/packages/storage/src/repos.d.ts +27 -1
- package/node_modules/@silicaclaw/storage/dist/packages/storage/src/repos.js +35 -1
- package/node_modules/@silicaclaw/storage/package.json +2 -2
- package/node_modules/@silicaclaw/storage/src/repos.ts +59 -1
- package/openclaw-skills/silicaclaw-bridge-setup/SKILL.md +18 -0
- package/openclaw-skills/silicaclaw-bridge-setup/VERSION +1 -1
- package/openclaw-skills/silicaclaw-bridge-setup/manifest.json +2 -2
- package/openclaw-skills/silicaclaw-broadcast/SKILL.md +18 -0
- package/openclaw-skills/silicaclaw-broadcast/VERSION +1 -1
- package/openclaw-skills/silicaclaw-broadcast/manifest.json +2 -2
- package/openclaw-skills/silicaclaw-network-config/SKILL.md +158 -0
- package/openclaw-skills/silicaclaw-network-config/VERSION +1 -0
- package/openclaw-skills/silicaclaw-network-config/agents/openai.yaml +6 -0
- package/openclaw-skills/silicaclaw-network-config/manifest.json +27 -0
- package/openclaw-skills/silicaclaw-network-config/references/network-modes.md +22 -0
- package/openclaw-skills/silicaclaw-network-config/references/owner-dialogue-cheatsheet-zh.md +47 -0
- package/openclaw-skills/silicaclaw-network-config/references/public-discovery.md +22 -0
- package/openclaw-skills/silicaclaw-owner-push/SKILL.md +18 -0
- package/openclaw-skills/silicaclaw-owner-push/VERSION +1 -1
- package/openclaw-skills/silicaclaw-owner-push/manifest.json +2 -2
- package/openclaw-skills/silicaclaw-owner-push/references/runtime-setup.md +3 -0
- package/openclaw-skills/silicaclaw-owner-push/scripts/owner-push-forwarder.mjs +151 -9
- package/package.json +1 -1
- package/packages/core/dist/packages/core/src/index.d.ts +2 -0
- package/packages/core/dist/packages/core/src/index.js +2 -0
- package/packages/core/dist/packages/core/src/privateCrypto.d.ts +17 -0
- package/packages/core/dist/packages/core/src/privateCrypto.js +40 -0
- package/packages/core/dist/packages/core/src/privateMessage.d.ts +23 -0
- package/packages/core/dist/packages/core/src/privateMessage.js +74 -0
- package/packages/core/dist/packages/core/src/profile.js +2 -0
- package/packages/core/dist/packages/core/src/publicProfileSummary.d.ts +4 -0
- package/packages/core/dist/packages/core/src/publicProfileSummary.js +3 -0
- package/packages/core/dist/packages/core/src/types.d.ts +40 -0
- package/packages/core/package.json +2 -2
- package/packages/core/src/index.ts +2 -0
- package/packages/core/src/privateCrypto.ts +57 -0
- package/packages/core/src/privateMessage.ts +101 -0
- package/packages/core/src/profile.ts +2 -0
- package/packages/core/src/publicProfileSummary.ts +7 -0
- package/packages/core/src/types.ts +44 -0
- package/packages/network/dist/packages/network/src/relayPreview.d.ts +12 -0
- package/packages/network/dist/packages/network/src/relayPreview.js +108 -8
- package/packages/network/dist/packages/network/src/types.d.ts +4 -0
- package/packages/network/src/relayPreview.ts +120 -10
- package/packages/network/src/types.ts +2 -0
- package/packages/storage/dist/packages/core/src/index.d.ts +2 -0
- package/packages/storage/dist/packages/core/src/index.js +2 -0
- package/packages/storage/dist/packages/core/src/privateCrypto.d.ts +17 -0
- package/packages/storage/dist/packages/core/src/privateCrypto.js +40 -0
- package/packages/storage/dist/packages/core/src/privateMessage.d.ts +23 -0
- package/packages/storage/dist/packages/core/src/privateMessage.js +74 -0
- package/packages/storage/dist/packages/core/src/profile.js +2 -0
- package/packages/storage/dist/packages/core/src/publicProfileSummary.d.ts +4 -0
- package/packages/storage/dist/packages/core/src/publicProfileSummary.js +3 -0
- package/packages/storage/dist/packages/core/src/types.d.ts +40 -0
- package/packages/storage/dist/packages/storage/src/repos.d.ts +27 -1
- package/packages/storage/dist/packages/storage/src/repos.js +35 -1
- package/packages/storage/package.json +2 -2
- package/packages/storage/src/repos.ts +59 -1
- package/scripts/silicaclaw-cli.mjs +4 -1
- package/scripts/silicaclaw-gateway.mjs +114 -2
- package/scripts/validate-openclaw-skill.mjs +19 -0
- package/node_modules/@silicaclaw/storage/dist/index.d.ts +0 -3
- package/node_modules/@silicaclaw/storage/dist/index.js +0 -19
- package/node_modules/@silicaclaw/storage/dist/jsonRepo.d.ts +0 -7
- package/node_modules/@silicaclaw/storage/dist/jsonRepo.js +0 -29
- package/node_modules/@silicaclaw/storage/dist/repos.d.ts +0 -61
- package/node_modules/@silicaclaw/storage/dist/repos.js +0 -67
- package/node_modules/@silicaclaw/storage/dist/socialRuntimeRepo.d.ts +0 -5
- package/node_modules/@silicaclaw/storage/dist/socialRuntimeRepo.js +0 -57
- package/packages/storage/dist/index.d.ts +0 -3
- package/packages/storage/dist/index.js +0 -19
- package/packages/storage/dist/jsonRepo.d.ts +0 -7
- package/packages/storage/dist/jsonRepo.js +0 -29
- package/packages/storage/dist/repos.d.ts +0 -61
- package/packages/storage/dist/repos.js +0 -67
- package/packages/storage/dist/socialRuntimeRepo.d.ts +0 -5
- package/packages/storage/dist/socialRuntimeRepo.js +0 -57
|
@@ -34,6 +34,10 @@ type RelayPeer = {
|
|
|
34
34
|
last_seen_at: number;
|
|
35
35
|
messages_seen: number;
|
|
36
36
|
reconnect_attempts: number;
|
|
37
|
+
meta?: {
|
|
38
|
+
signal_queue_size?: number;
|
|
39
|
+
relay_queue_size?: number;
|
|
40
|
+
};
|
|
37
41
|
};
|
|
38
42
|
|
|
39
43
|
type RelayDiagnostics = {
|
|
@@ -144,7 +148,8 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
144
148
|
|
|
145
149
|
private started = false;
|
|
146
150
|
private poller: NodeJS.Timeout | null = null;
|
|
147
|
-
private handlers = new Map<string, Set<(data: any) => void>>();
|
|
151
|
+
private handlers = new Map<string, Set<(data: any, meta?: { peerId?: string }) => void>>();
|
|
152
|
+
private directHandlers = new Map<string, Set<(data: any, meta?: { peerId?: string }) => void>>();
|
|
148
153
|
private peers = new Map<string, RelayPeer>();
|
|
149
154
|
private seenMessageIds = new Set<string>();
|
|
150
155
|
private activeEndpoint = "";
|
|
@@ -227,7 +232,6 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
227
232
|
try {
|
|
228
233
|
await this.joinRoom("start");
|
|
229
234
|
this.started = true;
|
|
230
|
-
await this.refreshPeers();
|
|
231
235
|
await this.pollOnce();
|
|
232
236
|
this.scheduleNextPoll(this.pollIntervalMs);
|
|
233
237
|
this.recordDiscovery("signaling_connected", { endpoint: this.activeEndpoint });
|
|
@@ -281,7 +285,43 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
281
285
|
if (!this.handlers.has(key)) {
|
|
282
286
|
this.handlers.set(key, new Set());
|
|
283
287
|
}
|
|
284
|
-
this.handlers.get(key)?.add(handler);
|
|
288
|
+
this.handlers.get(key)?.add(handler as (data: any, meta?: { peerId?: string }) => void);
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
async sendDirect(peerId: string, topic: string, data: any): Promise<void> {
|
|
292
|
+
if (!this.started) return;
|
|
293
|
+
const targetPeerId = String(peerId || "").trim();
|
|
294
|
+
if (!targetPeerId) return;
|
|
295
|
+
await this.maybeRefreshJoin("direct_send");
|
|
296
|
+
const envelope: NetworkMessageEnvelope = {
|
|
297
|
+
version: 1,
|
|
298
|
+
message_id: randomUUID(),
|
|
299
|
+
topic: `${this.namespace}:${topic}`,
|
|
300
|
+
source_peer_id: this.peerId,
|
|
301
|
+
timestamp: Date.now(),
|
|
302
|
+
payload: this.topicCodec.encode(topic, data),
|
|
303
|
+
};
|
|
304
|
+
const raw = this.envelopeCodec.encode(envelope);
|
|
305
|
+
if (raw.length > this.maxMessageBytes) {
|
|
306
|
+
this.stats.dropped_oversized += 1;
|
|
307
|
+
return;
|
|
308
|
+
}
|
|
309
|
+
await this.post("/direct/send", {
|
|
310
|
+
room: this.room,
|
|
311
|
+
from_peer_id: this.peerId,
|
|
312
|
+
to_peer_id: targetPeerId,
|
|
313
|
+
envelope,
|
|
314
|
+
});
|
|
315
|
+
this.lastPublishAt = Date.now();
|
|
316
|
+
this.signalingMessagesSentTotal += 1;
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
subscribeDirect(topic: string, handler: (data: any, meta?: { peerId?: string }) => void): void {
|
|
320
|
+
const key = `${this.namespace}:${topic}`;
|
|
321
|
+
if (!this.directHandlers.has(key)) {
|
|
322
|
+
this.directHandlers.set(key, new Set());
|
|
323
|
+
}
|
|
324
|
+
this.directHandlers.get(key)?.add(handler);
|
|
285
325
|
}
|
|
286
326
|
|
|
287
327
|
getDiagnostics(): RelayDiagnostics {
|
|
@@ -354,6 +394,15 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
354
394
|
this.signalingMessagesReceivedTotal += 1;
|
|
355
395
|
this.onEnvelope(message?.envelope);
|
|
356
396
|
}
|
|
397
|
+
let directMessages = Array.isArray(payload?.direct_messages) ? payload.direct_messages : null;
|
|
398
|
+
if (!directMessages) {
|
|
399
|
+
const directPayload = await this.get(`/direct/poll?room=${encodeURIComponent(this.room)}&peer_id=${encodeURIComponent(this.peerId)}`);
|
|
400
|
+
directMessages = Array.isArray(directPayload?.messages) ? directPayload.messages : [];
|
|
401
|
+
}
|
|
402
|
+
for (const message of directMessages) {
|
|
403
|
+
this.signalingMessagesReceivedTotal += 1;
|
|
404
|
+
this.onDirectEnvelope(message?.envelope, { peerId: String(message?.from_peer_id || "") || undefined });
|
|
405
|
+
}
|
|
357
406
|
if (Array.isArray(payload?.peers)) {
|
|
358
407
|
this.updatePeersFromList(payload.peers);
|
|
359
408
|
} else if (!this.lastPeerRefreshAt || Date.now() - this.lastPeerRefreshAt >= this.peerRefreshIntervalMs) {
|
|
@@ -375,11 +424,25 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
375
424
|
const payload = await this.get(`/peers?room=${encodeURIComponent(this.room)}`);
|
|
376
425
|
this.lastPeerRefreshAt = Date.now();
|
|
377
426
|
this.stats.peers_refresh_succeeded += 1;
|
|
378
|
-
const
|
|
379
|
-
|
|
427
|
+
const peerItems = Array.isArray(payload?.peer_details) && payload.peer_details.length
|
|
428
|
+
? payload.peer_details
|
|
429
|
+
: Array.isArray(payload?.peers) ? payload.peers : [];
|
|
430
|
+
this.updatePeersFromList(peerItems);
|
|
380
431
|
}
|
|
381
432
|
|
|
382
433
|
private onEnvelope(envelope: unknown): void {
|
|
434
|
+
this.dispatchEnvelope(envelope, this.handlers);
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
private onDirectEnvelope(envelope: unknown, meta?: { peerId?: string }): void {
|
|
438
|
+
this.dispatchEnvelope(envelope, this.directHandlers, meta);
|
|
439
|
+
}
|
|
440
|
+
|
|
441
|
+
private dispatchEnvelope(
|
|
442
|
+
envelope: unknown,
|
|
443
|
+
handlersByTopic: Map<string, Set<(data: any, meta?: { peerId?: string }) => void>>,
|
|
444
|
+
meta?: { peerId?: string }
|
|
445
|
+
): void {
|
|
383
446
|
this.stats.received_total += 1;
|
|
384
447
|
const validated = validateNetworkMessageEnvelope(envelope, {
|
|
385
448
|
max_future_drift_ms: this.maxFutureDriftMs,
|
|
@@ -416,7 +479,7 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
416
479
|
|
|
417
480
|
const topicKey = message.topic;
|
|
418
481
|
const topic = topicKey.slice(this.namespace.length + 1);
|
|
419
|
-
const handlers =
|
|
482
|
+
const handlers = handlersByTopic.get(topicKey);
|
|
420
483
|
if (!handlers || handlers.size === 0) return;
|
|
421
484
|
|
|
422
485
|
const peer = this.peers.get(message.source_peer_id);
|
|
@@ -434,7 +497,7 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
434
497
|
}
|
|
435
498
|
for (const handler of handlers) {
|
|
436
499
|
try {
|
|
437
|
-
handler(payload);
|
|
500
|
+
handler(payload, meta || { peerId: message.source_peer_id });
|
|
438
501
|
this.stats.delivered_total += 1;
|
|
439
502
|
} catch {
|
|
440
503
|
this.stats.dropped_handler_error += 1;
|
|
@@ -457,9 +520,13 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
457
520
|
|
|
458
521
|
private async joinRoom(reason: string): Promise<void> {
|
|
459
522
|
this.stats.join_attempted += 1;
|
|
460
|
-
await this.post("/join", { room: this.room, peer_id: this.peerId });
|
|
523
|
+
const payload = await this.post("/join", { room: this.room, peer_id: this.peerId });
|
|
461
524
|
this.lastJoinAt = Date.now();
|
|
462
525
|
this.stats.join_succeeded += 1;
|
|
526
|
+
if (Array.isArray(payload?.peers)) {
|
|
527
|
+
this.updatePeersFromList(payload.peers);
|
|
528
|
+
this.lastPeerRefreshAt = this.lastJoinAt;
|
|
529
|
+
}
|
|
463
530
|
this.recordDiscovery("join_ok", { endpoint: this.activeEndpoint, detail: reason });
|
|
464
531
|
}
|
|
465
532
|
|
|
@@ -467,6 +534,7 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
467
534
|
if (!this.lastJoinAt || Date.now() - this.lastJoinAt > Math.max(45_000, this.pollIntervalMs * 6)) {
|
|
468
535
|
await this.joinRoom(reason);
|
|
469
536
|
}
|
|
537
|
+
this.ensurePollingAlive(reason);
|
|
470
538
|
}
|
|
471
539
|
|
|
472
540
|
private async get(path: string): Promise<any> {
|
|
@@ -527,13 +595,38 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
527
595
|
}
|
|
528
596
|
|
|
529
597
|
private updatePeersFromList(values: unknown[]): void {
|
|
530
|
-
const
|
|
598
|
+
const parsedPeers: Array<{ peer_id: string; meta?: RelayPeer["meta"] }> = [];
|
|
599
|
+
for (const value of values) {
|
|
600
|
+
if (typeof value === "string") {
|
|
601
|
+
const peerId = String(value || "").trim();
|
|
602
|
+
if (peerId) {
|
|
603
|
+
parsedPeers.push({ peer_id: peerId });
|
|
604
|
+
}
|
|
605
|
+
continue;
|
|
606
|
+
}
|
|
607
|
+
if (value && typeof value === "object") {
|
|
608
|
+
const raw = value as Record<string, unknown>;
|
|
609
|
+
const peerId = String(raw.peer_id || "").trim();
|
|
610
|
+
if (!peerId) {
|
|
611
|
+
continue;
|
|
612
|
+
}
|
|
613
|
+
parsedPeers.push({
|
|
614
|
+
peer_id: peerId,
|
|
615
|
+
meta: {
|
|
616
|
+
signal_queue_size: Number(raw.signal_queue_size ?? 0),
|
|
617
|
+
relay_queue_size: Number(raw.relay_queue_size ?? 0),
|
|
618
|
+
},
|
|
619
|
+
});
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
const peerIds = parsedPeers.map((peer) => peer.peer_id);
|
|
531
623
|
if (!peerIds.includes(this.peerId)) {
|
|
532
624
|
void this.joinRoom("self_missing_from_peers").catch(() => {});
|
|
533
625
|
}
|
|
534
626
|
const now = Date.now();
|
|
535
627
|
const next = new Map<string, RelayPeer>();
|
|
536
|
-
for (const
|
|
628
|
+
for (const peerInfo of parsedPeers) {
|
|
629
|
+
const peerId = peerInfo.peer_id;
|
|
537
630
|
if (peerId === this.peerId) continue;
|
|
538
631
|
const existing = this.peers.get(peerId);
|
|
539
632
|
if (!existing) {
|
|
@@ -546,6 +639,7 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
546
639
|
last_seen_at: now,
|
|
547
640
|
messages_seen: existing?.messages_seen ?? 0,
|
|
548
641
|
reconnect_attempts: existing?.reconnect_attempts ?? 0,
|
|
642
|
+
meta: peerInfo.meta || existing?.meta,
|
|
549
643
|
});
|
|
550
644
|
}
|
|
551
645
|
for (const peerId of this.peers.keys()) {
|
|
@@ -565,4 +659,20 @@ export class RelayPreviewAdapter implements NetworkAdapter {
|
|
|
565
659
|
this.pollOnce().catch(() => {});
|
|
566
660
|
}, Math.max(1000, delayMs + jitterMs));
|
|
567
661
|
}
|
|
662
|
+
|
|
663
|
+
private ensurePollingAlive(reason: string): void {
|
|
664
|
+
if (!this.started) return;
|
|
665
|
+
const pollStaleMs = Math.max(45_000, this.pollIntervalMs * 6);
|
|
666
|
+
const pollMissing = !this.poller;
|
|
667
|
+
const pollStale = Boolean(this.lastPollAt) && Date.now() - this.lastPollAt > pollStaleMs;
|
|
668
|
+
if (!pollMissing && !pollStale) {
|
|
669
|
+
return;
|
|
670
|
+
}
|
|
671
|
+
this.recordDiscovery("poll_recover_scheduled", {
|
|
672
|
+
endpoint: this.activeEndpoint,
|
|
673
|
+
detail: `${reason}:${pollMissing ? "missing" : "stale"}`,
|
|
674
|
+
});
|
|
675
|
+
this.currentPollDelayMs = this.pollIntervalMs;
|
|
676
|
+
this.scheduleNextPoll(0);
|
|
677
|
+
}
|
|
568
678
|
}
|
|
@@ -3,4 +3,6 @@ export interface NetworkAdapter {
|
|
|
3
3
|
stop(): Promise<void>;
|
|
4
4
|
publish(topic: string, data: any): Promise<void>;
|
|
5
5
|
subscribe(topic: string, handler: (data: any) => void): void;
|
|
6
|
+
sendDirect?(peerId: string, topic: string, data: any): Promise<void>;
|
|
7
|
+
subscribeDirect?(topic: string, handler: (data: any, meta?: { peerId?: string }) => void): void;
|
|
6
8
|
}
|
|
@@ -4,6 +4,8 @@ export * from "./identity";
|
|
|
4
4
|
export * from "./profile";
|
|
5
5
|
export * from "./presence";
|
|
6
6
|
export * from "./socialMessage";
|
|
7
|
+
export * from "./privateCrypto";
|
|
8
|
+
export * from "./privateMessage";
|
|
7
9
|
export * from "./indexing";
|
|
8
10
|
export * from "./directory";
|
|
9
11
|
export * from "./publicProfileSummary";
|
|
@@ -20,6 +20,8 @@ __exportStar(require("./identity"), exports);
|
|
|
20
20
|
__exportStar(require("./profile"), exports);
|
|
21
21
|
__exportStar(require("./presence"), exports);
|
|
22
22
|
__exportStar(require("./socialMessage"), exports);
|
|
23
|
+
__exportStar(require("./privateCrypto"), exports);
|
|
24
|
+
__exportStar(require("./privateMessage"), exports);
|
|
23
25
|
__exportStar(require("./indexing"), exports);
|
|
24
26
|
__exportStar(require("./directory"), exports);
|
|
25
27
|
__exportStar(require("./publicProfileSummary"), exports);
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { PrivateEncryptionKeyPair } from "./types";
|
|
2
|
+
export declare function createPrivateEncryptionKeyPair(now?: number): PrivateEncryptionKeyPair;
|
|
3
|
+
export declare function encryptPrivatePayload(input: {
|
|
4
|
+
plaintext: string;
|
|
5
|
+
recipient_public_key: string;
|
|
6
|
+
sender_keypair?: PrivateEncryptionKeyPair | null;
|
|
7
|
+
}): {
|
|
8
|
+
ciphertext: string;
|
|
9
|
+
nonce: string;
|
|
10
|
+
sender_encryption_public_key: string;
|
|
11
|
+
};
|
|
12
|
+
export declare function decryptPrivatePayload(input: {
|
|
13
|
+
ciphertext: string;
|
|
14
|
+
nonce: string;
|
|
15
|
+
sender_encryption_public_key: string;
|
|
16
|
+
recipient_private_key: string;
|
|
17
|
+
}): string | null;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createPrivateEncryptionKeyPair = createPrivateEncryptionKeyPair;
|
|
7
|
+
exports.encryptPrivatePayload = encryptPrivatePayload;
|
|
8
|
+
exports.decryptPrivatePayload = decryptPrivatePayload;
|
|
9
|
+
const tweetnacl_1 = __importDefault(require("tweetnacl"));
|
|
10
|
+
const crypto_1 = require("./crypto");
|
|
11
|
+
function createPrivateEncryptionKeyPair(now = Date.now()) {
|
|
12
|
+
const pair = tweetnacl_1.default.box.keyPair();
|
|
13
|
+
return {
|
|
14
|
+
public_key: (0, crypto_1.toBase64)(pair.publicKey),
|
|
15
|
+
private_key: (0, crypto_1.toBase64)(pair.secretKey),
|
|
16
|
+
created_at: now,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function encryptPrivatePayload(input) {
|
|
20
|
+
const sender = input.sender_keypair || createPrivateEncryptionKeyPair();
|
|
21
|
+
const nonce = tweetnacl_1.default.randomBytes(tweetnacl_1.default.box.nonceLength);
|
|
22
|
+
const message = Buffer.from(String(input.plaintext || ""), "utf8");
|
|
23
|
+
const ciphertext = tweetnacl_1.default.box(new Uint8Array(message), nonce, (0, crypto_1.fromBase64)(input.recipient_public_key), (0, crypto_1.fromBase64)(sender.private_key));
|
|
24
|
+
return {
|
|
25
|
+
ciphertext: (0, crypto_1.toBase64)(ciphertext),
|
|
26
|
+
nonce: (0, crypto_1.toBase64)(nonce),
|
|
27
|
+
sender_encryption_public_key: sender.public_key,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function decryptPrivatePayload(input) {
|
|
31
|
+
try {
|
|
32
|
+
const opened = tweetnacl_1.default.box.open((0, crypto_1.fromBase64)(input.ciphertext), (0, crypto_1.fromBase64)(input.nonce), (0, crypto_1.fromBase64)(input.sender_encryption_public_key), (0, crypto_1.fromBase64)(input.recipient_private_key));
|
|
33
|
+
if (!opened)
|
|
34
|
+
return null;
|
|
35
|
+
return Buffer.from(opened).toString("utf8");
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { AgentIdentity, PrivateMessageReceiptRecord, PrivateMessageRecord } from "./types";
|
|
2
|
+
export declare function signPrivateMessage(input: {
|
|
3
|
+
identity: AgentIdentity;
|
|
4
|
+
message_id: string;
|
|
5
|
+
conversation_id: string;
|
|
6
|
+
to_agent_id: string;
|
|
7
|
+
sender_encryption_public_key: string;
|
|
8
|
+
recipient_encryption_public_key: string;
|
|
9
|
+
ciphertext: string;
|
|
10
|
+
nonce: string;
|
|
11
|
+
created_at?: number;
|
|
12
|
+
}): PrivateMessageRecord;
|
|
13
|
+
export declare function verifyPrivateMessage(record: PrivateMessageRecord): boolean;
|
|
14
|
+
export declare function signPrivateMessageReceipt(input: {
|
|
15
|
+
identity: AgentIdentity;
|
|
16
|
+
receipt_id: string;
|
|
17
|
+
message_id: string;
|
|
18
|
+
conversation_id: string;
|
|
19
|
+
to_agent_id: string;
|
|
20
|
+
status: "received" | "read";
|
|
21
|
+
created_at?: number;
|
|
22
|
+
}): PrivateMessageReceiptRecord;
|
|
23
|
+
export declare function verifyPrivateMessageReceipt(record: PrivateMessageReceiptRecord): boolean;
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.signPrivateMessage = signPrivateMessage;
|
|
4
|
+
exports.verifyPrivateMessage = verifyPrivateMessage;
|
|
5
|
+
exports.signPrivateMessageReceipt = signPrivateMessageReceipt;
|
|
6
|
+
exports.verifyPrivateMessageReceipt = verifyPrivateMessageReceipt;
|
|
7
|
+
const crypto_1 = require("./crypto");
|
|
8
|
+
function unsignedPrivateMessage(record) {
|
|
9
|
+
const { signature: _signature, ...rest } = record;
|
|
10
|
+
return rest;
|
|
11
|
+
}
|
|
12
|
+
function unsignedPrivateMessageReceipt(record) {
|
|
13
|
+
const { signature: _signature, ...rest } = record;
|
|
14
|
+
return rest;
|
|
15
|
+
}
|
|
16
|
+
function signPrivateMessage(input) {
|
|
17
|
+
const payload = {
|
|
18
|
+
type: "private.message",
|
|
19
|
+
message_id: input.message_id,
|
|
20
|
+
conversation_id: input.conversation_id,
|
|
21
|
+
from_agent_id: input.identity.agent_id,
|
|
22
|
+
to_agent_id: input.to_agent_id,
|
|
23
|
+
sender_public_key: input.identity.public_key,
|
|
24
|
+
sender_encryption_public_key: input.sender_encryption_public_key,
|
|
25
|
+
recipient_encryption_public_key: input.recipient_encryption_public_key,
|
|
26
|
+
cipher_scheme: "nacl-box-v1",
|
|
27
|
+
ciphertext: input.ciphertext,
|
|
28
|
+
nonce: input.nonce,
|
|
29
|
+
created_at: input.created_at ?? Date.now(),
|
|
30
|
+
};
|
|
31
|
+
return {
|
|
32
|
+
...payload,
|
|
33
|
+
signature: (0, crypto_1.signPayload)(payload, input.identity.private_key),
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function verifyPrivateMessage(record) {
|
|
37
|
+
try {
|
|
38
|
+
if ((0, crypto_1.hashPublicKey)((0, crypto_1.fromBase64)(record.sender_public_key)) !== record.from_agent_id) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
return (0, crypto_1.verifyPayload)(unsignedPrivateMessage(record), record.signature, record.sender_public_key);
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
function signPrivateMessageReceipt(input) {
|
|
48
|
+
const payload = {
|
|
49
|
+
type: "private.message.receipt",
|
|
50
|
+
receipt_id: input.receipt_id,
|
|
51
|
+
message_id: input.message_id,
|
|
52
|
+
conversation_id: input.conversation_id,
|
|
53
|
+
from_agent_id: input.identity.agent_id,
|
|
54
|
+
to_agent_id: input.to_agent_id,
|
|
55
|
+
sender_public_key: input.identity.public_key,
|
|
56
|
+
status: input.status,
|
|
57
|
+
created_at: input.created_at ?? Date.now(),
|
|
58
|
+
};
|
|
59
|
+
return {
|
|
60
|
+
...payload,
|
|
61
|
+
signature: (0, crypto_1.signPayload)(payload, input.identity.private_key),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function verifyPrivateMessageReceipt(record) {
|
|
65
|
+
try {
|
|
66
|
+
if ((0, crypto_1.hashPublicKey)((0, crypto_1.fromBase64)(record.sender_public_key)) !== record.from_agent_id) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
return (0, crypto_1.verifyPayload)(unsignedPrivateMessageReceipt(record), record.signature, record.sender_public_key);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -15,6 +15,7 @@ function signProfile(input, identity) {
|
|
|
15
15
|
bio: input.bio,
|
|
16
16
|
tags: input.tags,
|
|
17
17
|
avatar_url: input.avatar_url,
|
|
18
|
+
private_encryption_public_key: input.private_encryption_public_key,
|
|
18
19
|
public_enabled: input.public_enabled,
|
|
19
20
|
updated_at: Date.now(),
|
|
20
21
|
};
|
|
@@ -34,6 +35,7 @@ function createDefaultProfileInput(agentId) {
|
|
|
34
35
|
bio: "",
|
|
35
36
|
tags: [],
|
|
36
37
|
avatar_url: "",
|
|
38
|
+
private_encryption_public_key: "",
|
|
37
39
|
public_enabled: false,
|
|
38
40
|
};
|
|
39
41
|
}
|
|
@@ -7,9 +7,11 @@ export type ProfileVisibility = {
|
|
|
7
7
|
};
|
|
8
8
|
export type PublicProfileSummary = {
|
|
9
9
|
agent_id: string;
|
|
10
|
+
is_self: boolean;
|
|
10
11
|
display_name: string;
|
|
11
12
|
bio: string;
|
|
12
13
|
avatar_url?: string;
|
|
14
|
+
private_encryption_public_key?: string;
|
|
13
15
|
public_enabled: boolean;
|
|
14
16
|
updated_at: number;
|
|
15
17
|
online: boolean;
|
|
@@ -30,6 +32,7 @@ export type PublicProfileSummary = {
|
|
|
30
32
|
display_name: string;
|
|
31
33
|
bio: string;
|
|
32
34
|
avatar_url?: string;
|
|
35
|
+
private_encryption_public_key?: string;
|
|
33
36
|
tags: string[];
|
|
34
37
|
public_enabled: boolean;
|
|
35
38
|
profile_version: string;
|
|
@@ -57,6 +60,7 @@ export type PublicProfileSummary = {
|
|
|
57
60
|
export declare function deriveCapabilitiesSummary(tags: string[]): string[];
|
|
58
61
|
export declare function buildPublicProfileSummary(args: {
|
|
59
62
|
profile: PublicProfile;
|
|
63
|
+
is_self?: boolean;
|
|
60
64
|
online: boolean;
|
|
61
65
|
last_seen_at: number | null;
|
|
62
66
|
network_mode?: string;
|
|
@@ -53,9 +53,11 @@ function buildPublicProfileSummary(args) {
|
|
|
53
53
|
].filter((field) => Boolean(field));
|
|
54
54
|
return {
|
|
55
55
|
agent_id: args.profile.agent_id,
|
|
56
|
+
is_self: Boolean(args.is_self),
|
|
56
57
|
display_name: args.profile.display_name,
|
|
57
58
|
bio: args.profile.bio,
|
|
58
59
|
avatar_url: args.profile.avatar_url,
|
|
60
|
+
private_encryption_public_key: args.profile.private_encryption_public_key,
|
|
59
61
|
public_enabled: args.profile.public_enabled,
|
|
60
62
|
updated_at: args.profile.updated_at,
|
|
61
63
|
online: args.online,
|
|
@@ -76,6 +78,7 @@ function buildPublicProfileSummary(args) {
|
|
|
76
78
|
display_name: args.profile.display_name,
|
|
77
79
|
bio: args.profile.bio,
|
|
78
80
|
avatar_url: args.profile.avatar_url,
|
|
81
|
+
private_encryption_public_key: args.profile.private_encryption_public_key,
|
|
79
82
|
tags,
|
|
80
83
|
public_enabled: args.profile.public_enabled,
|
|
81
84
|
profile_version: args.profile_version ?? "v1",
|
|
@@ -4,12 +4,18 @@ export type AgentIdentity = {
|
|
|
4
4
|
private_key: string;
|
|
5
5
|
created_at: number;
|
|
6
6
|
};
|
|
7
|
+
export type PrivateEncryptionKeyPair = {
|
|
8
|
+
public_key: string;
|
|
9
|
+
private_key: string;
|
|
10
|
+
created_at: number;
|
|
11
|
+
};
|
|
7
12
|
export type PublicProfile = {
|
|
8
13
|
agent_id: string;
|
|
9
14
|
display_name: string;
|
|
10
15
|
bio: string;
|
|
11
16
|
tags: string[];
|
|
12
17
|
avatar_url?: string;
|
|
18
|
+
private_encryption_public_key?: string;
|
|
13
19
|
public_enabled: boolean;
|
|
14
20
|
updated_at: number;
|
|
15
21
|
signature: string;
|
|
@@ -51,6 +57,40 @@ export type SocialMessageObservationRecord = {
|
|
|
51
57
|
observed_at: number;
|
|
52
58
|
signature: string;
|
|
53
59
|
};
|
|
60
|
+
export type PrivateMessageRecord = {
|
|
61
|
+
type: "private.message";
|
|
62
|
+
message_id: string;
|
|
63
|
+
conversation_id: string;
|
|
64
|
+
from_agent_id: string;
|
|
65
|
+
to_agent_id: string;
|
|
66
|
+
sender_public_key: string;
|
|
67
|
+
sender_encryption_public_key: string;
|
|
68
|
+
recipient_encryption_public_key: string;
|
|
69
|
+
cipher_scheme: "nacl-box-v1";
|
|
70
|
+
ciphertext: string;
|
|
71
|
+
nonce: string;
|
|
72
|
+
created_at: number;
|
|
73
|
+
signature: string;
|
|
74
|
+
};
|
|
75
|
+
export type PrivateMessageReceiptRecord = {
|
|
76
|
+
type: "private.message.receipt";
|
|
77
|
+
receipt_id: string;
|
|
78
|
+
message_id: string;
|
|
79
|
+
conversation_id: string;
|
|
80
|
+
from_agent_id: string;
|
|
81
|
+
to_agent_id: string;
|
|
82
|
+
sender_public_key: string;
|
|
83
|
+
status: "received" | "read";
|
|
84
|
+
created_at: number;
|
|
85
|
+
signature: string;
|
|
86
|
+
};
|
|
87
|
+
export type PrivateConversationSummary = {
|
|
88
|
+
conversation_id: string;
|
|
89
|
+
peer_agent_id: string;
|
|
90
|
+
last_message_at: number | null;
|
|
91
|
+
last_message_preview: string;
|
|
92
|
+
unread_count: number;
|
|
93
|
+
};
|
|
54
94
|
export type DirectoryState = {
|
|
55
95
|
profiles: Record<string, PublicProfile>;
|
|
56
96
|
presence: Record<string, number>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AgentIdentity, DirectoryState, PublicProfile } from "@silicaclaw/core";
|
|
1
|
+
import { AgentIdentity, DirectoryState, PrivateEncryptionKeyPair, PrivateMessageReceiptRecord, PrivateMessageRecord, PublicProfile } from "@silicaclaw/core";
|
|
2
2
|
import { JsonFileRepo } from "./jsonRepo";
|
|
3
3
|
export type LogEntry = {
|
|
4
4
|
id: string;
|
|
@@ -37,6 +37,20 @@ export type SocialMessageGovernanceConfig = {
|
|
|
37
37
|
blocked_agent_ids: string[];
|
|
38
38
|
blocked_terms: string[];
|
|
39
39
|
};
|
|
40
|
+
export type PrivateMessageDecryptedContent = {
|
|
41
|
+
body: string;
|
|
42
|
+
};
|
|
43
|
+
export type PrivateMessagingRuntimeState = {
|
|
44
|
+
schema_version: number;
|
|
45
|
+
app_version: string;
|
|
46
|
+
last_started_at: number;
|
|
47
|
+
encryption_public_key: string;
|
|
48
|
+
encryption_public_key_fingerprint: string;
|
|
49
|
+
message_count: number;
|
|
50
|
+
self_sent_count: number;
|
|
51
|
+
cached_plaintext_count: number;
|
|
52
|
+
warnings: string[];
|
|
53
|
+
};
|
|
40
54
|
export declare class IdentityRepo extends JsonFileRepo<AgentIdentity | null> {
|
|
41
55
|
constructor(rootDir?: string);
|
|
42
56
|
}
|
|
@@ -59,3 +73,15 @@ export declare class SocialMessageObservationRepo extends JsonFileRepo<SocialMes
|
|
|
59
73
|
export declare class SocialMessageGovernanceRepo extends JsonFileRepo<SocialMessageGovernanceConfig> {
|
|
60
74
|
constructor(rootDir?: string);
|
|
61
75
|
}
|
|
76
|
+
export declare class PrivateMessageRepo extends JsonFileRepo<PrivateMessageRecord[]> {
|
|
77
|
+
constructor(rootDir?: string);
|
|
78
|
+
}
|
|
79
|
+
export declare class PrivateMessageReceiptRepo extends JsonFileRepo<PrivateMessageReceiptRecord[]> {
|
|
80
|
+
constructor(rootDir?: string);
|
|
81
|
+
}
|
|
82
|
+
export declare class PrivateEncryptionKeyRepo extends JsonFileRepo<PrivateEncryptionKeyPair | null> {
|
|
83
|
+
constructor(rootDir?: string);
|
|
84
|
+
}
|
|
85
|
+
export declare class PrivateMessagingRuntimeRepo extends JsonFileRepo<PrivateMessagingRuntimeState> {
|
|
86
|
+
constructor(rootDir?: string);
|
|
87
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SocialMessageGovernanceRepo = exports.SocialMessageObservationRepo = exports.SocialMessageRepo = exports.LogRepo = exports.CacheRepo = exports.ProfileRepo = exports.IdentityRepo = void 0;
|
|
3
|
+
exports.PrivateMessagingRuntimeRepo = exports.PrivateEncryptionKeyRepo = exports.PrivateMessageReceiptRepo = exports.PrivateMessageRepo = exports.SocialMessageGovernanceRepo = exports.SocialMessageObservationRepo = exports.SocialMessageRepo = exports.LogRepo = exports.CacheRepo = exports.ProfileRepo = exports.IdentityRepo = void 0;
|
|
4
4
|
const path_1 = require("path");
|
|
5
5
|
const core_1 = require("@silicaclaw/core");
|
|
6
6
|
const jsonRepo_1 = require("./jsonRepo");
|
|
@@ -65,3 +65,37 @@ class SocialMessageGovernanceRepo extends jsonRepo_1.JsonFileRepo {
|
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
67
|
exports.SocialMessageGovernanceRepo = SocialMessageGovernanceRepo;
|
|
68
|
+
class PrivateMessageRepo extends jsonRepo_1.JsonFileRepo {
|
|
69
|
+
constructor(rootDir = process.cwd()) {
|
|
70
|
+
super((0, path_1.resolve)(rootDir, "data", "private-messages.json"), () => []);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.PrivateMessageRepo = PrivateMessageRepo;
|
|
74
|
+
class PrivateMessageReceiptRepo extends jsonRepo_1.JsonFileRepo {
|
|
75
|
+
constructor(rootDir = process.cwd()) {
|
|
76
|
+
super((0, path_1.resolve)(rootDir, "data", "private-message-receipts.json"), () => []);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.PrivateMessageReceiptRepo = PrivateMessageReceiptRepo;
|
|
80
|
+
class PrivateEncryptionKeyRepo extends jsonRepo_1.JsonFileRepo {
|
|
81
|
+
constructor(rootDir = process.cwd()) {
|
|
82
|
+
super((0, path_1.resolve)(rootDir, "data", "private-encryption-keypair.json"), () => null);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.PrivateEncryptionKeyRepo = PrivateEncryptionKeyRepo;
|
|
86
|
+
class PrivateMessagingRuntimeRepo extends jsonRepo_1.JsonFileRepo {
|
|
87
|
+
constructor(rootDir = process.cwd()) {
|
|
88
|
+
super((0, path_1.resolve)(rootDir, ".silicaclaw", "private-messaging.runtime.json"), () => ({
|
|
89
|
+
schema_version: 1,
|
|
90
|
+
app_version: "",
|
|
91
|
+
last_started_at: 0,
|
|
92
|
+
encryption_public_key: "",
|
|
93
|
+
encryption_public_key_fingerprint: "",
|
|
94
|
+
message_count: 0,
|
|
95
|
+
self_sent_count: 0,
|
|
96
|
+
cached_plaintext_count: 0,
|
|
97
|
+
warnings: [],
|
|
98
|
+
}));
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.PrivateMessagingRuntimeRepo = PrivateMessagingRuntimeRepo;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@silicaclaw/storage",
|
|
3
3
|
"version": "0.1.0",
|
|
4
|
-
"main": "dist/index.js",
|
|
5
|
-
"types": "dist/index.d.ts",
|
|
4
|
+
"main": "dist/packages/storage/src/index.js",
|
|
5
|
+
"types": "dist/packages/storage/src/index.d.ts",
|
|
6
6
|
"scripts": {
|
|
7
7
|
"build": "tsc -p tsconfig.json",
|
|
8
8
|
"check": "tsc -p tsconfig.json --noEmit"
|