@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.
Files changed (184) hide show
  1. package/CHANGELOG.md +50 -0
  2. package/_packed_docs/CHANGELOG.md +50 -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.d.ts.map +1 -1
  69. package/dist/auth.js +33 -14
  70. package/dist/auth.js.map +1 -1
  71. package/dist/bundle.js +14300 -0
  72. package/dist/client.d.ts +200 -178
  73. package/dist/client.d.ts.map +1 -1
  74. package/dist/client.js +3096 -4019
  75. package/dist/client.js.map +1 -1
  76. package/dist/config.d.ts +0 -4
  77. package/dist/config.d.ts.map +1 -1
  78. package/dist/config.js +0 -4
  79. package/dist/config.js.map +1 -1
  80. package/dist/crypto.d.ts +8 -1
  81. package/dist/crypto.d.ts.map +1 -1
  82. package/dist/crypto.js +114 -1
  83. package/dist/crypto.js.map +1 -1
  84. package/dist/e2ee.d.ts +5 -210
  85. package/dist/e2ee.d.ts.map +1 -1
  86. package/dist/e2ee.js +4 -1379
  87. package/dist/e2ee.js.map +1 -1
  88. package/dist/index.d.ts +7 -3
  89. package/dist/index.d.ts.map +1 -1
  90. package/dist/index.js +5 -4
  91. package/dist/index.js.map +1 -1
  92. package/dist/namespaces/auth.d.ts +1 -0
  93. package/dist/namespaces/auth.d.ts.map +1 -1
  94. package/dist/namespaces/auth.js +23 -8
  95. package/dist/namespaces/auth.js.map +1 -1
  96. package/dist/protected-headers.d.ts +14 -0
  97. package/dist/protected-headers.d.ts.map +1 -0
  98. package/dist/protected-headers.js +47 -0
  99. package/dist/protected-headers.js.map +1 -0
  100. package/dist/seq-tracker.d.ts +7 -2
  101. package/dist/seq-tracker.d.ts.map +1 -1
  102. package/dist/seq-tracker.js +31 -10
  103. package/dist/seq-tracker.js.map +1 -1
  104. package/dist/transport.d.ts +9 -1
  105. package/dist/transport.d.ts.map +1 -1
  106. package/dist/transport.js +24 -0
  107. package/dist/transport.js.map +1 -1
  108. package/dist/v2/crypto/aead.d.ts +26 -0
  109. package/dist/v2/crypto/aead.d.ts.map +1 -0
  110. package/dist/v2/crypto/aead.js +63 -0
  111. package/dist/v2/crypto/aead.js.map +1 -0
  112. package/dist/v2/crypto/canonical.d.ts +21 -0
  113. package/dist/v2/crypto/canonical.d.ts.map +1 -0
  114. package/dist/v2/crypto/canonical.js +111 -0
  115. package/dist/v2/crypto/canonical.js.map +1 -0
  116. package/dist/v2/crypto/dh-path.d.ts +21 -0
  117. package/dist/v2/crypto/dh-path.d.ts.map +1 -0
  118. package/dist/v2/crypto/dh-path.js +50 -0
  119. package/dist/v2/crypto/dh-path.js.map +1 -0
  120. package/dist/v2/crypto/ecdh.d.ts +19 -0
  121. package/dist/v2/crypto/ecdh.d.ts.map +1 -0
  122. package/dist/v2/crypto/ecdh.js +101 -0
  123. package/dist/v2/crypto/ecdh.js.map +1 -0
  124. package/dist/v2/crypto/ecdsa.d.ts +16 -0
  125. package/dist/v2/crypto/ecdsa.d.ts.map +1 -0
  126. package/dist/v2/crypto/ecdsa.js +52 -0
  127. package/dist/v2/crypto/ecdsa.js.map +1 -0
  128. package/dist/v2/crypto/hkdf.d.ts +21 -0
  129. package/dist/v2/crypto/hkdf.d.ts.map +1 -0
  130. package/dist/v2/crypto/hkdf.js +32 -0
  131. package/dist/v2/crypto/hkdf.js.map +1 -0
  132. package/dist/v2/crypto/index.d.ts +9 -0
  133. package/dist/v2/crypto/index.d.ts.map +1 -0
  134. package/dist/v2/crypto/index.js +8 -0
  135. package/dist/v2/crypto/index.js.map +1 -0
  136. package/dist/v2/crypto/recipients.d.ts +43 -0
  137. package/dist/v2/crypto/recipients.d.ts.map +1 -0
  138. package/dist/v2/crypto/recipients.js +188 -0
  139. package/dist/v2/crypto/recipients.js.map +1 -0
  140. package/dist/v2/e2ee/decrypt.d.ts +13 -0
  141. package/dist/v2/e2ee/decrypt.d.ts.map +1 -0
  142. package/dist/v2/e2ee/decrypt.js +176 -0
  143. package/dist/v2/e2ee/decrypt.js.map +1 -0
  144. package/dist/v2/e2ee/encrypt-group.d.ts +14 -0
  145. package/dist/v2/e2ee/encrypt-group.d.ts.map +1 -0
  146. package/dist/v2/e2ee/encrypt-group.js +196 -0
  147. package/dist/v2/e2ee/encrypt-group.js.map +1 -0
  148. package/dist/v2/e2ee/encrypt-p2p.d.ts +15 -0
  149. package/dist/v2/e2ee/encrypt-p2p.d.ts.map +1 -0
  150. package/dist/v2/e2ee/encrypt-p2p.js +240 -0
  151. package/dist/v2/e2ee/encrypt-p2p.js.map +1 -0
  152. package/dist/v2/e2ee/index.d.ts +9 -0
  153. package/dist/v2/e2ee/index.d.ts.map +1 -0
  154. package/dist/v2/e2ee/index.js +9 -0
  155. package/dist/v2/e2ee/index.js.map +1 -0
  156. package/dist/v2/e2ee/metadata-auth.d.ts +9 -0
  157. package/dist/v2/e2ee/metadata-auth.d.ts.map +1 -0
  158. package/dist/v2/e2ee/metadata-auth.js +60 -0
  159. package/dist/v2/e2ee/metadata-auth.js.map +1 -0
  160. package/dist/v2/e2ee/types.d.ts +57 -0
  161. package/dist/v2/e2ee/types.d.ts.map +1 -0
  162. package/dist/v2/e2ee/types.js +7 -0
  163. package/dist/v2/e2ee/types.js.map +1 -0
  164. package/dist/v2/session/index.d.ts +4 -0
  165. package/dist/v2/session/index.d.ts.map +1 -0
  166. package/dist/v2/session/index.js +3 -0
  167. package/dist/v2/session/index.js.map +1 -0
  168. package/dist/v2/session/keystore.d.ts +48 -0
  169. package/dist/v2/session/keystore.d.ts.map +1 -0
  170. package/dist/v2/session/keystore.js +184 -0
  171. package/dist/v2/session/keystore.js.map +1 -0
  172. package/dist/v2/session/session.d.ts +98 -0
  173. package/dist/v2/session/session.d.ts.map +1 -0
  174. package/dist/v2/session/session.js +270 -0
  175. package/dist/v2/session/session.js.map +1 -0
  176. package/dist/v2/state/commitment.d.ts +10 -0
  177. package/dist/v2/state/commitment.d.ts.map +1 -0
  178. package/dist/v2/state/commitment.js +86 -0
  179. package/dist/v2/state/commitment.js.map +1 -0
  180. package/dist/v2/state/index.d.ts +2 -0
  181. package/dist/v2/state/index.d.ts.map +1 -0
  182. package/dist/v2/state/index.js +2 -0
  183. package/dist/v2/state/index.js.map +1 -0
  184. package/package.json +43 -37
