@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.
Files changed (162) hide show
  1. package/CHANGELOG.md +46 -0
  2. package/_packed_docs/CHANGELOG.md +46 -0
  3. package/_packed_docs/agent.md/SCHEMA.md +173 -0
  4. package/_packed_docs/agent.md/examples/codeagent-claudecode.md +61 -0
  5. package/_packed_docs/agent.md/examples/human-developer.md +60 -0
  6. package/_packed_docs/agent.md/examples/openclaw-lobster.md +52 -0
  7. package/_packed_docs/agent.md/examples/signed-openclaw-lobster.md +43 -0
  8. package/_packed_docs/protocol/00-/346/200/273/350/247/210/344/270/216/345/210/206/345/261/202.md +205 -0
  9. 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
  10. 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
  11. 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
  12. package/_packed_docs/protocol/03-Gateway-/350/277/236/346/216/245/346/250/241/345/274/217.md +262 -0
  13. package/_packed_docs/protocol/04-Peer-/345/255/220/345/215/217/350/256/256.md +180 -0
  14. package/_packed_docs/protocol/05-Relay-/345/255/220/345/215/217/350/256/256.md +164 -0
  15. package/_packed_docs/protocol/06-/346/234/215/345/212/241/345/215/217/350/256/256.md +1135 -0
  16. 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
  17. package/_packed_docs/protocol/08-AUN-E2EE-Group.md +900 -0
  18. package/_packed_docs/protocol/08-AUN-E2EE.md +413 -0
  19. package/_packed_docs/protocol/09-/345/256/211/345/205/250/350/200/203/350/231/221.md +316 -0
  20. package/_packed_docs/protocol/10-Group-/345/255/220/345/215/217/350/256/256.md +804 -0
  21. package/_packed_docs/protocol/11-Storage-/345/255/220/345/215/217/350/256/256.md +271 -0
  22. package/_packed_docs/protocol/12-Stream-/345/255/220/345/215/217/350/256/256.md +329 -0
  23. package/_packed_docs/protocol/13-Agent/350/241/214/344/270/272/350/247/204/350/214/203.md +141 -0
  24. 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
  25. 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
  26. package/_packed_docs/protocol/README.md +71 -0
  27. package/_packed_docs/protocol/agent.md/SCHEMA.md +118 -0
  28. package/_packed_docs/protocol/agent.md/examples/codeagent-claudecode.md +61 -0
  29. package/_packed_docs/protocol/agent.md/examples/human-developer.md +60 -0
  30. package/_packed_docs/protocol/agent.md/examples/openclaw-lobster.md +52 -0
  31. package/_packed_docs/protocol/aun-docs-guide.md +49 -0
  32. package/_packed_docs/protocol/index.md +124 -0
  33. 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
  34. 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
  35. package/_packed_docs/protocol//351/231/204/345/275/225A-/346/234/257/350/257/255/350/241/250.md +337 -0
  36. 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
  37. 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
  38. 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
  39. 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
  40. 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
  41. 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
  42. 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
  43. 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
  44. 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
  45. 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
  46. 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
  47. 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
  48. package/_packed_docs/python-sdk-v2-only-changelog.md +189 -0
  49. package/_packed_docs/sdk/01-/345/277/253/351/200/237/345/274/200/345/247/213.md +223 -0
  50. package/_packed_docs/sdk/02-WebSocket/345/215/217/350/256/256.md +354 -0
  51. package/_packed_docs/sdk/03-/346/240/270/345/277/203/346/246/202/345/277/265.md +172 -0
  52. package/_packed_docs/sdk/04-/350/277/236/346/216/245/344/270/216/350/256/244/350/257/201.md +396 -0
  53. package/_packed_docs/sdk/05-E2EE/345/212/240/345/257/206/351/200/232/344/277/241.md +611 -0
  54. package/_packed_docs/sdk/06-API/346/211/213/345/206/214.md +1203 -0
  55. package/_packed_docs/sdk/07-/351/224/231/350/257/257/345/244/204/347/220/206.md +150 -0
  56. package/_packed_docs/sdk/08-/346/234/200/344/275/263/345/256/236/350/267/265.md +89 -0
  57. package/_packed_docs/sdk/09-custody-api-manual.md +445 -0
  58. package/_packed_docs/sdk/09-group-rpc-manual.md +1895 -0
  59. package/_packed_docs/sdk/09-message-rpc-manual.md +597 -0
  60. package/_packed_docs/sdk/09-meta-rpc-manual.md +142 -0
  61. package/_packed_docs/sdk/09-payload-reference.md +702 -0
  62. package/_packed_docs/sdk/09-storage-rpc-manual.md +408 -0
  63. package/_packed_docs/sdk/09-stream-rpc-manual.md +275 -0
  64. package/_packed_docs/sdk/AUN_DOCS_GUIDE.md +72 -0
  65. package/_packed_docs/sdk/INDEX.md +131 -0
  66. package/_packed_docs/sdk/README.md +307 -0
  67. package/dist/auth.d.ts +2 -1
  68. package/dist/auth.js +37 -18
  69. package/dist/auth.js.map +1 -1
  70. package/dist/client.d.ts +147 -171
  71. package/dist/client.js +2583 -3916
  72. package/dist/client.js.map +1 -1
  73. package/dist/config.d.ts +0 -4
  74. package/dist/config.js +0 -4
  75. package/dist/config.js.map +1 -1
  76. package/dist/e2ee.d.ts +5 -139
  77. package/dist/e2ee.js +4 -1151
  78. package/dist/e2ee.js.map +1 -1
  79. package/dist/errors.d.ts +0 -8
  80. package/dist/errors.js +0 -14
  81. package/dist/errors.js.map +1 -1
  82. package/dist/index.d.ts +9 -5
  83. package/dist/index.js +6 -3
  84. package/dist/index.js.map +1 -1
  85. package/dist/keystore/aid-db.d.ts +12 -61
  86. package/dist/keystore/aid-db.js +41 -539
  87. package/dist/keystore/aid-db.js.map +1 -1
  88. package/dist/keystore/file.d.ts +5 -41
  89. package/dist/keystore/file.js +8 -64
  90. package/dist/keystore/file.js.map +1 -1
  91. package/dist/keystore/index.d.ts +1 -49
  92. package/dist/namespaces/auth.d.ts +1 -0
  93. package/dist/namespaces/auth.js +22 -6
  94. package/dist/namespaces/auth.js.map +1 -1
  95. package/dist/protected-headers.d.ts +13 -0
  96. package/dist/protected-headers.js +47 -0
  97. package/dist/protected-headers.js.map +1 -0
  98. package/dist/seq-tracker.d.ts +7 -2
  99. package/dist/seq-tracker.js +31 -10
  100. package/dist/seq-tracker.js.map +1 -1
  101. package/dist/transport.d.ts +10 -0
  102. package/dist/transport.js +24 -0
  103. package/dist/transport.js.map +1 -1
  104. package/dist/types.d.ts +0 -56
  105. package/dist/v2/crypto/aead.d.ts +20 -0
  106. package/dist/v2/crypto/aead.js +59 -0
  107. package/dist/v2/crypto/aead.js.map +1 -0
  108. package/dist/v2/crypto/canonical.d.ts +20 -0
  109. package/dist/v2/crypto/canonical.js +119 -0
  110. package/dist/v2/crypto/canonical.js.map +1 -0
  111. package/dist/v2/crypto/dh-path.d.ts +39 -0
  112. package/dist/v2/crypto/dh-path.js +55 -0
  113. package/dist/v2/crypto/dh-path.js.map +1 -0
  114. package/dist/v2/crypto/ecdh.d.ts +29 -0
  115. package/dist/v2/crypto/ecdh.js +122 -0
  116. package/dist/v2/crypto/ecdh.js.map +1 -0
  117. package/dist/v2/crypto/ecdsa.d.ts +29 -0
  118. package/dist/v2/crypto/ecdsa.js +120 -0
  119. package/dist/v2/crypto/ecdsa.js.map +1 -0
  120. package/dist/v2/crypto/hkdf.d.ts +19 -0
  121. package/dist/v2/crypto/hkdf.js +47 -0
  122. package/dist/v2/crypto/hkdf.js.map +1 -0
  123. package/dist/v2/crypto/index.d.ts +8 -0
  124. package/dist/v2/crypto/index.js +8 -0
  125. package/dist/v2/crypto/index.js.map +1 -0
  126. package/dist/v2/crypto/recipients.d.ts +32 -0
  127. package/dist/v2/crypto/recipients.js +183 -0
  128. package/dist/v2/crypto/recipients.js.map +1 -0
  129. package/dist/v2/e2ee/decrypt.d.ts +29 -0
  130. package/dist/v2/e2ee/decrypt.js +159 -0
  131. package/dist/v2/e2ee/decrypt.js.map +1 -0
  132. package/dist/v2/e2ee/encrypt-group.d.ts +17 -0
  133. package/dist/v2/e2ee/encrypt-group.js +143 -0
  134. package/dist/v2/e2ee/encrypt-group.js.map +1 -0
  135. package/dist/v2/e2ee/encrypt-p2p.d.ts +31 -0
  136. package/dist/v2/e2ee/encrypt-p2p.js +190 -0
  137. package/dist/v2/e2ee/encrypt-p2p.js.map +1 -0
  138. package/dist/v2/e2ee/index.d.ts +9 -0
  139. package/dist/v2/e2ee/index.js +9 -0
  140. package/dist/v2/e2ee/index.js.map +1 -0
  141. package/dist/v2/e2ee/metadata-auth.d.ts +15 -0
  142. package/dist/v2/e2ee/metadata-auth.js +50 -0
  143. package/dist/v2/e2ee/metadata-auth.js.map +1 -0
  144. package/dist/v2/e2ee/types.d.ts +57 -0
  145. package/dist/v2/e2ee/types.js +7 -0
  146. package/dist/v2/e2ee/types.js.map +1 -0
  147. package/dist/v2/session/index.d.ts +4 -0
  148. package/dist/v2/session/index.js +3 -0
  149. package/dist/v2/session/index.js.map +1 -0
  150. package/dist/v2/session/keystore.d.ts +41 -0
  151. package/dist/v2/session/keystore.js +103 -0
  152. package/dist/v2/session/keystore.js.map +1 -0
  153. package/dist/v2/session/session.d.ts +97 -0
  154. package/dist/v2/session/session.js +242 -0
  155. package/dist/v2/session/session.js.map +1 -0
  156. package/dist/v2/state/commitment.d.ts +58 -0
  157. package/dist/v2/state/commitment.js +85 -0
  158. package/dist/v2/state/commitment.js.map +1 -0
  159. package/dist/v2/state/index.d.ts +2 -0
  160. package/dist/v2/state/index.js +2 -0
  161. package/dist/v2/state/index.js.map +1 -0
  162. 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,2 @@
