@agentunion/fastaun 0.2.19 → 0.3.0
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 +46 -0
- package/_packed_docs/CHANGELOG.md +46 -0
- package/_packed_docs/agent.md/SCHEMA.md +173 -0
- package/_packed_docs/agent.md/examples/codeagent-claudecode.md +61 -0
- package/_packed_docs/agent.md/examples/human-developer.md +60 -0
- package/_packed_docs/agent.md/examples/openclaw-lobster.md +52 -0
- package/_packed_docs/agent.md/examples/signed-openclaw-lobster.md +43 -0
- package/_packed_docs/protocol/00-/346/200/273/350/247/210/344/270/216/345/210/206/345/261/202.md +205 -0
- package/_packed_docs/protocol/00A-/350/256/276/350/256/241/345/216/237/345/210/231-/344/270/272Agent/350/200/214/347/224/237.md +197 -0
- package/_packed_docs/protocol/01-/350/272/253/344/273/275/344/270/216/345/207/255/350/257/201/345/215/217/350/256/256-auth.md +549 -0
- package/_packed_docs/protocol/02-/350/257/201/344/271/246/344/270/216/344/277/241/344/273/273/344/275/223/347/263/273.md +810 -0
- package/_packed_docs/protocol/03-Gateway-/350/277/236/346/216/245/346/250/241/345/274/217.md +262 -0
- package/_packed_docs/protocol/04-Peer-/345/255/220/345/215/217/350/256/256.md +180 -0
- package/_packed_docs/protocol/05-Relay-/345/255/220/345/215/217/350/256/256.md +164 -0
- package/_packed_docs/protocol/06-/346/234/215/345/212/241/345/215/217/350/256/256.md +1135 -0
- package/_packed_docs/protocol/07-/351/224/231/350/257/257/347/240/201/344/270/216/347/212/266/346/200/201/346/234/272.md +234 -0
- package/_packed_docs/protocol/08-AUN-E2EE-Group.md +900 -0
- package/_packed_docs/protocol/08-AUN-E2EE.md +413 -0
- package/_packed_docs/protocol/09-/345/256/211/345/205/250/350/200/203/350/231/221.md +316 -0
- package/_packed_docs/protocol/10-Group-/345/255/220/345/215/217/350/256/256.md +804 -0
- package/_packed_docs/protocol/11-Storage-/345/255/220/345/215/217/350/256/256.md +271 -0
- package/_packed_docs/protocol/12-Stream-/345/255/220/345/215/217/350/256/256.md +329 -0
- package/_packed_docs/protocol/13-Agent/350/241/214/344/270/272/350/247/204/350/214/203.md +141 -0
- package/_packed_docs/protocol/14-/344/272/244/344/272/222/346/234/272/345/210/266-/345/223/215/345/272/224/346/250/241/345/274/217/344/270/216/350/207/252/344/270/273/346/250/241/345/274/217.md +170 -0
- package/_packed_docs/protocol/15-/347/246/273/347/272/277/346/216/250/351/200/201/351/200/232/347/237/245/345/215/217/350/256/256.md +419 -0
- package/_packed_docs/protocol/README.md +71 -0
- package/_packed_docs/protocol/agent.md/SCHEMA.md +118 -0
- package/_packed_docs/protocol/agent.md/examples/codeagent-claudecode.md +61 -0
- package/_packed_docs/protocol/agent.md/examples/human-developer.md +60 -0
- package/_packed_docs/protocol/agent.md/examples/openclaw-lobster.md +52 -0
- package/_packed_docs/protocol/aun-docs-guide.md +49 -0
- package/_packed_docs/protocol/index.md +124 -0
- package/_packed_docs/protocol//350/215/211/346/241/210-agent.md/347/255/276/345/220/215/345/215/217/350/256/256.md +205 -0
- package/_packed_docs/protocol//350/215/211/346/241/210-/346/213/222/347/273/235/344/277/241/345/217/267/345/215/217/350/256/256.md +249 -0
- package/_packed_docs/protocol//351/231/204/345/275/225A-/346/234/257/350/257/255/350/241/250.md +337 -0
- package/_packed_docs/protocol//351/231/204/345/275/225B-/346/211/251/345/261/225/346/200/247/346/214/207/345/215/227.md +80 -0
- package/_packed_docs/protocol//351/231/204/345/275/225C-/347/247/201/351/222/245/347/256/241/347/220/206/344/270/216/350/272/253/344/273/275/346/201/242/345/244/215.md +704 -0
- package/_packed_docs/protocol//351/231/204/345/275/225D-Root_CA_/346/262/273/347/220/206/346/234/272/345/210/266.md +620 -0
- package/_packed_docs/protocol//351/231/204/345/275/225E-Root_CA_/345/207/206/345/205/245/346/265/201/347/250/213.md +605 -0
- package/_packed_docs/protocol//351/231/204/345/275/225F-Issuer_CA_/347/224/263/350/257/267/346/265/201/347/250/213.md +548 -0
- package/_packed_docs/protocol//351/231/204/345/275/225G-AID_/345/255/244/345/204/277/351/242/204/351/230/262/344/270/216/346/225/221/346/217/264/346/234/272/345/210/266.md +513 -0
- package/_packed_docs/protocol//351/231/204/345/275/225H-Identity/346/234/215/345/212/241/345/256/236/347/216/260/346/214/207/345/215/227.md +619 -0
- package/_packed_docs/protocol//351/231/204/345/275/225I-/350/267/250/345/237/237/346/266/210/346/201/257/350/267/257/347/224/261/345/256/236/347/216/260/346/214/207/345/215/227.md +492 -0
- package/_packed_docs/protocol//351/231/204/345/275/225J-/345/256/242/346/210/267/347/253/257/346/216/245/345/205/245/347/244/272/344/276/213.md +402 -0
- package/_packed_docs/protocol//351/231/204/345/275/225K-Agent_Web/345/217/221/347/216/260/345/215/217/350/256/256.md +130 -0
- package/_packed_docs/protocol//351/231/204/345/275/225L-E2EE/345/256/236/347/216/260/346/214/207/345/215/227.md +267 -0
- package/_packed_docs/protocol//351/231/204/345/275/225M-JWT/350/256/244/350/257/201/345/256/236/347/216/260/346/214/207/345/215/227.md +367 -0
- package/_packed_docs/python-sdk-v2-only-changelog.md +189 -0
- package/_packed_docs/sdk/01-/345/277/253/351/200/237/345/274/200/345/247/213.md +223 -0
- package/_packed_docs/sdk/02-WebSocket/345/215/217/350/256/256.md +354 -0
- package/_packed_docs/sdk/03-/346/240/270/345/277/203/346/246/202/345/277/265.md +172 -0
- package/_packed_docs/sdk/04-/350/277/236/346/216/245/344/270/216/350/256/244/350/257/201.md +396 -0
- package/_packed_docs/sdk/05-E2EE/345/212/240/345/257/206/351/200/232/344/277/241.md +611 -0
- package/_packed_docs/sdk/06-API/346/211/213/345/206/214.md +1203 -0
- package/_packed_docs/sdk/07-/351/224/231/350/257/257/345/244/204/347/220/206.md +150 -0
- package/_packed_docs/sdk/08-/346/234/200/344/275/263/345/256/236/350/267/265.md +89 -0
- package/_packed_docs/sdk/09-custody-api-manual.md +445 -0
- package/_packed_docs/sdk/09-group-rpc-manual.md +1895 -0
- package/_packed_docs/sdk/09-message-rpc-manual.md +597 -0
- package/_packed_docs/sdk/09-meta-rpc-manual.md +142 -0
- package/_packed_docs/sdk/09-payload-reference.md +702 -0
- package/_packed_docs/sdk/09-storage-rpc-manual.md +408 -0
- package/_packed_docs/sdk/09-stream-rpc-manual.md +275 -0
- package/_packed_docs/sdk/AUN_DOCS_GUIDE.md +72 -0
- package/_packed_docs/sdk/INDEX.md +131 -0
- package/_packed_docs/sdk/README.md +307 -0
- package/dist/auth.d.ts +2 -1
- package/dist/auth.js +37 -18
- package/dist/auth.js.map +1 -1
- package/dist/client.d.ts +147 -171
- package/dist/client.js +2583 -3916
- package/dist/client.js.map +1 -1
- package/dist/config.d.ts +0 -4
- package/dist/config.js +0 -4
- package/dist/config.js.map +1 -1
- package/dist/e2ee.d.ts +5 -139
- package/dist/e2ee.js +4 -1151
- package/dist/e2ee.js.map +1 -1
- package/dist/errors.d.ts +0 -8
- package/dist/errors.js +0 -14
- package/dist/errors.js.map +1 -1
- package/dist/index.d.ts +9 -5
- package/dist/index.js +6 -3
- package/dist/index.js.map +1 -1
- package/dist/keystore/aid-db.d.ts +12 -61
- package/dist/keystore/aid-db.js +41 -539
- package/dist/keystore/aid-db.js.map +1 -1
- package/dist/keystore/file.d.ts +5 -41
- package/dist/keystore/file.js +8 -64
- package/dist/keystore/file.js.map +1 -1
- package/dist/keystore/index.d.ts +1 -49
- package/dist/namespaces/auth.d.ts +1 -0
- package/dist/namespaces/auth.js +22 -6
- package/dist/namespaces/auth.js.map +1 -1
- package/dist/protected-headers.d.ts +13 -0
- package/dist/protected-headers.js +47 -0
- package/dist/protected-headers.js.map +1 -0
- package/dist/seq-tracker.d.ts +7 -2
- package/dist/seq-tracker.js +31 -10
- package/dist/seq-tracker.js.map +1 -1
- package/dist/transport.d.ts +10 -0
- package/dist/transport.js +24 -0
- package/dist/transport.js.map +1 -1
- package/dist/types.d.ts +0 -56
- package/dist/v2/crypto/aead.d.ts +20 -0
- package/dist/v2/crypto/aead.js +59 -0
- package/dist/v2/crypto/aead.js.map +1 -0
- package/dist/v2/crypto/canonical.d.ts +20 -0
- package/dist/v2/crypto/canonical.js +119 -0
- package/dist/v2/crypto/canonical.js.map +1 -0
- package/dist/v2/crypto/dh-path.d.ts +39 -0
- package/dist/v2/crypto/dh-path.js +55 -0
- package/dist/v2/crypto/dh-path.js.map +1 -0
- package/dist/v2/crypto/ecdh.d.ts +29 -0
- package/dist/v2/crypto/ecdh.js +122 -0
- package/dist/v2/crypto/ecdh.js.map +1 -0
- package/dist/v2/crypto/ecdsa.d.ts +29 -0
- package/dist/v2/crypto/ecdsa.js +120 -0
- package/dist/v2/crypto/ecdsa.js.map +1 -0
- package/dist/v2/crypto/hkdf.d.ts +19 -0
- package/dist/v2/crypto/hkdf.js +47 -0
- package/dist/v2/crypto/hkdf.js.map +1 -0
- package/dist/v2/crypto/index.d.ts +8 -0
- package/dist/v2/crypto/index.js +8 -0
- package/dist/v2/crypto/index.js.map +1 -0
- package/dist/v2/crypto/recipients.d.ts +32 -0
- package/dist/v2/crypto/recipients.js +183 -0
- package/dist/v2/crypto/recipients.js.map +1 -0
- package/dist/v2/e2ee/decrypt.d.ts +29 -0
- package/dist/v2/e2ee/decrypt.js +159 -0
- package/dist/v2/e2ee/decrypt.js.map +1 -0
- package/dist/v2/e2ee/encrypt-group.d.ts +17 -0
- package/dist/v2/e2ee/encrypt-group.js +143 -0
- package/dist/v2/e2ee/encrypt-group.js.map +1 -0
- package/dist/v2/e2ee/encrypt-p2p.d.ts +31 -0
- package/dist/v2/e2ee/encrypt-p2p.js +190 -0
- package/dist/v2/e2ee/encrypt-p2p.js.map +1 -0
- package/dist/v2/e2ee/index.d.ts +9 -0
- package/dist/v2/e2ee/index.js +9 -0
- package/dist/v2/e2ee/index.js.map +1 -0
- package/dist/v2/e2ee/metadata-auth.d.ts +15 -0
- package/dist/v2/e2ee/metadata-auth.js +50 -0
- package/dist/v2/e2ee/metadata-auth.js.map +1 -0
- package/dist/v2/e2ee/types.d.ts +57 -0
- package/dist/v2/e2ee/types.js +7 -0
- package/dist/v2/e2ee/types.js.map +1 -0
- package/dist/v2/session/index.d.ts +4 -0
- package/dist/v2/session/index.js +3 -0
- package/dist/v2/session/index.js.map +1 -0
- package/dist/v2/session/keystore.d.ts +41 -0
- package/dist/v2/session/keystore.js +103 -0
- package/dist/v2/session/keystore.js.map +1 -0
- package/dist/v2/session/session.d.ts +97 -0
- package/dist/v2/session/session.js +242 -0
- package/dist/v2/session/session.js.map +1 -0
- package/dist/v2/state/commitment.d.ts +58 -0
- package/dist/v2/state/commitment.js +85 -0
- package/dist/v2/state/commitment.js.map +1 -0
- package/dist/v2/state/index.d.ts +2 -0
- package/dist/v2/state/index.js +2 -0
- package/dist/v2/state/index.js.map +1 -0
- package/package.json +46 -42
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V2 E2EE Session Manager。
|
|
3
|
+
*
|
|
4
|
+
* 管理本设备的 IK/SPK 生命周期、服务端注册、加解密密钥获取。
|
|
5
|
+
*
|
|
6
|
+
* 设计要点:
|
|
7
|
+
* - IK = AID 长期密钥(多设备共享 AID 身份),不独立生成
|
|
8
|
+
* - SPK 设备级 P-256 密钥对,IK 签名背书
|
|
9
|
+
* - SPK 销毁三重条件:
|
|
10
|
+
* - contig_seq >= 该 SPK 引用的最大 seq
|
|
11
|
+
* - 自最后一次见到该 spk_id >= 7 小时
|
|
12
|
+
* - 不在最近 7 代保留窗口内
|
|
13
|
+
* - 对端 IK 公钥缓存 TTL 1 小时
|
|
14
|
+
* - SPK 注册:调 callFn("message.v2.put_peer_pk", ...)
|
|
15
|
+
*/
|
|
16
|
+
import { createHash } from 'node:crypto';
|
|
17
|
+
import { generateP256Keypair } from '../crypto/ecdh.js';
|
|
18
|
+
import { ecdsaSignRaw } from '../crypto/ecdsa.js';
|
|
19
|
+
/** 对端 IK 公钥缓存 TTL(毫秒)。 */
|
|
20
|
+
export const PEER_KEY_CACHE_TTL_MS = 60 * 60 * 1000; // 1h
|
|
21
|
+
/** SPK 销毁安全窗口(毫秒)。 */
|
|
22
|
+
export const DESTROY_DELAY_MS = 7 * 60 * 60 * 1000; // 7h
|
|
23
|
+
/** SPK 销毁时保留的最近代数。 */
|
|
24
|
+
export const RECENT_GENERATIONS = 7;
|
|
25
|
+
export const HARD_LIMIT_MS = 180 * 24 * 60 * 60 * 1000; // 180 天
|
|
26
|
+
export class V2Session {
|
|
27
|
+
_store;
|
|
28
|
+
_deviceId;
|
|
29
|
+
_aid;
|
|
30
|
+
_ikPriv;
|
|
31
|
+
_ikPubDer;
|
|
32
|
+
_spkId = '';
|
|
33
|
+
_spkPriv;
|
|
34
|
+
_spkPubDer;
|
|
35
|
+
_registered = false;
|
|
36
|
+
_peerIKCache = new Map();
|
|
37
|
+
_verifiedSPKs = new Set();
|
|
38
|
+
_oldSPKMaxSeq = new Map();
|
|
39
|
+
_nowFn = () => Date.now();
|
|
40
|
+
constructor(store, deviceId, aid, ikPriv, ikPubDer) {
|
|
41
|
+
if (!ikPriv || !ikPubDer) {
|
|
42
|
+
throw new Error('V2Session requires AID priv/pub keys (IK = AID identity)');
|
|
43
|
+
}
|
|
44
|
+
this._store = store;
|
|
45
|
+
this._deviceId = deviceId;
|
|
46
|
+
this._aid = aid;
|
|
47
|
+
this._ikPriv = ikPriv;
|
|
48
|
+
this._ikPubDer = ikPubDer;
|
|
49
|
+
}
|
|
50
|
+
/** 测试用:注入虚拟时钟。 */
|
|
51
|
+
_setNowFn(fn) {
|
|
52
|
+
this._nowFn = fn;
|
|
53
|
+
}
|
|
54
|
+
get deviceId() {
|
|
55
|
+
return this._deviceId;
|
|
56
|
+
}
|
|
57
|
+
get aid() {
|
|
58
|
+
return this._aid;
|
|
59
|
+
}
|
|
60
|
+
get currentSpkId() {
|
|
61
|
+
return this._spkId;
|
|
62
|
+
}
|
|
63
|
+
get currentIkPubDer() {
|
|
64
|
+
return this._ikPubDer;
|
|
65
|
+
}
|
|
66
|
+
/** 暴露 store 便于测试(与 Python 同等私有约定)。 */
|
|
67
|
+
get _storeForTest() {
|
|
68
|
+
return this._store;
|
|
69
|
+
}
|
|
70
|
+
/** 加载或生成当前 SPK;IK 由构造函数注入,无需加载。 */
|
|
71
|
+
ensureKeys() {
|
|
72
|
+
if (this._spkPriv)
|
|
73
|
+
return;
|
|
74
|
+
const cur = this._store.loadCurrentSPK(this._deviceId);
|
|
75
|
+
if (cur) {
|
|
76
|
+
this._spkId = cur.spkId;
|
|
77
|
+
this._spkPriv = cur.priv;
|
|
78
|
+
this._spkPubDer = cur.pubDer;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
this._generateNewSPK();
|
|
82
|
+
}
|
|
83
|
+
_generateNewSPK() {
|
|
84
|
+
const [priv, pubDer] = generateP256Keypair();
|
|
85
|
+
const hashHex = createHash('sha256').update(pubDer).digest('hex');
|
|
86
|
+
const spkId = `sha256:${hashHex.substring(0, 16)}`;
|
|
87
|
+
this._store.saveSPK(this._deviceId, spkId, priv, pubDer);
|
|
88
|
+
this._spkId = spkId;
|
|
89
|
+
this._spkPriv = priv;
|
|
90
|
+
this._spkPubDer = pubDer;
|
|
91
|
+
}
|
|
92
|
+
/** 注册本设备 SPK 到服务端。IK = AID 长期密钥,无需注册。 */
|
|
93
|
+
async ensureRegistered(callFn) {
|
|
94
|
+
if (this._registered)
|
|
95
|
+
return;
|
|
96
|
+
this.ensureKeys();
|
|
97
|
+
await this._registerSPK(callFn);
|
|
98
|
+
this._registered = true;
|
|
99
|
+
}
|
|
100
|
+
/** SPK 由 AID 私钥(IK)签名背书,并上报到 message.v2.put_peer_pk。 */
|
|
101
|
+
async _registerSPK(callFn) {
|
|
102
|
+
const spkTimestamp = Math.floor(this._nowFn() / 1000);
|
|
103
|
+
const signData = Buffer.concat([
|
|
104
|
+
Buffer.from(this._spkPubDer),
|
|
105
|
+
Buffer.from(this._spkId, 'utf-8'),
|
|
106
|
+
Buffer.from(String(spkTimestamp), 'utf-8'),
|
|
107
|
+
]);
|
|
108
|
+
const signature = ecdsaSignRaw(this._ikPriv, signData);
|
|
109
|
+
await callFn('message.v2.put_peer_pk', {
|
|
110
|
+
peer_aid: this._aid,
|
|
111
|
+
key_source: 'peer_device_prekey',
|
|
112
|
+
spk_id: this._spkId,
|
|
113
|
+
spk_pk: Buffer.from(this._spkPubDer).toString('base64'),
|
|
114
|
+
spk_signature: Buffer.from(signature).toString('base64'),
|
|
115
|
+
spk_timestamp: spkTimestamp,
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
/** 返回加密所需的 sender 结构。 */
|
|
119
|
+
getSenderIdentity() {
|
|
120
|
+
this.ensureKeys();
|
|
121
|
+
return {
|
|
122
|
+
aid: this._aid,
|
|
123
|
+
deviceId: this._deviceId,
|
|
124
|
+
ikPriv: this._ikPriv,
|
|
125
|
+
ikPubDer: this._ikPubDer,
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* 返回解密所需的私钥。
|
|
130
|
+
* - spkId 空:1DH(仅 IK)
|
|
131
|
+
* - spkId == 当前 SPK:当前 spkPriv
|
|
132
|
+
* - 否则:从 store 加载旧 SPK 私钥(可能为 null = 已销毁)
|
|
133
|
+
*/
|
|
134
|
+
getDecryptKeys(spkId) {
|
|
135
|
+
this.ensureKeys();
|
|
136
|
+
if (!spkId)
|
|
137
|
+
return { ikPriv: this._ikPriv };
|
|
138
|
+
if (spkId === this._spkId)
|
|
139
|
+
return { ikPriv: this._ikPriv, spkPriv: this._spkPriv };
|
|
140
|
+
const oldSPK = this._store.loadSPK(this._deviceId, spkId);
|
|
141
|
+
if (!oldSPK)
|
|
142
|
+
return { ikPriv: this._ikPriv };
|
|
143
|
+
return { ikPriv: this._ikPriv, spkPriv: oldSPK };
|
|
144
|
+
}
|
|
145
|
+
/** 判断 spkId 是否命中当前活跃 SPK。 */
|
|
146
|
+
isCurrentSPK(spkId) {
|
|
147
|
+
return Boolean(spkId) && spkId === this._spkId;
|
|
148
|
+
}
|
|
149
|
+
/** 跟踪每个旧 SPK 引用的最大 seq(用于销毁判定)。 */
|
|
150
|
+
trackOldSPKMaxSeq(spkId, seq) {
|
|
151
|
+
if (!spkId || spkId === this._spkId)
|
|
152
|
+
return;
|
|
153
|
+
const cur = this._oldSPKMaxSeq.get(spkId);
|
|
154
|
+
const curSeq = cur ? cur.seq : 0;
|
|
155
|
+
if (seq > curSeq) {
|
|
156
|
+
this._oldSPKMaxSeq.set(spkId, { seq, lastSeenAt: this._nowFn() });
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* contig_seq 已覆盖、超过 7h 安全窗口、且不在最近 7 代保留窗口内时销毁。
|
|
161
|
+
*
|
|
162
|
+
* 销毁条件(全部满足才销毁):
|
|
163
|
+
* - contig_seq >= 该 SPK 引用的最大 seq(接收方已消费完所有引用此 SPK 的消息)
|
|
164
|
+
* - 自最后一次见到该 spk_id 引用 >= 7 小时
|
|
165
|
+
* - 不在最近 7 代 SPK 保留窗口内
|
|
166
|
+
*
|
|
167
|
+
* 7h + 7 代双兜底:低频群即便 contig_seq 已覆盖也至少留 7 代或 7h,
|
|
168
|
+
* 避免发送方陈旧 bootstrap 缓存导致新消息加密失败。
|
|
169
|
+
*/
|
|
170
|
+
maybeDestroyOldSPKs(contigSeq) {
|
|
171
|
+
const destroyed = [];
|
|
172
|
+
const now = this._nowFn();
|
|
173
|
+
let recentKeep;
|
|
174
|
+
try {
|
|
175
|
+
recentKeep = new Set(this._store.listRecentSPKIds(this._deviceId, RECENT_GENERATIONS));
|
|
176
|
+
}
|
|
177
|
+
catch {
|
|
178
|
+
recentKeep = new Set();
|
|
179
|
+
}
|
|
180
|
+
for (const [spkId, info] of Array.from(this._oldSPKMaxSeq.entries())) {
|
|
181
|
+
if (spkId === this._spkId)
|
|
182
|
+
continue;
|
|
183
|
+
if (contigSeq < info.seq)
|
|
184
|
+
continue;
|
|
185
|
+
if (now - info.lastSeenAt < DESTROY_DELAY_MS)
|
|
186
|
+
continue;
|
|
187
|
+
if (recentKeep.has(spkId))
|
|
188
|
+
continue;
|
|
189
|
+
try {
|
|
190
|
+
this._store.deleteSPK(this._deviceId, spkId);
|
|
191
|
+
}
|
|
192
|
+
catch {
|
|
193
|
+
// 忽略 delete 失败,但 _oldSPKMaxSeq 仍清理避免重复尝试
|
|
194
|
+
}
|
|
195
|
+
this._oldSPKMaxSeq.delete(spkId);
|
|
196
|
+
destroyed.push(spkId);
|
|
197
|
+
}
|
|
198
|
+
// 180 天硬上限:无论是否被引用,超龄 SPK 强制销毁
|
|
199
|
+
try {
|
|
200
|
+
const expired = this._store.listExpiredSPKIds(this._deviceId, HARD_LIMIT_MS);
|
|
201
|
+
for (const spkId of expired) {
|
|
202
|
+
if (spkId === this._spkId)
|
|
203
|
+
continue;
|
|
204
|
+
try {
|
|
205
|
+
this._store.deleteSPK(this._deviceId, spkId);
|
|
206
|
+
}
|
|
207
|
+
catch { /* ignore */ }
|
|
208
|
+
this._oldSPKMaxSeq.delete(spkId);
|
|
209
|
+
if (!destroyed.includes(spkId))
|
|
210
|
+
destroyed.push(spkId);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
catch { /* ignore */ }
|
|
214
|
+
return destroyed;
|
|
215
|
+
}
|
|
216
|
+
/** 轮换 SPK:生成新 SPK 并上报到服务端。旧 SPK 保留本地用于解密。 */
|
|
217
|
+
async rotateSPK(callFn) {
|
|
218
|
+
this._generateNewSPK();
|
|
219
|
+
await this._registerSPK(callFn);
|
|
220
|
+
}
|
|
221
|
+
cachePeerIK(peerAid, deviceId, ikPubDer) {
|
|
222
|
+
this._peerIKCache.set(`${peerAid}#${deviceId}`, { pubDer: ikPubDer, cachedAt: this._nowFn() });
|
|
223
|
+
}
|
|
224
|
+
getPeerIK(peerAid, deviceId) {
|
|
225
|
+
const key = `${peerAid}#${deviceId}`;
|
|
226
|
+
const entry = this._peerIKCache.get(key);
|
|
227
|
+
if (!entry)
|
|
228
|
+
return null;
|
|
229
|
+
if (this._nowFn() - entry.cachedAt >= PEER_KEY_CACHE_TTL_MS) {
|
|
230
|
+
this._peerIKCache.delete(key);
|
|
231
|
+
return null;
|
|
232
|
+
}
|
|
233
|
+
return entry.pubDer;
|
|
234
|
+
}
|
|
235
|
+
isPeerSPKVerified(peerAid, deviceId, spkId) {
|
|
236
|
+
return this._verifiedSPKs.has(`${peerAid}#${deviceId}#${spkId}`);
|
|
237
|
+
}
|
|
238
|
+
markPeerSPKVerified(peerAid, deviceId, spkId) {
|
|
239
|
+
this._verifiedSPKs.add(`${peerAid}#${deviceId}#${spkId}`);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
//# sourceMappingURL=session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../../src/v2/session/session.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2: state_commitment 计算
|
|
3
|
+
*
|
|
4
|
+
* 规范引用:§6.2
|
|
5
|
+
*
|
|
6
|
+
* state_commitment = SHA256(
|
|
7
|
+
* "AUN-V2-SC-v1" ||
|
|
8
|
+
* group_id ||
|
|
9
|
+
* uint32(epoch, big-endian) ||
|
|
10
|
+
* canonical_json({
|
|
11
|
+
* "members": [...sorted by aid, devices sorted by device_id...],
|
|
12
|
+
* "audit_aids": [...sorted...],
|
|
13
|
+
* "join_policy_hash": "64hex" | null,
|
|
14
|
+
* "admin_set": {"admin_aids": [...sorted...], "threshold": N},
|
|
15
|
+
* "recovery_quorum": {...} | null,
|
|
16
|
+
* "history_policy": "none" | "recent_N_days" | "full",
|
|
17
|
+
* "wrap_protocol": "3DH" | "1DH"
|
|
18
|
+
* })
|
|
19
|
+
* )
|
|
20
|
+
*
|
|
21
|
+
* 排序在内部完成,调用方无需预排序。
|
|
22
|
+
*/
|
|
23
|
+
export declare const STATE_PREFIX: Uint8Array;
|
|
24
|
+
export interface MemberDevice {
|
|
25
|
+
device_id?: string;
|
|
26
|
+
fp?: string;
|
|
27
|
+
[k: string]: unknown;
|
|
28
|
+
}
|
|
29
|
+
export interface Member {
|
|
30
|
+
aid?: string;
|
|
31
|
+
devices?: MemberDevice[];
|
|
32
|
+
[k: string]: unknown;
|
|
33
|
+
}
|
|
34
|
+
export interface AdminSet {
|
|
35
|
+
admin_aids?: string[];
|
|
36
|
+
threshold?: number;
|
|
37
|
+
[k: string]: unknown;
|
|
38
|
+
}
|
|
39
|
+
export interface RecoveryQuorum {
|
|
40
|
+
trigger?: string;
|
|
41
|
+
quorum_aids?: string[];
|
|
42
|
+
threshold?: number;
|
|
43
|
+
[k: string]: unknown;
|
|
44
|
+
}
|
|
45
|
+
export interface StatePayload {
|
|
46
|
+
members?: Member[];
|
|
47
|
+
audit_aids?: string[];
|
|
48
|
+
join_policy_hash?: string | null;
|
|
49
|
+
admin_set?: AdminSet;
|
|
50
|
+
recovery_quorum?: RecoveryQuorum | null;
|
|
51
|
+
history_policy?: string;
|
|
52
|
+
wrap_protocol?: string;
|
|
53
|
+
[k: string]: unknown;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* 计算 state_commitment(hex)。
|
|
57
|
+
*/
|
|
58
|
+
export declare function computeStateCommitment(groupId: string, epoch: number, statePayload: StatePayload): string;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2: state_commitment 计算
|
|
3
|
+
*
|
|
4
|
+
* 规范引用:§6.2
|
|
5
|
+
*
|
|
6
|
+
* state_commitment = SHA256(
|
|
7
|
+
* "AUN-V2-SC-v1" ||
|
|
8
|
+
* group_id ||
|
|
9
|
+
* uint32(epoch, big-endian) ||
|
|
10
|
+
* canonical_json({
|
|
11
|
+
* "members": [...sorted by aid, devices sorted by device_id...],
|
|
12
|
+
* "audit_aids": [...sorted...],
|
|
13
|
+
* "join_policy_hash": "64hex" | null,
|
|
14
|
+
* "admin_set": {"admin_aids": [...sorted...], "threshold": N},
|
|
15
|
+
* "recovery_quorum": {...} | null,
|
|
16
|
+
* "history_policy": "none" | "recent_N_days" | "full",
|
|
17
|
+
* "wrap_protocol": "3DH" | "1DH"
|
|
18
|
+
* })
|
|
19
|
+
* )
|
|
20
|
+
*
|
|
21
|
+
* 排序在内部完成,调用方无需预排序。
|
|
22
|
+
*/
|
|
23
|
+
import { createHash } from 'node:crypto';
|
|
24
|
+
import { canonicalJson } from '../crypto/canonical.js';
|
|
25
|
+
export const STATE_PREFIX = new TextEncoder().encode('AUN-V2-SC-v1');
|
|
26
|
+
/** in-place 规范化排序。 */
|
|
27
|
+
function sortPayload(payload) {
|
|
28
|
+
if (Array.isArray(payload.members)) {
|
|
29
|
+
payload.members.sort((a, b) => {
|
|
30
|
+
const ka = a.aid ?? '';
|
|
31
|
+
const kb = b.aid ?? '';
|
|
32
|
+
if (ka === kb)
|
|
33
|
+
return 0;
|
|
34
|
+
return ka < kb ? -1 : 1;
|
|
35
|
+
});
|
|
36
|
+
for (const m of payload.members) {
|
|
37
|
+
if (Array.isArray(m.devices)) {
|
|
38
|
+
m.devices.sort((a, b) => {
|
|
39
|
+
const ka = a.device_id ?? '';
|
|
40
|
+
const kb = b.device_id ?? '';
|
|
41
|
+
if (ka === kb)
|
|
42
|
+
return 0;
|
|
43
|
+
return ka < kb ? -1 : 1;
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if (Array.isArray(payload.audit_aids)) {
|
|
49
|
+
payload.audit_aids.sort();
|
|
50
|
+
}
|
|
51
|
+
if (payload.admin_set && Array.isArray(payload.admin_set.admin_aids)) {
|
|
52
|
+
payload.admin_set.admin_aids.sort();
|
|
53
|
+
}
|
|
54
|
+
if (payload.recovery_quorum && Array.isArray(payload.recovery_quorum.quorum_aids)) {
|
|
55
|
+
payload.recovery_quorum.quorum_aids.sort();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
/** 大端 uint32 编码。 */
|
|
59
|
+
function uint32BE(value) {
|
|
60
|
+
if (value < 0 || value > 0xffffffff || !Number.isInteger(value)) {
|
|
61
|
+
throw new Error(`epoch out of uint32 range: ${value}`);
|
|
62
|
+
}
|
|
63
|
+
const out = new Uint8Array(4);
|
|
64
|
+
const dv = new DataView(out.buffer);
|
|
65
|
+
dv.setUint32(0, value, false);
|
|
66
|
+
return out;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* 计算 state_commitment(hex)。
|
|
70
|
+
*/
|
|
71
|
+
export function computeStateCommitment(groupId, epoch, statePayload) {
|
|
72
|
+
// 深拷贝避免修改调用方数据
|
|
73
|
+
const payload = JSON.parse(JSON.stringify(statePayload));
|
|
74
|
+
sortPayload(payload);
|
|
75
|
+
const groupBytes = new TextEncoder().encode(groupId);
|
|
76
|
+
const epochBytes = uint32BE(epoch);
|
|
77
|
+
const payloadBytes = canonicalJson(payload);
|
|
78
|
+
const h = createHash('sha256');
|
|
79
|
+
h.update(STATE_PREFIX);
|
|
80
|
+
h.update(groupBytes);
|
|
81
|
+
h.update(epochBytes);
|
|
82
|
+
h.update(payloadBytes);
|
|
83
|
+
return h.digest('hex');
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=commitment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commitment.js","sourceRoot":"","sources":["../../../src/v2/state/commitment.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/v2/state/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,42 +1,46 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@agentunion/fastaun",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "AUN Protocol Core SDK for Node.js",
|
|
5
|
-
"type": "module",
|
|
6
|
-
"main": "dist/index.js",
|
|
7
|
-
"types": "dist/index.d.ts",
|
|
8
|
-
"exports": {
|
|
9
|
-
".": {
|
|
10
|
-
"import": "./dist/index.js",
|
|
11
|
-
"types": "./dist/index.d.ts"
|
|
12
|
-
}
|
|
13
|
-
},
|
|
14
|
-
"engines": {
|
|
15
|
-
"node": ">=22.16.0"
|
|
16
|
-
},
|
|
17
|
-
"license": "Apache-2.0",
|
|
18
|
-
"files": [
|
|
19
|
-
"dist",
|
|
20
|
-
"
|
|
21
|
-
"
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"test
|
|
29
|
-
"test:
|
|
30
|
-
"test:
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
"
|
|
34
|
-
},
|
|
35
|
-
"
|
|
36
|
-
"@
|
|
37
|
-
"
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
"
|
|
41
|
-
|
|
42
|
-
|
|
1
|
+
{
|
|
2
|
+
"name": "@agentunion/fastaun",
|
|
3
|
+
"version": "0.3.0",
|
|
4
|
+
"description": "AUN Protocol Core SDK for Node.js",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/index.js",
|
|
7
|
+
"types": "dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"import": "./dist/index.js",
|
|
11
|
+
"types": "./dist/index.d.ts"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"engines": {
|
|
15
|
+
"node": ">=22.16.0"
|
|
16
|
+
},
|
|
17
|
+
"license": "Apache-2.0",
|
|
18
|
+
"files": [
|
|
19
|
+
"dist",
|
|
20
|
+
"_packed_docs",
|
|
21
|
+
"README.md",
|
|
22
|
+
"CHANGELOG.md",
|
|
23
|
+
"LICENSE"
|
|
24
|
+
],
|
|
25
|
+
"scripts": {
|
|
26
|
+
"build": "tsc",
|
|
27
|
+
"prepack": "python ../scripts/sync_packed_docs.py ts",
|
|
28
|
+
"test": "vitest run",
|
|
29
|
+
"test:unit": "vitest run tests/unit",
|
|
30
|
+
"test:integration": "vitest run tests/integration/federation-v2-thought.test.ts tests/integration/group-e2ee.test.ts",
|
|
31
|
+
"test:e2e": "vitest run tests/e2e/v2-p2p.test.ts tests/e2e/v2-group.test.ts tests/e2e/v2-thought.test.ts",
|
|
32
|
+
"test:federation": "vitest run tests/integration/federation.test.ts tests/integration/federation-storage.test.ts",
|
|
33
|
+
"test:watch": "vitest"
|
|
34
|
+
},
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"@noble/curves": "^2.2.0",
|
|
37
|
+
"ws": "^8.18.0"
|
|
38
|
+
},
|
|
39
|
+
"devDependencies": {
|
|
40
|
+
"@types/node": "^22.0.0",
|
|
41
|
+
"@types/ws": "^8.5.0",
|
|
42
|
+
"@vitest/coverage-v8": "^4.1.3",
|
|
43
|
+
"typescript": "^5.6.0",
|
|
44
|
+
"vitest": "^2.0.0"
|
|
45
|
+
}
|
|
46
|
+
}
|