@@ -0,0 +1,704 @@
1
+ # 附录 C:私钥管理与身份恢复(非规范性)
2
+
3
+ > **本文档为非规范性内容**:讨论私钥管理问题的扩展方案,不是 AUN 核心协议的一部分。
4
+
5
+ ## C.1 问题背景
6
+
7
+ ### C.1.1 当前设计的困境
8
+
9
+ **当前方案**:用户自己保存私钥
10
+
11
+ **优点**:
12
+ - ✅ 安全性高(用户完全控制)
13
+ - ✅ 去中心化(无需信任第三方)
14
+ - ✅ 符合 PKI 理念
15
+
16
+ **缺点**:
17
+ - ❌ 用户体验差(需要备份私钥)
18
+ - ❌ 私钥丢失 = 身份丢失
19
+ - ❌ 跨设备同步困难
20
+ - ❌ 普通用户难以理解
21
+
22
+ ### C.1.2 现实问题
23
+
24
+ **场景 1:用户换手机**
25
+ ```
26
+ - 私钥在旧手机上
27
+ - 新手机无法登录
28
+ - 需要手动导出/导入私钥
29
+ ```
30
+
31
+ **场景 2:用户忘记备份**
32
+ ```
33
+ - 手机丢失/损坏
34
+ - 私钥永久丢失
35
+ - AID 无法恢复
36
+ ```
37
+
38
+ **场景 3:多设备使用**
39
+ ```
40
+ - 手机、电脑、平板
41
+ - 需要在每个设备上导入私钥
42
+ - 或者每个设备一个 AID?
43
+ ```
44
+
45
+ ### C.1.3 PKI 体系的必要性
46
+
47
+ **问题**:AUN 是否必须基于 PKI?
48
+
49
+ **PKI 的价值**:
50
+ - ✅ 去中心化信任(不依赖单一 CA)
51
+ - ✅ 证书链验证(可验证到受信 Root CA)
52
+ - ✅ 跨域互通(不同 Issuer 互相信任)
53
+ - ✅ 抗审查(无法被单点控制)
54
+
55
+ **PKI 的代价**:
56
+ - ❌ 私钥管理复杂
57
+ - ❌ 证书申请流程复杂
58
+ - ❌ 证书吊销机制复杂
59
+ - ❌ 用户体验差
60
+
61
+ **结论**:
62
+ - **PKI 是必需的**:跨域互通和去中心化信任需要 PKI
63
+ - **私钥管理可以优化**:不是替代 PKI,而是补充
64
+
65
+ ## C.2 第三方账号绑定的问题
66
+
67
+ ### C.2.1 核心问题
68
+
69
+ **如果用户使用 Google 账号登录,私钥在哪里?**
70
+
71
+ #### 选项 A:私钥在 Gateway(不推荐)
72
+
73
+ ```
74
+ 用户使用 Google 登录:
75
+ 1. Gateway 验证 Google OAuth token
76
+ 2. Gateway 生成私钥
77
+ 3. 私钥存储在 Gateway 数据库
78
+ 4. 用户每次登录,Gateway 代理签名
79
+ ```
80
+
81
+ **问题**:
82
+ - ❌ Gateway 完全控制私钥
83
+ - ❌ 用户无法真正"拥有"AID
84
+ - ❌ 这不是去中心化,是传统账号系统
85
+ - ❌ Gateway 被攻破 = 所有私钥泄露
86
+
87
+ #### 选项 B:私钥在客户端,Google 账号用于恢复(有风险)
88
+
89
+ ```
90
+ 首次注册:
91
+ 1. 客户端生成私钥
92
+ 2. 私钥存储在客户端本地
93
+ 3. 用户绑定 Google 账号
94
+ 4. 私钥加密后备份到 Gateway(用 Google ID 派生的密钥加密)
95
+
96
+ 恢复流程:
97
+ 1. 用户在新设备使用 Google 登录
98
+ 2. Gateway 验证 Google OAuth token
99
+ 3. Gateway 返回加密的私钥备份
100
+ 4. 客户端用 Google ID 派生密钥解密
101
+ 5. 私钥恢复到新设备
102
+ ```
103
+
104
+ **问题**:
105
+ - ❌ 如果 Google 账号被盗,私钥也被盗
106
+ - ❌ Gateway 存储加密私钥,仍有风险
107
+ - ❌ 加密密钥派生依赖 Google ID(可能变化)
108
+
109
+ #### 选项 C:私钥在客户端,Google 账号用于授权新设备(需要主设备在线)
110
+
111
+ ```
112
+ 首次注册:
113
+ 1. 主设备生成私钥
114
+ 2. 私钥存储在主设备
115
+ 3. 用户绑定 Google 账号(主设备签名授权)
116
+
117
+ 新设备登录:
118
+ 1. 新设备使用 Google 登录
119
+ 2. Gateway 验证 Google OAuth token
120
+ 3. Gateway 通知主设备:"有人用 Google 账号请求授权"
121
+ 4. 主设备确认后,签发委托证书给新设备
122
+ 5. 新设备生成自己的私钥,使用委托证书
123
+ ```
124
+
125
+ **问题**:
126
+ - ❌ 主设备丢失 = 无法授权新设备
127
+ - ❌ 仍然需要主设备在线
128
+
129
+ ### C.2.2 Gateway 如何信任第三方账号?
130
+
131
+ **场景**:用户使用 Google 账号登录
132
+
133
+ ```
134
+ 用户 → Google OAuth → Gateway
135
+
136
+ Gateway 获得:
137
+ - Google User ID: 123456789
138
+ - Email: alice@gmail.com
139
+ - Name: Alice
140
+
141
+ 问题:
142
+ 1. Gateway 如何确认这是真实的 Google 响应?
143
+ → 验证 OAuth token 签名
144
+
145
+ 2. Gateway 如何防止伪造的 OAuth 响应?
146
+ → 使用 HTTPS + 验证 Google 的证书
147
+
148
+ 3. 其他 Issuer 的 Gateway 是否信任这个绑定?
149
+ → 不信任!第三方账号只在本 Issuer 内有效
150
+ ```
151
+
152
+ **信任链问题**:
153
+
154
+ ```
155
+ 方案 1:Gateway 信任 OAuth Provider
156
+ 信任链:用户 → Google (OAuth) → Gateway → AID
157
+ 问题:其他 Issuer 不信任这个绑定
158
+
159
+ 方案 2:跨域信任 OAuth Provider
160
+ 信任链:用户 → Google (OAuth) → Gateway A → Gateway B
161
+ 问题:
162
+ - 信任链过长
163
+ - 如果 Google 账号被盗,AID 也被盗
164
+ - 违背 AUN 的去中心化理念
165
+ ```
166
+
167
+ **结论**:
168
+ - 第三方账号**不能**作为跨 Issuer 的身份证明
169
+ - 第三方账号只能作为**恢复机制**的一部分
170
+ - 跨 Issuer 通信仍然需要 PKI 证书
171
+
172
+ ## C.3 推荐方案:分层身份模型
173
+
174
+ ### C.3.1 核心思想
175
+
176
+ **区分"身份"和"认证方式"**
177
+
178
+ ```
179
+ ┌─────────────────────────────────────┐
180
+ │ AID (身份层) │
181
+ │ - alice.aid.pub │
182
+ │ - 由 PKI 证书保证 │
183
+ │ - 私钥是身份的根 │
184
+ └─────────────────────────────────────┘
185
+
186
+ │ 绑定
187
+
188
+ ┌─────────────────────────────────────┐
189
+ │ 认证方式 (认证层) │
190
+ │ - 主设备(私钥在本地) │
191
+ │ - 辅助设备(委托认证) │
192
+ │ - 第三方账号(恢复机制) │
193
+ └─────────────────────────────────────┘
194
+ ```
195
+
196
+ ### C.3.2 主设备(私钥在本地)
197
+
198
+ ```
199
+ 用户首次注册:
200
+ 1. 在主设备(如手机)上生成私钥
201
+ 2. 私钥存储在设备安全区域(Keychain/Keystore)
202
+ 3. 申请 AID 证书
203
+ 4. 主设备是"身份的根"
204
+ ```
205
+
206
+ **存储位置**:
207
+ ```
208
+ iOS:Keychain(系统级加密,支持 Face ID/Touch ID)
209
+ Android:Keystore(硬件支持,TEE/SE)
210
+ 浏览器:WebCrypto API(不可导出的密钥)
211
+ 桌面端:操作系统密钥链
212
+ ```
213
+
214
+ ### C.3.3 辅助设备(委托认证)
215
+
216
+ ```
217
+ 用户在新设备登录:
218
+ 1. 新设备生成临时密钥对
219
+ 2. 主设备扫码授权
220
+ 3. 主设备用私钥签发"委托证书"
221
+ 4. 新设备使用委托证书登录
222
+
223
+ 委托证书:
224
+ Subject: alice.aid.pub (device-2)
225
+ Issuer: alice.aid.pub (主设备签名)
226
+ Valid: 30 天(可配置)
227
+ Extensions:
228
+ - Device ID: device-2
229
+ - Device Name: "Alice's Laptop"
230
+ - Delegated By: device-1 (主设备)
231
+ ```
232
+
233
+ **优点**:
234
+ - ✅ 无需导出主私钥
235
+ - ✅ 主设备控制权限
236
+ - ✅ 可以随时撤销委托
237
+ - ✅ 委托证书有效期短,降低风险
238
+
239
+ **协议方法**:
240
+ ```
241
+ auth.delegate_device
242
+ - 主设备签发委托证书
243
+
244
+ auth.list_devices
245
+ - 列出所有授权设备
246
+
247
+ auth.revoke_device
248
+ - 撤销设备授权
249
+ ```
250
+
251
+ ### C.3.4 第三方账号(恢复机制)
252
+
253
+ ```
254
+ 用户绑定 Google 账号:
255
+ 1. 主设备用私钥签名:
256
+ "我授权 Google ID 123456789 作为恢复方式"
257
+ 2. Gateway 存储这个绑定
258
+ 3. 主设备丢失时,用户可以:
259
+ - 使用 Google 登录
260
+ - 通过恢复机制重建私钥
261
+ - 旧证书自动吊销
262
+ ```
263
+
264
+ **关键**:
265
+ - 第三方账号**不是**"身份",是"恢复方式"
266
+ - 需要主设备授权绑定
267
+ - 恢复时会生成新的私钥(或重建旧私钥)
268
+
269
+ **信任模型**:
270
+ ```
271
+ 其他 Issuer 的 Gateway 信任:
272
+ ✅ 主设备证书(由 Issuer CA 签发)
273
+ ✅ 委托证书(由主设备签发,可验证)
274
+ ❌ 第三方账号(仅用于恢复,不用于跨 Issuer 通信)
275
+ ```
276
+
277
+ ## C.4 联系方式绑定与多因素恢复
278
+
279
+ ### C.4.1 核心理念
280
+
281
+ - 协议层面定义绑定和恢复的扩展接口
282
+ - 具体实现由应用开发者决定
283
+ - 推荐将加密私钥存储到应用开发者的服务器
284
+
285
+ ### C.4.2 绑定联系方式
286
+
287
+ ```
288
+ auth.bind_contact # 绑定联系方式(phone/email/其他)
289
+ auth.verify_contact # 验证联系方式
290
+ auth.list_contacts # 列出已绑定的联系方式
291
+ auth.unbind_contact # 解绑联系方式
292
+ ```
293
+
294
+ **请求示例**:
295
+ ```json
296
+ {
297
+ "jsonrpc": "2.0",
298
+ "id": 1,
299
+ "method": "auth.bind_contact",
300
+ "params": {
301
+ "aid": "alice.aid.pub",
302
+ "contact_type": "phone",
303
+ "contact_value": "+86138****1234",
304
+ "verification_code": "123456"
305
+ }
306
+ }
307
+ ```
308
+
309
+ **支持的联系方式类型**(建议):
310
+ - `phone`:手机号(短信验证码)
311
+ - `email`:邮箱(邮件验证码)
312
+ - `oauth`:第三方账号(Google/GitHub/微信等)
313
+ - 自定义类型:由应用开发者扩展
314
+
315
+ ### C.4.3 多因素验证恢复
316
+
317
+ ```
318
+ auth.request_recovery # 发起恢复请求
319
+ auth.verify_recovery # 提交验证信息
320
+ auth.complete_recovery # 完成恢复
321
+ ```
322
+
323
+ **恢复流程示例**:
324
+ ```
325
+ 1. 用户在新设备发起恢复:
326
+ auth.request_recovery({
327
+ aid: "alice.aid.pub",
328
+ recovery_methods: ["phone", "email"]
329
+ })
330
+
331
+ 2. 服务端发送验证码到手机和邮箱
332
+
333
+ 3. 用户提交验证码:
334
+ auth.verify_recovery({
335
+ aid: "alice.aid.pub",
336
+ verifications: [
337
+ {type: "phone", code: "123456"},
338
+ {type: "email", code: "789012"}
339
+ ]
340
+ })
341
+
342
+ 4. 验证通过后,服务端返回加密的私钥备份
343
+
344
+ 5. 客户端解密并恢复身份
345
+ ```
346
+
347
+ ### C.4.4 私钥存储建议
348
+
349
+ **推荐方案**:加密私钥存储到应用开发者的服务器
350
+
351
+ ```
352
+ 首次创建 AID:
353
+ 1. 客户端生成私钥对
354
+ 2. 客户端本地存储私钥(主副本)
355
+ 3. 使用用户密码派生密钥加密私钥
356
+ 4. 将加密私钥上传到应用服务器(备份副本)
357
+ 5. 绑定 phone/email 等联系方式
358
+
359
+ 恢复流程:
360
+ 1. 用户在新设备通过 phone/email 验证身份
361
+ 2. 应用服务器返回加密的私钥备份
362
+ 3. 用户输入密码解密私钥
363
+ 4. 客户端恢复身份
364
+ ```
365
+
366
+ **安全考虑**:
367
+ - 私钥始终加密存储(服务器无法解密)
368
+ - 多因素验证防止恶意恢复
369
+ - 用户密码不传输到服务器
370
+ - 即使服务器被攻破,私钥仍然安全
371
+ - 用户忘记密码 = 无法解密备份(需要额外的密码恢复机制)
372
+
373
+ **实施灵活性**:
374
+ - 协议定义接口,不强制实现细节
375
+ - 应用开发者可以选择:
376
+ - 存储位置:自己的服务器 / Gateway / 第三方服务
377
+ - 加密方式:密码派生 / 生物识别 / 硬件密钥
378
+ - 验证方式:短信 / 邮件 / OAuth / 生物识别
379
+ - 恢复策略:单因素 / 多因素 / 社交恢复
380
+
381
+ ## C.5 社交恢复机制(Social Recovery)
382
+
383
+ ### C.5.1 核心思路
384
+
385
+ **借鉴以太坊钱包的社交恢复机制**:
386
+
387
+ ```
388
+ 用户指定 N 个"守护者"(Guardians):
389
+ - 守护者 1:用户的另一个设备
390
+ - 守护者 2:用户的 Google 账号
391
+ - 守护者 3:用户信任的朋友(另一个 AID)
392
+ - 守护者 4:Gateway(可选)
393
+ - 守护者 5:用户的邮箱
394
+
395
+ 私钥分片存储(门限签名):
396
+ - 需要 M/N 个守护者同意才能恢复(如 3/5)
397
+ ```
398
+
399
+ ### C.5.2 初始设置
400
+
401
+ ```
402
+ 用户在主设备注册:
403
+ 1. 主设备生成私钥
404
+ 2. 私钥分成 5 片(Shamir's Secret Sharing)
405
+ 3. 分配给守护者:
406
+ - 片 1:主设备本地(Keychain)
407
+ - 片 2:备用设备(扫码授权)
408
+ - 片 3:Gateway(加密存储)
409
+ - 片 4:Google Drive(加密文件)
410
+ - 片 5:信任的朋友(加密发送)
411
+ 4. 设置恢复阈值:需要 3/5 片
412
+ ```
413
+
414
+ ### C.5.3 恢复流程
415
+
416
+ ```
417
+ 主设备丢失,用户在新设备恢复:
418
+ 1. 新设备发起恢复请求
419
+ 2. 联系守护者:
420
+ - 备用设备:扫码确认 ✅
421
+ - Gateway:验证用户身份(密码/2FA)✅
422
+ - Google 账号:OAuth 登录,从 Google Drive 下载 ✅
423
+ 3. 收集到 3/5 片,重建私钥
424
+ 4. 私钥恢复到新设备
425
+ 5. 旧的私钥片自动失效(重新分片)
426
+ ```
427
+
428
+ ### C.5.4 守护者类型
429
+
430
+ **守护者 1:备用设备**
431
+ ```
432
+ 验证方式:扫码确认
433
+ 存储位置:设备本地 Keychain
434
+ 优点:用户完全控制
435
+ 缺点:设备丢失则此片丢失
436
+ ```
437
+
438
+ **守护者 2:Gateway**
439
+ ```
440
+ 验证方式:密码 + 2FA
441
+ 存储位置:Gateway 数据库(加密)
442
+ 加密方式:用户密码派生的密钥加密
443
+ 优点:Gateway 无法单独解密
444
+ 缺点:用户忘记密码则此片无法使用
445
+ ```
446
+
447
+ **守护者 3:Google 账号**
448
+ ```
449
+ 验证方式:OAuth 登录
450
+ 存储位置:Google Drive(加密文件)
451
+ 加密方式:用 Google ID 派生的密钥加密
452
+ 流程:
453
+ 1. 用户 OAuth 登录 Google
454
+ 2. 客户端访问 Google Drive API
455
+ 3. 下载加密的私钥片
456
+ 4. 用 Google ID 派生的密钥解密
457
+ 优点:用户熟悉的登录方式
458
+ 缺点:Google 账号被盗有风险
459
+ ```
460
+
461
+ **守护者 4:信任的朋友**
462
+ ```
463
+ 验证方式:朋友确认
464
+ 存储位置:朋友的设备
465
+ 流程:
466
+ 1. 用户请求恢复
467
+ 2. 朋友收到通知(通过 AUN 消息)
468
+ 3. 朋友确认后,发送私钥片
469
+ 优点:去中心化,无需信任第三方
470
+ 缺点:需要朋友在线且愿意帮助
471
+ ```
472
+
473
+ **守护者 5:用户的邮箱**
474
+ ```
475
+ 验证方式:邮箱验证码
476
+ 存储位置:加密邮件
477
+ 流程:
478
+ 1. 初始设置时,发送加密邮件到用户邮箱
479
+ 2. 恢复时,用户提供邮箱验证码
480
+ 3. 客户端从邮件中提取私钥片
481
+ 优点:简单,用户熟悉
482
+ 缺点:邮箱被盗有风险
483
+ ```
484
+
485
+ ### C.5.5 门限签名算法
486
+
487
+ **Shamir's Secret Sharing**:
488
+
489
+ ```
490
+ 原理:
491
+ - 将私钥 S 分成 N 片:S1, S2, ..., SN
492
+ - 任意 M 片可以重建 S
493
+ - 少于 M 片无法获得任何关于 S 的信息
494
+
495
+ 示例(3/5 阈值):
496
+ - 5 个守护者各持有 1 片
497
+ - 需要任意 3 片才能重建私钥
498
+ - 2 片或更少无法重建
499
+
500
+ 安全性:
501
+ - 单个守护者无法访问私钥
502
+ - Gateway 被攻破也无法获得私钥
503
+ - 用户丢失 2 个守护者仍可恢复
504
+ ```
505
+
506
+ **实现**:
507
+ ```javascript
508
+ // 分片
509
+ const shares = shamirSplit(privateKey, {
510
+ shares: 5, // 总共 5 片
511
+ threshold: 3 // 需要 3 片
512
+ });
513
+
514
+ // 重建
515
+ const privateKey = shamirCombine([share1, share3, share5]);
516
+ ```
517
+
518
+ ### C.5.6 协议扩展
519
+
520
+ **新增方法**:
521
+
522
+ ```
523
+ auth.setup_recovery
524
+ - 设置守护者
525
+ - 分片私钥
526
+ - 参数:
527
+ {
528
+ guardians: [
529
+ {type: "device", device_id: "device-2"},
530
+ {type: "gateway", auth: "password+2fa"},
531
+ {type: "oauth", provider: "google"},
532
+ {type: "friend", aid: "bob.aid.pub"},
533
+ {type: "email", email: "alice@example.com"}
534
+ ],
535
+ threshold: 3 // 需要 3/5
536
+ }
537
+
538
+ auth.add_guardian
539
+ - 添加守护者
540
+ - 重新分片私钥
541
+
542
+ auth.remove_guardian
543
+ - 移除守护者
544
+ - 重新分片私钥
545
+
546
+ auth.list_guardians
547
+ - 列出所有守护者
548
+
549
+ auth.recover_aid
550
+ - 发起恢复请求
551
+ - 联系守护者
552
+
553
+ auth.guardian_approve
554
+ - 守护者批准恢复
555
+ - 提供私钥片
556
+ ```
557
+
558
+ ## C.6 简化方案:2/3 恢复
559
+
560
+ 如果社交恢复太复杂,可以用简化方案:
561
+
562
+ ```
563
+ 私钥分成 3 片:
564
+ - 片 1:主设备(手机)
565
+ - 片 2:备用设备(电脑)
566
+ - 片 3:Gateway(加密存储)
567
+
568
+ 需要任意 2 片即可恢复
569
+ ```
570
+
571
+ **场景分析**:
572
+
573
+ | 场景 | 恢复方式 |
574
+ |------|---------|
575
+ | 主设备丢失 | 备用设备 + Gateway |
576
+ | 备用设备丢失 | 主设备 + Gateway(重新分片)|
577
+ | Gateway 被攻破 | Gateway 只有 1 片,无法单独恢复,用户安全 |
578
+ | 主设备和备用设备都丢失 | 无法恢复(建议添加第 4 个守护者)|
579
+
580
+ ## C.7 密钥恢复后的证书处理
581
+
582
+ 当用户通过多因素验证恢复身份并生成新密钥对后:
583
+
584
+ **原密钥的处理**:
585
+ - 原私钥不能再签发新的凭证(已丢失或被撤销)
586
+ - 原证书对应的公钥仍然存储在证书服务器
587
+ - 之前使用原私钥签发的凭证继续有效
588
+
589
+ **新密钥的处理**:
590
+ - 生成新的密钥对
591
+ - 向 CA 申请新证书(使用新公钥)
592
+ - 新证书与原 AID 关联
593
+ - 可选:将原证书标记为"已恢复"状态
594
+
595
+ **证书服务器的角色**:
596
+ ```
597
+ 证书服务器存储:
598
+ ✅ 历史证书(公钥)
599
+ ✅ 证书状态(有效/吊销/已恢复)
600
+ ❌ 私钥(从不存储)
601
+
602
+ 验证流程:
603
+ 1. 验证者获取证书链
604
+ 2. 验证证书签名(使用公钥)
605
+ 3. 检查证书状态(CRL/OCSP)
606
+ 4. 验证消息签名(使用证书中的公钥)
607
+ ```
608
+
609
+ **实际场景示例**:
610
+
611
+ ```
612
+ 场景:Alice 丢失手机,通过 phone + email 恢复身份
613
+
614
+ 恢复前:
615
+ - 原私钥:已丢失
616
+ - 原证书:cert-v1(公钥 pub-v1)
617
+ - 历史消息:使用 pub-v1 验证签名 ✅
618
+
619
+ 恢复后:
620
+ - 新私钥:priv-v2
621
+ - 新证书:cert-v2(公钥 pub-v2)
622
+ - 历史消息:仍使用 pub-v1 验证签名 ✅
623
+ - 新消息:使用 priv-v2 签名,pub-v2 验证 ✅
624
+ ```
625
+
626
+ ## C.8 私钥存储最佳实践
627
+
628
+ ### C.8.1 推荐方案
629
+
630
+ ```
631
+ 1. 主私钥:主设备本地(Keychain/Keystore)
632
+ - iOS Keychain(支持 Face ID/Touch ID)
633
+ - Android Keystore(硬件支持)
634
+ - 浏览器 WebCrypto API(不可导出)
635
+
636
+ 2. 备份方案:门限签名(2/3 或 3/5)
637
+ - 备用设备
638
+ - Gateway(加密)
639
+ - 第三方账号(Google Drive 加密)
640
+ - 可选:信任的朋友、邮箱
641
+
642
+ 3. 恢复机制:社交恢复或多设备恢复
643
+ - 需要 M/N 个守护者同意
644
+ - 单个守护者无法单独恢复
645
+ ```
646
+
647
+ ### C.8.2 第三方账号的角色
648
+
649
+ ```
650
+ 不是:主要认证方式
651
+ 不是:私钥存储位置
652
+ 而是:恢复机制的一部分(守护者之一)
653
+ ```
654
+
655
+ ### C.8.3 关键原则
656
+
657
+ ```
658
+ ✅ 私钥永远不以明文形式存储在服务端
659
+ ✅ 单个守护者无法单独恢复私钥
660
+ ✅ 用户始终控制私钥(通过多个守护者)
661
+ ✅ 第三方账号只是恢复方式之一,不是唯一方式
662
+ ✅ PKI 体系保持不变(跨域互通需要)
663
+ ```
664
+
665
+ ## C.9 实施建议
666
+
667
+ ### C.9.1 阶段 1:基础实现(MVP)
668
+
669
+ ```
670
+ 实现:
671
+ ✅ 主设备私钥存储(Keychain/Keystore)
672
+ ✅ 委托设备认证
673
+ ✅ 简单备份(导出/导入私钥)
674
+
675
+ 不实现:
676
+ ❌ 门限签名
677
+ ❌ 社交恢复
678
+ ❌ 第三方账号绑定
679
+ ```
680
+
681
+ ### C.9.2 阶段 2:增强恢复(推荐)
682
+
683
+ ```
684
+ 实现:
685
+ ✅ 2/3 门限签名
686
+ ✅ Gateway 加密备份
687
+ ✅ 备用设备恢复
688
+
689
+ 不实现:
690
+ ❌ 复杂的社交恢复
691
+ ❌ 多种守护者类型
692
+ ```
693
+
694
+ ### C.9.3 阶段 3:完整方案(可选)
695
+
696
+ ```
697
+ 实现:
698
+ ✅ 3/5 或更高阈值
699
+ ✅ 多种守护者类型
700
+ ✅ 第三方账号绑定
701
+ ✅ 朋友作为守护者
702
+ ```
703
+
704
+ ---