1
+ export { computeStateCommitment, STATE_PREFIX } from './commitment.js';
2
+ export type { Member, MemberDevice, AdminSet, RecoveryQuorum, StatePayload } from './commitment.js';
@@ -0,0 +1,2 @@
1
+ export { computeStateCommitment, STATE_PREFIX } from './commitment.js';
2
+ //# sourceMappingURL=index.js.map
@@ -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.2.19",
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
- "README.md",
21
- "LICENSE"
22
- ],
23
- "scripts": {
24
- "build": "tsc",
25
- "test": "vitest run",
26
- "test:unit": "vitest run tests/unit",
27
- "test:integration": "vitest run tests/integration/e2ee.test.ts",
28
- "test:e2e": "vitest run tests/e2e/group-e2ee.test.ts",
29
- "test:federation": "vitest run tests/integration/federation.test.ts tests/integration/federation-storage.test.ts",
30
- "test:watch": "vitest"
31
- },
32
- "dependencies": {
33
- "ws": "^8.18.0"
34
- },
35
- "devDependencies": {
36
- "@types/node": "^22.0.0",
37
- "@types/ws": "^8.5.0",
38
- "@vitest/coverage-v8": "^4.1.3",
39
- "typescript": "^5.6.0",
40
- "vitest": "^2.0.0"
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
+ }