@agentunion/fastaun-browser 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 +50 -0
- package/_packed_docs/CHANGELOG.md +50 -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.d.ts.map +1 -1
- package/dist/auth.js +33 -14
- package/dist/auth.js.map +1 -1
- package/dist/bundle.js +14300 -0
- package/dist/client.d.ts +200 -178
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +3096 -4019
- package/dist/client.js.map +1 -1
- package/dist/config.d.ts +0 -4
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +0 -4
- package/dist/config.js.map +1 -1
- package/dist/crypto.d.ts +8 -1
- package/dist/crypto.d.ts.map +1 -1
- package/dist/crypto.js +114 -1
- package/dist/crypto.js.map +1 -1
- package/dist/e2ee.d.ts +5 -210
- package/dist/e2ee.d.ts.map +1 -1
- package/dist/e2ee.js +4 -1379
- package/dist/e2ee.js.map +1 -1
- package/dist/index.d.ts +7 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -4
- package/dist/index.js.map +1 -1
- package/dist/namespaces/auth.d.ts +1 -0
- package/dist/namespaces/auth.d.ts.map +1 -1
- package/dist/namespaces/auth.js +23 -8
- package/dist/namespaces/auth.js.map +1 -1
- package/dist/protected-headers.d.ts +14 -0
- package/dist/protected-headers.d.ts.map +1 -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.d.ts.map +1 -1
- package/dist/seq-tracker.js +31 -10
- package/dist/seq-tracker.js.map +1 -1
- package/dist/transport.d.ts +9 -1
- package/dist/transport.d.ts.map +1 -1
- package/dist/transport.js +24 -0
- package/dist/transport.js.map +1 -1
- package/dist/v2/crypto/aead.d.ts +26 -0
- package/dist/v2/crypto/aead.d.ts.map +1 -0
- package/dist/v2/crypto/aead.js +63 -0
- package/dist/v2/crypto/aead.js.map +1 -0
- package/dist/v2/crypto/canonical.d.ts +21 -0
- package/dist/v2/crypto/canonical.d.ts.map +1 -0
- package/dist/v2/crypto/canonical.js +111 -0
- package/dist/v2/crypto/canonical.js.map +1 -0
- package/dist/v2/crypto/dh-path.d.ts +21 -0
- package/dist/v2/crypto/dh-path.d.ts.map +1 -0
- package/dist/v2/crypto/dh-path.js +50 -0
- package/dist/v2/crypto/dh-path.js.map +1 -0
- package/dist/v2/crypto/ecdh.d.ts +19 -0
- package/dist/v2/crypto/ecdh.d.ts.map +1 -0
- package/dist/v2/crypto/ecdh.js +101 -0
- package/dist/v2/crypto/ecdh.js.map +1 -0
- package/dist/v2/crypto/ecdsa.d.ts +16 -0
- package/dist/v2/crypto/ecdsa.d.ts.map +1 -0
- package/dist/v2/crypto/ecdsa.js +52 -0
- package/dist/v2/crypto/ecdsa.js.map +1 -0
- package/dist/v2/crypto/hkdf.d.ts +21 -0
- package/dist/v2/crypto/hkdf.d.ts.map +1 -0
- package/dist/v2/crypto/hkdf.js +32 -0
- package/dist/v2/crypto/hkdf.js.map +1 -0
- package/dist/v2/crypto/index.d.ts +9 -0
- package/dist/v2/crypto/index.d.ts.map +1 -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 +43 -0
- package/dist/v2/crypto/recipients.d.ts.map +1 -0
- package/dist/v2/crypto/recipients.js +188 -0
- package/dist/v2/crypto/recipients.js.map +1 -0
- package/dist/v2/e2ee/decrypt.d.ts +13 -0
- package/dist/v2/e2ee/decrypt.d.ts.map +1 -0
- package/dist/v2/e2ee/decrypt.js +176 -0
- package/dist/v2/e2ee/decrypt.js.map +1 -0
- package/dist/v2/e2ee/encrypt-group.d.ts +14 -0
- package/dist/v2/e2ee/encrypt-group.d.ts.map +1 -0
- package/dist/v2/e2ee/encrypt-group.js +196 -0
- package/dist/v2/e2ee/encrypt-group.js.map +1 -0
- package/dist/v2/e2ee/encrypt-p2p.d.ts +15 -0
- package/dist/v2/e2ee/encrypt-p2p.d.ts.map +1 -0
- package/dist/v2/e2ee/encrypt-p2p.js +240 -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.d.ts.map +1 -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 +9 -0
- package/dist/v2/e2ee/metadata-auth.d.ts.map +1 -0
- package/dist/v2/e2ee/metadata-auth.js +60 -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.d.ts.map +1 -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.d.ts.map +1 -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 +48 -0
- package/dist/v2/session/keystore.d.ts.map +1 -0
- package/dist/v2/session/keystore.js +184 -0
- package/dist/v2/session/keystore.js.map +1 -0
- package/dist/v2/session/session.d.ts +98 -0
- package/dist/v2/session/session.d.ts.map +1 -0
- package/dist/v2/session/session.js +270 -0
- package/dist/v2/session/session.js.map +1 -0
- package/dist/v2/state/commitment.d.ts +10 -0
- package/dist/v2/state/commitment.d.ts.map +1 -0
- package/dist/v2/state/commitment.js +86 -0
- package/dist/v2/state/commitment.js.map +1 -0
- package/dist/v2/state/index.d.ts +2 -0
- package/dist/v2/state/index.d.ts.map +1 -0
- package/dist/v2/state/index.js +2 -0
- package/dist/v2/state/index.js.map +1 -0
- package/package.json +43 -37
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2: 加解密引擎类型定义
|
|
3
|
+
*
|
|
4
|
+
* 与 Python `aun_core.v2.e2ee.encrypt_p2p` / `encrypt_group` / `decrypt` 对齐。
|
|
5
|
+
*/
|
|
6
|
+
export declare const SUITE_NAME: "P256_HKDF_SHA256_AES_256_GCM";
|
|
7
|
+
/** 发送方身份。 */
|
|
8
|
+
export interface Sender {
|
|
9
|
+
/** 发送方 AID。 */
|
|
10
|
+
aid: string;
|
|
11
|
+
/** 发送方 device_id。 */
|
|
12
|
+
deviceId: string;
|
|
13
|
+
/** 32 字节 P-256 私钥标量(AID 主私钥)。 */
|
|
14
|
+
ikPriv: Uint8Array;
|
|
15
|
+
/** SPKI DER 编码的公钥(用于签名指纹计算)。 */
|
|
16
|
+
ikPubDer: Uint8Array;
|
|
17
|
+
}
|
|
18
|
+
/** 接收方目标设备。 */
|
|
19
|
+
export interface Target {
|
|
20
|
+
aid: string;
|
|
21
|
+
deviceId: string;
|
|
22
|
+
/** "peer" | "member" | "self_sync" | "audit" 等。 */
|
|
23
|
+
role: string;
|
|
24
|
+
/** "peer_device_prekey" | "group_device_prekey" | "aid_master"。 */
|
|
25
|
+
keySource: string;
|
|
26
|
+
/** 接收方 IK 公钥(DER SPKI)。 */
|
|
27
|
+
ikPkDer: Uint8Array;
|
|
28
|
+
/** 接收方 SPK 公钥(DER SPKI);undefined 表示走 1DH 路径。 */
|
|
29
|
+
spkPkDer?: Uint8Array;
|
|
30
|
+
/** SPK 标识;3DH 时为非空字符串,1DH 时为空串/未定义。 */
|
|
31
|
+
spkId?: string;
|
|
32
|
+
}
|
|
33
|
+
/** 接收方集合(P2P)。 */
|
|
34
|
+
export interface TargetSet {
|
|
35
|
+
/** 普通接收设备。 */
|
|
36
|
+
targets: Target[];
|
|
37
|
+
/** 监管方设备(可选)。 */
|
|
38
|
+
auditRecipients?: Target[];
|
|
39
|
+
}
|
|
40
|
+
/** 加密可选参数。 */
|
|
41
|
+
export interface EncryptOptions {
|
|
42
|
+
/** 消息 ID;不传则自动生成 `m-{uuid4 hex}`。 */
|
|
43
|
+
messageId?: string;
|
|
44
|
+
/** 时间戳(毫秒);不传则用 Date.now()。 */
|
|
45
|
+
timestamp?: number;
|
|
46
|
+
/** 受保护头部(HMAC 签名后附加到 envelope.protected_headers)。 */
|
|
47
|
+
protectedHeaders?: Record<string, unknown>;
|
|
48
|
+
/** 上下文元数据(HMAC 签名后附加到 envelope.context)。 */
|
|
49
|
+
context?: Record<string, unknown>;
|
|
50
|
+
}
|
|
51
|
+
/** Group AAD 中的 state_commitment 子结构。 */
|
|
52
|
+
export interface StateCommitmentAAD {
|
|
53
|
+
state_version: number;
|
|
54
|
+
state_hash: string;
|
|
55
|
+
state_chain: string;
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/v2/e2ee/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,eAAO,MAAM,UAAU,EAAG,8BAAuC,CAAC;AAElE,aAAa;AACb,MAAM,WAAW,MAAM;IACrB,eAAe;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,qBAAqB;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,iCAAiC;IACjC,MAAM,EAAE,UAAU,CAAC;IACnB,gCAAgC;IAChC,QAAQ,EAAE,UAAU,CAAC;CACtB;AAED,eAAe;AACf,MAAM,WAAW,MAAM;IACrB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,mDAAmD;IACnD,IAAI,EAAE,MAAM,CAAC;IACb,mEAAmE;IACnE,SAAS,EAAE,MAAM,CAAC;IAClB,2BAA2B;IAC3B,OAAO,EAAE,UAAU,CAAC;IACpB,iDAAiD;IACjD,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB,uCAAuC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,kBAAkB;AAClB,MAAM,WAAW,SAAS;IACxB,cAAc;IACd,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,iBAAiB;IACjB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,cAAc;AACd,MAAM,WAAW,cAAc;IAC7B,qCAAqC;IACrC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+BAA+B;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qDAAqD;IACrD,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,4CAA4C;IAC5C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,yCAAyC;AACzC,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;CACrB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/v2/e2ee/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,CAAC,MAAM,UAAU,GAAG,8BAAuC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { V2KeyStore, V2_DB_NAME, V2_DB_VERSION, V2_STORE_NAME } from './keystore';
|
|
2
|
+
export { V2Session, PEER_KEY_CACHE_TTL_MS, DESTROY_DELAY_MS, RECENT_GENERATIONS, } from './session';
|
|
3
|
+
export type { CallFn, SenderIdentity, DecryptKeys } from './session';
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/v2/session/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAClF,OAAO,EACL,SAAS,EACT,qBAAqB,EACrB,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,WAAW,CAAC;AACnB,YAAY,EAAE,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/v2/session/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAClF,OAAO,EACL,SAAS,EACT,qBAAqB,EACrB,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2: 设备密钥存储(IndexedDB 持久化)
|
|
3
|
+
*
|
|
4
|
+
* 与 Python `aun_core.v2.keystore.V2KeyStore` 行为对齐:
|
|
5
|
+
* - 每个 `(device_id)` 持有一对 IK 与若干 SPK(按 spk_id 索引)
|
|
6
|
+
* - SPK 按 created_at 排序,支持 `loadCurrentSPK` / `listRecentSPKIds(n)`
|
|
7
|
+
*
|
|
8
|
+
* 浏览器目标:所有 IO 是 async(IndexedDB 事务)。
|
|
9
|
+
*/
|
|
10
|
+
export declare const V2_DB_NAME = "aun_v2";
|
|
11
|
+
export declare const V2_DB_VERSION = 1;
|
|
12
|
+
export declare const V2_STORE_NAME = "v2_device_keys";
|
|
13
|
+
export declare const V2_INDEX_BY_DEVICE_TYPE_CREATED = "by_device_type_created";
|
|
14
|
+
/**
|
|
15
|
+
* V2 设备密钥持久化存储。复合主键 [device_id, key_type, key_id]。
|
|
16
|
+
*
|
|
17
|
+
* 使用 IndexedDB;在浏览器内置 indexedDB 不可用时(如 jsdom)请提前安装
|
|
18
|
+
* `fake-indexeddb/auto` 作为 polyfill(见 `tests/setup.ts`)。
|
|
19
|
+
*/
|
|
20
|
+
export declare class V2KeyStore {
|
|
21
|
+
private readonly db;
|
|
22
|
+
constructor(db: IDBDatabase);
|
|
23
|
+
/** 打开/创建 V2 keystore 数据库。 */
|
|
24
|
+
static open(dbName?: string): Promise<V2KeyStore>;
|
|
25
|
+
/** 关闭数据库连接(测试或释放资源时使用)。 */
|
|
26
|
+
close(): void;
|
|
27
|
+
private store;
|
|
28
|
+
saveSPK(deviceId: string, spkId: string, priv: Uint8Array, pubDer: Uint8Array): Promise<void>;
|
|
29
|
+
loadSPK(deviceId: string, spkId: string): Promise<Uint8Array | null>;
|
|
30
|
+
/** 取最新 SPK(按 created_at DESC LIMIT 1)。 */
|
|
31
|
+
loadCurrentSPK(deviceId: string): Promise<{
|
|
32
|
+
spkId: string;
|
|
33
|
+
priv: Uint8Array;
|
|
34
|
+
pubDer: Uint8Array;
|
|
35
|
+
} | null>;
|
|
36
|
+
deleteSPK(deviceId: string, spkId: string): Promise<void>;
|
|
37
|
+
/** 返回最近 N 代 SPK 的 spk_id(按 created_at DESC)。 */
|
|
38
|
+
listRecentSPKIds(deviceId: string, n: number): Promise<string[]>;
|
|
39
|
+
listExpiredSPKIds(deviceId: string, maxAgeMs: number): Promise<string[]>;
|
|
40
|
+
saveIK(deviceId: string, priv: Uint8Array, pubDer: Uint8Array): Promise<void>;
|
|
41
|
+
loadIK(deviceId: string): Promise<{
|
|
42
|
+
priv: Uint8Array;
|
|
43
|
+
pubDer: Uint8Array;
|
|
44
|
+
} | null>;
|
|
45
|
+
/** 测试用:清空 store。 */
|
|
46
|
+
_clear(): Promise<void>;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=keystore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keystore.d.ts","sourceRoot":"","sources":["../../../src/v2/session/keystore.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,eAAO,MAAM,UAAU,WAAW,CAAC;AACnC,eAAO,MAAM,aAAa,IAAI,CAAC;AAC/B,eAAO,MAAM,aAAa,mBAAmB,CAAC;AAC9C,eAAO,MAAM,+BAA+B,2BAA2B,CAAC;AAaxE;;;;;GAKG;AACH,qBAAa,UAAU;IACT,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,WAAW;IAE5C,6BAA6B;WAChB,IAAI,CAAC,MAAM,GAAE,MAAmB,GAAG,OAAO,CAAC,UAAU,CAAC;IAqBnE,2BAA2B;IAC3B,KAAK,IAAI,IAAI;IAIb,OAAO,CAAC,KAAK;IAMP,OAAO,CACX,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,UAAU,EAChB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,IAAI,CAAC;IAgBV,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAY1E,0CAA0C;IACpC,cAAc,CAClB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,UAAU,CAAC;QAAC,MAAM,EAAE,UAAU,CAAA;KAAE,GAAG,IAAI,CAAC;IAyBpE,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ/D,gDAAgD;IAC1C,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAuBhE,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IA0BxE,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB7E,MAAM,CACV,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC;QAAE,IAAI,EAAE,UAAU,CAAC;QAAC,MAAM,EAAE,UAAU,CAAA;KAAE,GAAG,IAAI,CAAC;IAe3D,oBAAoB;IACd,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;CAO9B"}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2: 设备密钥存储(IndexedDB 持久化)
|
|
3
|
+
*
|
|
4
|
+
* 与 Python `aun_core.v2.keystore.V2KeyStore` 行为对齐:
|
|
5
|
+
* - 每个 `(device_id)` 持有一对 IK 与若干 SPK(按 spk_id 索引)
|
|
6
|
+
* - SPK 按 created_at 排序,支持 `loadCurrentSPK` / `listRecentSPKIds(n)`
|
|
7
|
+
*
|
|
8
|
+
* 浏览器目标:所有 IO 是 async(IndexedDB 事务)。
|
|
9
|
+
*/
|
|
10
|
+
export const V2_DB_NAME = 'aun_v2';
|
|
11
|
+
export const V2_DB_VERSION = 1;
|
|
12
|
+
export const V2_STORE_NAME = 'v2_device_keys';
|
|
13
|
+
export const V2_INDEX_BY_DEVICE_TYPE_CREATED = 'by_device_type_created';
|
|
14
|
+
/**
|
|
15
|
+
* V2 设备密钥持久化存储。复合主键 [device_id, key_type, key_id]。
|
|
16
|
+
*
|
|
17
|
+
* 使用 IndexedDB;在浏览器内置 indexedDB 不可用时(如 jsdom)请提前安装
|
|
18
|
+
* `fake-indexeddb/auto` 作为 polyfill(见 `tests/setup.ts`)。
|
|
19
|
+
*/
|
|
20
|
+
export class V2KeyStore {
|
|
21
|
+
db;
|
|
22
|
+
constructor(db) {
|
|
23
|
+
this.db = db;
|
|
24
|
+
}
|
|
25
|
+
/** 打开/创建 V2 keystore 数据库。 */
|
|
26
|
+
static async open(dbName = V2_DB_NAME) {
|
|
27
|
+
return new Promise((resolve, reject) => {
|
|
28
|
+
const req = indexedDB.open(dbName, V2_DB_VERSION);
|
|
29
|
+
req.onupgradeneeded = () => {
|
|
30
|
+
const db = req.result;
|
|
31
|
+
if (!db.objectStoreNames.contains(V2_STORE_NAME)) {
|
|
32
|
+
const store = db.createObjectStore(V2_STORE_NAME, {
|
|
33
|
+
keyPath: ['device_id', 'key_type', 'key_id'],
|
|
34
|
+
});
|
|
35
|
+
store.createIndex(V2_INDEX_BY_DEVICE_TYPE_CREATED, ['device_id', 'key_type', 'created_at']);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
req.onsuccess = () => resolve(new V2KeyStore(req.result));
|
|
39
|
+
req.onerror = () => reject(req.error);
|
|
40
|
+
req.onblocked = () => reject(new Error('V2KeyStore.open: blocked'));
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
/** 关闭数据库连接(测试或释放资源时使用)。 */
|
|
44
|
+
close() {
|
|
45
|
+
this.db.close();
|
|
46
|
+
}
|
|
47
|
+
store(mode) {
|
|
48
|
+
return this.db.transaction(V2_STORE_NAME, mode).objectStore(V2_STORE_NAME);
|
|
49
|
+
}
|
|
50
|
+
// ---------- SPK ----------
|
|
51
|
+
async saveSPK(deviceId, spkId, priv, pubDer) {
|
|
52
|
+
const record = {
|
|
53
|
+
device_id: deviceId,
|
|
54
|
+
key_type: 'spk',
|
|
55
|
+
key_id: spkId,
|
|
56
|
+
private_key: priv,
|
|
57
|
+
public_key: pubDer,
|
|
58
|
+
created_at: Date.now(),
|
|
59
|
+
};
|
|
60
|
+
return new Promise((resolve, reject) => {
|
|
61
|
+
const req = this.store('readwrite').put(record);
|
|
62
|
+
req.onsuccess = () => resolve();
|
|
63
|
+
req.onerror = () => reject(req.error);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
async loadSPK(deviceId, spkId) {
|
|
67
|
+
return new Promise((resolve, reject) => {
|
|
68
|
+
const req = this.store('readonly').get([deviceId, 'spk', spkId]);
|
|
69
|
+
req.onsuccess = () => {
|
|
70
|
+
const r = req.result;
|
|
71
|
+
// 用 new Uint8Array(...) 拷贝,规避 fake-indexeddb / 跨 realm 实例对象
|
|
72
|
+
resolve(r ? new Uint8Array(r.private_key) : null);
|
|
73
|
+
};
|
|
74
|
+
req.onerror = () => reject(req.error);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
/** 取最新 SPK(按 created_at DESC LIMIT 1)。 */
|
|
78
|
+
async loadCurrentSPK(deviceId) {
|
|
79
|
+
return new Promise((resolve, reject) => {
|
|
80
|
+
const idx = this.store('readonly').index(V2_INDEX_BY_DEVICE_TYPE_CREATED);
|
|
81
|
+
const range = IDBKeyRange.bound([deviceId, 'spk', -Infinity], [deviceId, 'spk', Infinity]);
|
|
82
|
+
const req = idx.openCursor(range, 'prev');
|
|
83
|
+
req.onsuccess = () => {
|
|
84
|
+
const cursor = req.result;
|
|
85
|
+
if (!cursor) {
|
|
86
|
+
resolve(null);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const r = cursor.value;
|
|
90
|
+
resolve({
|
|
91
|
+
spkId: r.key_id,
|
|
92
|
+
priv: new Uint8Array(r.private_key),
|
|
93
|
+
pubDer: new Uint8Array(r.public_key),
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
req.onerror = () => reject(req.error);
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
async deleteSPK(deviceId, spkId) {
|
|
100
|
+
return new Promise((resolve, reject) => {
|
|
101
|
+
const req = this.store('readwrite').delete([deviceId, 'spk', spkId]);
|
|
102
|
+
req.onsuccess = () => resolve();
|
|
103
|
+
req.onerror = () => reject(req.error);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
/** 返回最近 N 代 SPK 的 spk_id(按 created_at DESC)。 */
|
|
107
|
+
async listRecentSPKIds(deviceId, n) {
|
|
108
|
+
if (n <= 0)
|
|
109
|
+
return [];
|
|
110
|
+
return new Promise((resolve, reject) => {
|
|
111
|
+
const idx = this.store('readonly').index(V2_INDEX_BY_DEVICE_TYPE_CREATED);
|
|
112
|
+
const range = IDBKeyRange.bound([deviceId, 'spk', -Infinity], [deviceId, 'spk', Infinity]);
|
|
113
|
+
const req = idx.openCursor(range, 'prev');
|
|
114
|
+
const out = [];
|
|
115
|
+
req.onsuccess = () => {
|
|
116
|
+
const cursor = req.result;
|
|
117
|
+
if (cursor && out.length < n) {
|
|
118
|
+
out.push(cursor.value.key_id);
|
|
119
|
+
cursor.continue();
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
resolve(out);
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
req.onerror = () => reject(req.error);
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
async listExpiredSPKIds(deviceId, maxAgeMs) {
|
|
129
|
+
const cutoff = Date.now() - maxAgeMs;
|
|
130
|
+
return new Promise((resolve, reject) => {
|
|
131
|
+
const idx = this.store('readonly').index(V2_INDEX_BY_DEVICE_TYPE_CREATED);
|
|
132
|
+
const range = IDBKeyRange.bound([deviceId, 'spk', -Infinity], [deviceId, 'spk', cutoff], false, true);
|
|
133
|
+
const req = idx.openCursor(range);
|
|
134
|
+
const out = [];
|
|
135
|
+
req.onsuccess = () => {
|
|
136
|
+
const cursor = req.result;
|
|
137
|
+
if (cursor) {
|
|
138
|
+
out.push(cursor.value.key_id);
|
|
139
|
+
cursor.continue();
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
resolve(out);
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
req.onerror = () => reject(req.error);
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
// ---------- IK ----------
|
|
149
|
+
async saveIK(deviceId, priv, pubDer) {
|
|
150
|
+
const record = {
|
|
151
|
+
device_id: deviceId,
|
|
152
|
+
key_type: 'ik',
|
|
153
|
+
key_id: '',
|
|
154
|
+
private_key: priv,
|
|
155
|
+
public_key: pubDer,
|
|
156
|
+
created_at: Date.now(),
|
|
157
|
+
};
|
|
158
|
+
return new Promise((resolve, reject) => {
|
|
159
|
+
const req = this.store('readwrite').put(record);
|
|
160
|
+
req.onsuccess = () => resolve();
|
|
161
|
+
req.onerror = () => reject(req.error);
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
async loadIK(deviceId) {
|
|
165
|
+
return new Promise((resolve, reject) => {
|
|
166
|
+
const req = this.store('readonly').get([deviceId, 'ik', '']);
|
|
167
|
+
req.onsuccess = () => {
|
|
168
|
+
const r = req.result;
|
|
169
|
+
resolve(r ? { priv: new Uint8Array(r.private_key), pubDer: new Uint8Array(r.public_key) } : null);
|
|
170
|
+
};
|
|
171
|
+
req.onerror = () => reject(req.error);
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
// ---------- 测试用 ----------
|
|
175
|
+
/** 测试用:清空 store。 */
|
|
176
|
+
async _clear() {
|
|
177
|
+
return new Promise((resolve, reject) => {
|
|
178
|
+
const req = this.store('readwrite').clear();
|
|
179
|
+
req.onsuccess = () => resolve();
|
|
180
|
+
req.onerror = () => reject(req.error);
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
//# sourceMappingURL=keystore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keystore.js","sourceRoot":"","sources":["../../../src/v2/session/keystore.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AUN E2EE V2 Session Manager(浏览器版,全 async)。
|
|
3
|
+
*
|
|
4
|
+
* 与 Python `aun_core.v2.session.V2Session` 行为对齐:
|
|
5
|
+
* - IK = AID 长期密钥(多设备共享 AID 身份),由构造函数注入,不独立生成
|
|
6
|
+
* - SPK 设备级 P-256 密钥对,IK 签名背书
|
|
7
|
+
* - SPK 销毁三重条件:
|
|
8
|
+
* contig_seq >= 该 SPK 引用的最大 seq
|
|
9
|
+
* && now - last_seen >= 7 小时
|
|
10
|
+
* && 不在最近 7 代保留窗口内
|
|
11
|
+
* - 对端 IK 公钥缓存 TTL 1 小时
|
|
12
|
+
* - SPK 注册:`callFn("message.v2.put_peer_pk", ...)`
|
|
13
|
+
*
|
|
14
|
+
* 浏览器目标:所有 store 调用均 `await`,签名走 noble(确定性 ECDSA)。
|
|
15
|
+
*/
|
|
16
|
+
import { V2KeyStore } from './keystore';
|
|
17
|
+
/** 对端 IK 公钥缓存 TTL(毫秒)。 */
|
|
18
|
+
export declare const PEER_KEY_CACHE_TTL_MS: number;
|
|
19
|
+
/** SPK 销毁安全窗口(毫秒)。 */
|
|
20
|
+
export declare const DESTROY_DELAY_MS: number;
|
|
21
|
+
/** SPK 销毁时保留的最近代数。 */
|
|
22
|
+
export declare const RECENT_GENERATIONS = 7;
|
|
23
|
+
/** SPK 180 天硬上限。 */
|
|
24
|
+
export declare const HARD_LIMIT_MS: number;
|
|
25
|
+
/** 服务端 RPC 调用函数签名(与 Python `call_fn` 等价)。 */
|
|
26
|
+
export type CallFn = (method: string, params: Record<string, unknown>) => Promise<Record<string, unknown> | unknown>;
|
|
27
|
+
/** 加密所需的发送方身份。 */
|
|
28
|
+
export interface SenderIdentity {
|
|
29
|
+
aid: string;
|
|
30
|
+
deviceId: string;
|
|
31
|
+
ikPriv: Uint8Array;
|
|
32
|
+
ikPubDer: Uint8Array;
|
|
33
|
+
}
|
|
34
|
+
/** 解密所需的私钥。 */
|
|
35
|
+
export interface DecryptKeys {
|
|
36
|
+
ikPriv: Uint8Array;
|
|
37
|
+
spkPriv?: Uint8Array;
|
|
38
|
+
}
|
|
39
|
+
export declare class V2Session {
|
|
40
|
+
private readonly _store;
|
|
41
|
+
private readonly _deviceId;
|
|
42
|
+
private readonly _aid;
|
|
43
|
+
private readonly _ikPriv;
|
|
44
|
+
private readonly _ikPubDer;
|
|
45
|
+
private _spkId;
|
|
46
|
+
private _spkPriv?;
|
|
47
|
+
private _spkPubDer?;
|
|
48
|
+
private _registered;
|
|
49
|
+
private _peerIKCache;
|
|
50
|
+
private _verifiedSPKs;
|
|
51
|
+
private _oldSPKMaxSeq;
|
|
52
|
+
private _nowFn;
|
|
53
|
+
constructor(store: V2KeyStore, deviceId: string, aid: string, ikPriv: Uint8Array, ikPubDer: Uint8Array);
|
|
54
|
+
/** 测试用:注入虚拟时钟。 */
|
|
55
|
+
_setNowFn(fn: () => number): void;
|
|
56
|
+
get deviceId(): string;
|
|
57
|
+
get aid(): string;
|
|
58
|
+
get currentSpkId(): string;
|
|
59
|
+
get currentIkPubDer(): Uint8Array;
|
|
60
|
+
/** 暴露 store 以便测试(与 Python 同等私有约定)。 */
|
|
61
|
+
get _storeForTest(): V2KeyStore;
|
|
62
|
+
/** 加载或生成当前 SPK;IK 由构造函数注入,无需加载。 */
|
|
63
|
+
ensureKeys(): Promise<void>;
|
|
64
|
+
private _generateNewSPK;
|
|
65
|
+
/** SPK 由 AID 私钥(IK)签名背书并上报到 message.v2.put_peer_pk。 */
|
|
66
|
+
private _registerSPK;
|
|
67
|
+
/** 注册本设备 SPK 到服务端。IK = AID 长期密钥,无需注册。幂等。 */
|
|
68
|
+
ensureRegistered(callFn: CallFn): Promise<void>;
|
|
69
|
+
/** 返回加密所需的 sender 结构。 */
|
|
70
|
+
getSenderIdentity(): Promise<SenderIdentity>;
|
|
71
|
+
/**
|
|
72
|
+
* 返回解密所需的私钥。
|
|
73
|
+
* - spkId 空:1DH(仅 IK)
|
|
74
|
+
* - spkId == 当前 SPK:当前 spkPriv
|
|
75
|
+
* - 否则:从 store 加载旧 SPK 私钥(可能 undefined = 已销毁)
|
|
76
|
+
*/
|
|
77
|
+
getDecryptKeys(spkId: string | null | undefined): Promise<DecryptKeys>;
|
|
78
|
+
/** 判断 spkId 是否命中当前活跃 SPK。 */
|
|
79
|
+
isCurrentSPK(spkId: string | null | undefined): boolean;
|
|
80
|
+
/** 跟踪每个旧 SPK 引用的最大 seq(用于销毁判定)。 */
|
|
81
|
+
trackOldSPKMaxSeq(spkId: string, seq: number): void;
|
|
82
|
+
/**
|
|
83
|
+
* contig_seq 已覆盖、超过 7h 安全窗口、且不在最近 7 代保留窗口内时销毁。
|
|
84
|
+
*
|
|
85
|
+
* 销毁条件(全部满足才销毁):
|
|
86
|
+
* - contig_seq >= 该 SPK 引用的最大 seq
|
|
87
|
+
* - 自最后一次见到该 spk_id 引用 >= 7 小时
|
|
88
|
+
* - 不在最近 7 代 SPK 保留窗口内
|
|
89
|
+
*/
|
|
90
|
+
maybeDestroyOldSPKs(contigSeq: number): Promise<string[]>;
|
|
91
|
+
/** 轮换 SPK:生成新 SPK 并上报到服务端。旧 SPK 保留本地用于解密。 */
|
|
92
|
+
rotateSPK(callFn: CallFn): Promise<void>;
|
|
93
|
+
cachePeerIK(peerAid: string, deviceId: string, ikPubDer: Uint8Array): void;
|
|
94
|
+
getPeerIK(peerAid: string, deviceId: string): Uint8Array | null;
|
|
95
|
+
isPeerSPKVerified(peerAid: string, deviceId: string, spkId: string): boolean;
|
|
96
|
+
markPeerSPKVerified(peerAid: string, deviceId: string, spkId: string): void;
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=session.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../../src/v2/session/session.ts"],"names":[],"mappings":"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"}
|