@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.
Files changed (98) hide show
  1. package/CHANGELOG.md +46 -23
  2. package/_packed_docs/CHANGELOG.md +46 -23
  3. 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
  4. package/_packed_docs/protocol/index.md +13 -3
  5. package/_packed_docs/python-sdk-v2-only-changelog.md +189 -0
  6. package/_packed_docs/sdk/04-/350/277/236/346/216/245/344/270/216/350/256/244/350/257/201.md +39 -16
  7. package/_packed_docs/sdk/06-API/346/211/213/345/206/214.md +90 -39
  8. package/dist/auth.js +24 -7
  9. package/dist/auth.js.map +1 -1
  10. package/dist/client.d.ts +115 -166
  11. package/dist/client.js +2006 -3427
  12. package/dist/client.js.map +1 -1
  13. package/dist/config.d.ts +0 -4
  14. package/dist/config.js +0 -4
  15. package/dist/config.js.map +1 -1
  16. package/dist/e2ee.d.ts +5 -139
  17. package/dist/e2ee.js +4 -1151
  18. package/dist/e2ee.js.map +1 -1
  19. package/dist/errors.d.ts +0 -8
  20. package/dist/errors.js +0 -14
  21. package/dist/errors.js.map +1 -1
  22. package/dist/index.d.ts +9 -5
  23. package/dist/index.js +6 -3
  24. package/dist/index.js.map +1 -1
  25. package/dist/keystore/aid-db.d.ts +12 -61
  26. package/dist/keystore/aid-db.js +41 -539
  27. package/dist/keystore/aid-db.js.map +1 -1
  28. package/dist/keystore/file.d.ts +5 -41
  29. package/dist/keystore/file.js +8 -64
  30. package/dist/keystore/file.js.map +1 -1
  31. package/dist/keystore/index.d.ts +1 -49
  32. package/dist/namespaces/auth.js +4 -2
  33. package/dist/namespaces/auth.js.map +1 -1
  34. package/dist/protected-headers.d.ts +13 -0
  35. package/dist/protected-headers.js +47 -0
  36. package/dist/protected-headers.js.map +1 -0
  37. package/dist/seq-tracker.d.ts +7 -2
  38. package/dist/seq-tracker.js +31 -10
  39. package/dist/seq-tracker.js.map +1 -1
  40. package/dist/types.d.ts +0 -56
  41. package/dist/v2/crypto/aead.d.ts +20 -0
  42. package/dist/v2/crypto/aead.js +59 -0
  43. package/dist/v2/crypto/aead.js.map +1 -0
  44. package/dist/v2/crypto/canonical.d.ts +20 -0
  45. package/dist/v2/crypto/canonical.js +119 -0
  46. package/dist/v2/crypto/canonical.js.map +1 -0
  47. package/dist/v2/crypto/dh-path.d.ts +39 -0
  48. package/dist/v2/crypto/dh-path.js +55 -0
  49. package/dist/v2/crypto/dh-path.js.map +1 -0
  50. package/dist/v2/crypto/ecdh.d.ts +29 -0
  51. package/dist/v2/crypto/ecdh.js +122 -0
  52. package/dist/v2/crypto/ecdh.js.map +1 -0
  53. package/dist/v2/crypto/ecdsa.d.ts +29 -0
  54. package/dist/v2/crypto/ecdsa.js +120 -0
  55. package/dist/v2/crypto/ecdsa.js.map +1 -0
  56. package/dist/v2/crypto/hkdf.d.ts +19 -0
  57. package/dist/v2/crypto/hkdf.js +47 -0
  58. package/dist/v2/crypto/hkdf.js.map +1 -0
  59. package/dist/v2/crypto/index.d.ts +8 -0
  60. package/dist/v2/crypto/index.js +8 -0
  61. package/dist/v2/crypto/index.js.map +1 -0
  62. package/dist/v2/crypto/recipients.d.ts +32 -0
  63. package/dist/v2/crypto/recipients.js +183 -0
  64. package/dist/v2/crypto/recipients.js.map +1 -0
  65. package/dist/v2/e2ee/decrypt.d.ts +29 -0
  66. package/dist/v2/e2ee/decrypt.js +159 -0
  67. package/dist/v2/e2ee/decrypt.js.map +1 -0
  68. package/dist/v2/e2ee/encrypt-group.d.ts +17 -0
  69. package/dist/v2/e2ee/encrypt-group.js +143 -0
  70. package/dist/v2/e2ee/encrypt-group.js.map +1 -0
  71. package/dist/v2/e2ee/encrypt-p2p.d.ts +31 -0
  72. package/dist/v2/e2ee/encrypt-p2p.js +190 -0
  73. package/dist/v2/e2ee/encrypt-p2p.js.map +1 -0
  74. package/dist/v2/e2ee/index.d.ts +9 -0
  75. package/dist/v2/e2ee/index.js +9 -0
  76. package/dist/v2/e2ee/index.js.map +1 -0
  77. package/dist/v2/e2ee/metadata-auth.d.ts +15 -0
  78. package/dist/v2/e2ee/metadata-auth.js +50 -0
  79. package/dist/v2/e2ee/metadata-auth.js.map +1 -0
  80. package/dist/v2/e2ee/types.d.ts +57 -0
  81. package/dist/v2/e2ee/types.js +7 -0
  82. package/dist/v2/e2ee/types.js.map +1 -0
  83. package/dist/v2/session/index.d.ts +4 -0
  84. package/dist/v2/session/index.js +3 -0
  85. package/dist/v2/session/index.js.map +1 -0
  86. package/dist/v2/session/keystore.d.ts +41 -0
  87. package/dist/v2/session/keystore.js +103 -0
  88. package/dist/v2/session/keystore.js.map +1 -0
  89. package/dist/v2/session/session.d.ts +97 -0
  90. package/dist/v2/session/session.js +242 -0
  91. package/dist/v2/session/session.js.map +1 -0
  92. package/dist/v2/state/commitment.d.ts +58 -0
  93. package/dist/v2/state/commitment.js +85 -0
  94. package/dist/v2/state/commitment.js.map +1 -0
  95. package/dist/v2/state/index.d.ts +2 -0
  96. package/dist/v2/state/index.js +2 -0
  97. package/dist/v2/state/index.js.map +1 -0
  98. 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":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAEvD,MAAM,CAAC,MAAM,YAAY,GAAe,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;AAkCjF,sBAAsB;AACtB,SAAS,WAAW,CAAC,OAAqB;IACxC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACnC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC;YACvB,MAAM,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC;YACvB,IAAI,EAAE,KAAK,EAAE;gBAAE,OAAO,CAAC,CAAC;YACxB,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,KAAK,MAAM,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YAChC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC7B,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;oBACtB,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC;oBAC7B,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC;oBAC7B,IAAI,EAAE,KAAK,EAAE;wBAAE,OAAO,CAAC,CAAC;oBACxB,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IACD,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QACtC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IACD,IAAI,OAAO,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC;QACrE,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACtC,CAAC;IACD,IAAI,OAAO,CAAC,eAAe,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,WAAW,CAAC,EAAE,CAAC;QAClF,OAAO,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC7C,CAAC;AACH,CAAC;AAED,oBAAoB;AACpB,SAAS,QAAQ,CAAC,KAAa;IAC7B,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,UAAU,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;QAChE,MAAM,IAAI,KAAK,CAAC,8BAA8B,KAAK,EAAE,CAAC,CAAC;IACzD,CAAC;IACD,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;IAC9B,MAAM,EAAE,GAAG,IAAI,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACpC,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAC9B,OAAO,GAAG,CAAC;AACb,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB,CACpC,OAAe,EACf,KAAa,EACb,YAA0B;IAE1B,eAAe;IACf,MAAM,OAAO,GAAiB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC;IACvE,WAAW,CAAC,OAAO,CAAC,CAAC;IAErB,MAAM,UAAU,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACrD,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnC,MAAM,YAAY,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;IAE5C,MAAM,CAAC,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IACvB,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACrB,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACrB,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IACvB,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AACzB,CAAC"}
@@ -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,6 +1,6 @@
1
1
  {
2
2
  "name": "@agentunion/fastaun",
3
- "version": "0.2.20",
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-e2ee.test.ts",
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": {