@agentunion/fastaun 0.2.20 → 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 -23
- package/_packed_docs/CHANGELOG.md +46 -23
- 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/index.md +13 -3
- package/_packed_docs/python-sdk-v2-only-changelog.md +189 -0
- package/_packed_docs/sdk/04-/350/277/236/346/216/245/344/270/216/350/256/244/350/257/201.md +39 -16
- package/_packed_docs/sdk/06-API/346/211/213/345/206/214.md +90 -39
- package/dist/auth.js +24 -7
- package/dist/auth.js.map +1 -1
- package/dist/client.d.ts +115 -166
- package/dist/client.js +2006 -3427
- 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.js +4 -2
- 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/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 +4 -3
|
@@ -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,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@agentunion/fastaun",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "AUN Protocol Core SDK for Node.js",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -27,12 +27,13 @@
|
|
|
27
27
|
"prepack": "python ../scripts/sync_packed_docs.py ts",
|
|
28
28
|
"test": "vitest run",
|
|
29
29
|
"test:unit": "vitest run tests/unit",
|
|
30
|
-
"test:integration": "vitest run tests/integration/e2ee.test.ts",
|
|
31
|
-
"test:e2e": "vitest run tests/e2e/group-
|
|
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
32
|
"test:federation": "vitest run tests/integration/federation.test.ts tests/integration/federation-storage.test.ts",
|
|
33
33
|
"test:watch": "vitest"
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
|
+
"@noble/curves": "^2.2.0",
|
|
36
37
|
"ws": "^8.18.0"
|
|
37
38
|
},
|
|
38
39
|
"devDependencies": {
|