@f2a/network 0.1.2

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 (234) hide show
  1. package/.github/workflows/ci.yml +113 -0
  2. package/.github/workflows/publish.yml +60 -0
  3. package/LICENSE +21 -0
  4. package/MONOREPO.md +58 -0
  5. package/README.md +280 -0
  6. package/SKILL.md +137 -0
  7. package/dist/adapters/openclaw.d.ts +103 -0
  8. package/dist/adapters/openclaw.d.ts.map +1 -0
  9. package/dist/adapters/openclaw.js +297 -0
  10. package/dist/adapters/openclaw.js.map +1 -0
  11. package/dist/cli/commands.d.ts +17 -0
  12. package/dist/cli/commands.d.ts.map +1 -0
  13. package/dist/cli/commands.js +107 -0
  14. package/dist/cli/commands.js.map +1 -0
  15. package/dist/cli/index.d.ts +6 -0
  16. package/dist/cli/index.d.ts.map +1 -0
  17. package/dist/cli/index.js +203 -0
  18. package/dist/cli/index.js.map +1 -0
  19. package/dist/core/autonomous-economy.d.ts +136 -0
  20. package/dist/core/autonomous-economy.d.ts.map +1 -0
  21. package/dist/core/autonomous-economy.js +255 -0
  22. package/dist/core/autonomous-economy.js.map +1 -0
  23. package/dist/core/connection-manager.d.ts +80 -0
  24. package/dist/core/connection-manager.d.ts.map +1 -0
  25. package/dist/core/connection-manager.js +235 -0
  26. package/dist/core/connection-manager.js.map +1 -0
  27. package/dist/core/connection-manager.test.d.ts +2 -0
  28. package/dist/core/connection-manager.test.d.ts.map +1 -0
  29. package/dist/core/connection-manager.test.js +52 -0
  30. package/dist/core/connection-manager.test.js.map +1 -0
  31. package/dist/core/e2ee-crypto.d.ts +90 -0
  32. package/dist/core/e2ee-crypto.d.ts.map +1 -0
  33. package/dist/core/e2ee-crypto.js +190 -0
  34. package/dist/core/e2ee-crypto.js.map +1 -0
  35. package/dist/core/f2a.d.ts +126 -0
  36. package/dist/core/f2a.d.ts.map +1 -0
  37. package/dist/core/f2a.js +425 -0
  38. package/dist/core/f2a.js.map +1 -0
  39. package/dist/core/identity.d.ts +47 -0
  40. package/dist/core/identity.d.ts.map +1 -0
  41. package/dist/core/identity.js +130 -0
  42. package/dist/core/identity.js.map +1 -0
  43. package/dist/core/identity.test.d.ts +2 -0
  44. package/dist/core/identity.test.d.ts.map +1 -0
  45. package/dist/core/identity.test.js +43 -0
  46. package/dist/core/identity.test.js.map +1 -0
  47. package/dist/core/p2p-network.d.ts +242 -0
  48. package/dist/core/p2p-network.d.ts.map +1 -0
  49. package/dist/core/p2p-network.js +1182 -0
  50. package/dist/core/p2p-network.js.map +1 -0
  51. package/dist/core/reputation-security.d.ts +168 -0
  52. package/dist/core/reputation-security.d.ts.map +1 -0
  53. package/dist/core/reputation-security.js +369 -0
  54. package/dist/core/reputation-security.js.map +1 -0
  55. package/dist/core/reputation.d.ts +179 -0
  56. package/dist/core/reputation.d.ts.map +1 -0
  57. package/dist/core/reputation.js +472 -0
  58. package/dist/core/reputation.js.map +1 -0
  59. package/dist/core/review-committee.d.ts +130 -0
  60. package/dist/core/review-committee.d.ts.map +1 -0
  61. package/dist/core/review-committee.js +251 -0
  62. package/dist/core/review-committee.js.map +1 -0
  63. package/dist/core/serverless.d.ts +155 -0
  64. package/dist/core/serverless.d.ts.map +1 -0
  65. package/dist/core/serverless.js +615 -0
  66. package/dist/core/serverless.js.map +1 -0
  67. package/dist/core/token-manager.d.ts +42 -0
  68. package/dist/core/token-manager.d.ts.map +1 -0
  69. package/dist/core/token-manager.js +122 -0
  70. package/dist/core/token-manager.js.map +1 -0
  71. package/dist/daemon/control-server.d.ts +55 -0
  72. package/dist/daemon/control-server.d.ts.map +1 -0
  73. package/dist/daemon/control-server.js +262 -0
  74. package/dist/daemon/control-server.js.map +1 -0
  75. package/dist/daemon/index.d.ts +35 -0
  76. package/dist/daemon/index.d.ts.map +1 -0
  77. package/dist/daemon/index.js +69 -0
  78. package/dist/daemon/index.js.map +1 -0
  79. package/dist/daemon/main.d.ts +6 -0
  80. package/dist/daemon/main.d.ts.map +1 -0
  81. package/dist/daemon/main.js +38 -0
  82. package/dist/daemon/main.js.map +1 -0
  83. package/dist/daemon/start.d.ts +6 -0
  84. package/dist/daemon/start.d.ts.map +1 -0
  85. package/dist/daemon/start.js +25 -0
  86. package/dist/daemon/start.js.map +1 -0
  87. package/dist/daemon/webhook.d.ts +30 -0
  88. package/dist/daemon/webhook.d.ts.map +1 -0
  89. package/dist/daemon/webhook.js +86 -0
  90. package/dist/daemon/webhook.js.map +1 -0
  91. package/dist/daemon/webhook.test.d.ts +2 -0
  92. package/dist/daemon/webhook.test.d.ts.map +1 -0
  93. package/dist/daemon/webhook.test.js +24 -0
  94. package/dist/daemon/webhook.test.js.map +1 -0
  95. package/dist/index.d.ts +24 -0
  96. package/dist/index.d.ts.map +1 -0
  97. package/dist/index.js +25 -0
  98. package/dist/index.js.map +1 -0
  99. package/dist/protocol/messages.d.ts +739 -0
  100. package/dist/protocol/messages.d.ts.map +1 -0
  101. package/dist/protocol/messages.js +188 -0
  102. package/dist/protocol/messages.js.map +1 -0
  103. package/dist/protocol/messages.test.d.ts +2 -0
  104. package/dist/protocol/messages.test.d.ts.map +1 -0
  105. package/dist/protocol/messages.test.js +55 -0
  106. package/dist/protocol/messages.test.js.map +1 -0
  107. package/dist/types/index.d.ts +247 -0
  108. package/dist/types/index.d.ts.map +1 -0
  109. package/dist/types/index.js +10 -0
  110. package/dist/types/index.js.map +1 -0
  111. package/dist/types/result.d.ts +28 -0
  112. package/dist/types/result.d.ts.map +1 -0
  113. package/dist/types/result.js +16 -0
  114. package/dist/types/result.js.map +1 -0
  115. package/dist/utils/benchmark.d.ts +67 -0
  116. package/dist/utils/benchmark.d.ts.map +1 -0
  117. package/dist/utils/benchmark.js +179 -0
  118. package/dist/utils/benchmark.js.map +1 -0
  119. package/dist/utils/logger.d.ts +105 -0
  120. package/dist/utils/logger.d.ts.map +1 -0
  121. package/dist/utils/logger.js +275 -0
  122. package/dist/utils/logger.js.map +1 -0
  123. package/dist/utils/middleware.d.ts +85 -0
  124. package/dist/utils/middleware.d.ts.map +1 -0
  125. package/dist/utils/middleware.js +173 -0
  126. package/dist/utils/middleware.js.map +1 -0
  127. package/dist/utils/rate-limiter.d.ts +71 -0
  128. package/dist/utils/rate-limiter.d.ts.map +1 -0
  129. package/dist/utils/rate-limiter.js +160 -0
  130. package/dist/utils/rate-limiter.js.map +1 -0
  131. package/dist/utils/signature.d.ts +57 -0
  132. package/dist/utils/signature.d.ts.map +1 -0
  133. package/dist/utils/signature.js +102 -0
  134. package/dist/utils/signature.js.map +1 -0
  135. package/dist/utils/validation.d.ts +504 -0
  136. package/dist/utils/validation.d.ts.map +1 -0
  137. package/dist/utils/validation.js +159 -0
  138. package/dist/utils/validation.js.map +1 -0
  139. package/docs/F2A-PROTOCOL.md +61 -0
  140. package/docs/MOBILE_BOOTSTRAP_DESIGN.md +126 -0
  141. package/docs/a2a-lessons.md +316 -0
  142. package/docs/middleware-guide.md +448 -0
  143. package/docs/readme-update-checklist.md +90 -0
  144. package/docs/reputation-guide.md +396 -0
  145. package/docs/rfcs/001-reputation-system.md +712 -0
  146. package/docs/security-design.md +247 -0
  147. package/install.sh +231 -0
  148. package/package.json +64 -0
  149. package/packages/openclaw-adapter/README.md +510 -0
  150. package/packages/openclaw-adapter/openclaw.plugin.json +106 -0
  151. package/packages/openclaw-adapter/package.json +40 -0
  152. package/packages/openclaw-adapter/src/announcement-queue.test.ts +449 -0
  153. package/packages/openclaw-adapter/src/announcement-queue.ts +403 -0
  154. package/packages/openclaw-adapter/src/capability-detector.test.ts +99 -0
  155. package/packages/openclaw-adapter/src/capability-detector.ts +183 -0
  156. package/packages/openclaw-adapter/src/claim-handlers.test.ts +974 -0
  157. package/packages/openclaw-adapter/src/claim-handlers.ts +482 -0
  158. package/packages/openclaw-adapter/src/connector.business.test.ts +583 -0
  159. package/packages/openclaw-adapter/src/connector.ts +795 -0
  160. package/packages/openclaw-adapter/src/index.test.ts +82 -0
  161. package/packages/openclaw-adapter/src/index.ts +18 -0
  162. package/packages/openclaw-adapter/src/integration.e2e.test.ts +829 -0
  163. package/packages/openclaw-adapter/src/logger.ts +51 -0
  164. package/packages/openclaw-adapter/src/network-client.test.ts +266 -0
  165. package/packages/openclaw-adapter/src/network-client.ts +251 -0
  166. package/packages/openclaw-adapter/src/network-recovery.test.ts +465 -0
  167. package/packages/openclaw-adapter/src/node-manager.test.ts +136 -0
  168. package/packages/openclaw-adapter/src/node-manager.ts +429 -0
  169. package/packages/openclaw-adapter/src/plugin.test.ts +439 -0
  170. package/packages/openclaw-adapter/src/plugin.ts +104 -0
  171. package/packages/openclaw-adapter/src/reputation.test.ts +221 -0
  172. package/packages/openclaw-adapter/src/reputation.ts +368 -0
  173. package/packages/openclaw-adapter/src/task-guard.test.ts +502 -0
  174. package/packages/openclaw-adapter/src/task-guard.ts +860 -0
  175. package/packages/openclaw-adapter/src/task-queue.concurrency.test.ts +462 -0
  176. package/packages/openclaw-adapter/src/task-queue.edge-cases.test.ts +284 -0
  177. package/packages/openclaw-adapter/src/task-queue.persistence.test.ts +408 -0
  178. package/packages/openclaw-adapter/src/task-queue.ts +668 -0
  179. package/packages/openclaw-adapter/src/tool-handlers.test.ts +906 -0
  180. package/packages/openclaw-adapter/src/tool-handlers.ts +574 -0
  181. package/packages/openclaw-adapter/src/types.ts +361 -0
  182. package/packages/openclaw-adapter/src/webhook-pusher.test.ts +188 -0
  183. package/packages/openclaw-adapter/src/webhook-pusher.ts +220 -0
  184. package/packages/openclaw-adapter/src/webhook-server.test.ts +580 -0
  185. package/packages/openclaw-adapter/src/webhook-server.ts +202 -0
  186. package/packages/openclaw-adapter/tsconfig.json +20 -0
  187. package/src/cli/commands.test.ts +157 -0
  188. package/src/cli/commands.ts +129 -0
  189. package/src/cli/index.test.ts +77 -0
  190. package/src/cli/index.ts +234 -0
  191. package/src/core/autonomous-economy.test.ts +291 -0
  192. package/src/core/autonomous-economy.ts +428 -0
  193. package/src/core/e2ee-crypto.test.ts +125 -0
  194. package/src/core/e2ee-crypto.ts +246 -0
  195. package/src/core/f2a.test.ts +269 -0
  196. package/src/core/f2a.ts +618 -0
  197. package/src/core/p2p-network.test.ts +199 -0
  198. package/src/core/p2p-network.ts +1432 -0
  199. package/src/core/reputation-security.test.ts +403 -0
  200. package/src/core/reputation-security.ts +562 -0
  201. package/src/core/reputation.test.ts +260 -0
  202. package/src/core/reputation.ts +576 -0
  203. package/src/core/review-committee.test.ts +380 -0
  204. package/src/core/review-committee.ts +401 -0
  205. package/src/core/token-manager.test.ts +133 -0
  206. package/src/core/token-manager.ts +140 -0
  207. package/src/daemon/control-server.test.ts +216 -0
  208. package/src/daemon/control-server.ts +292 -0
  209. package/src/daemon/index.test.ts +85 -0
  210. package/src/daemon/index.ts +89 -0
  211. package/src/daemon/main.ts +44 -0
  212. package/src/daemon/start.ts +29 -0
  213. package/src/daemon/webhook.test.ts +68 -0
  214. package/src/daemon/webhook.ts +105 -0
  215. package/src/index.test.ts +436 -0
  216. package/src/index.ts +72 -0
  217. package/src/types/index.test.ts +87 -0
  218. package/src/types/index.ts +341 -0
  219. package/src/types/result.ts +68 -0
  220. package/src/utils/benchmark.ts +237 -0
  221. package/src/utils/logger.ts +331 -0
  222. package/src/utils/middleware.ts +229 -0
  223. package/src/utils/rate-limiter.ts +207 -0
  224. package/src/utils/signature.ts +136 -0
  225. package/src/utils/validation.ts +186 -0
  226. package/tests/docker/Dockerfile.node +23 -0
  227. package/tests/docker/Dockerfile.runner +18 -0
  228. package/tests/docker/docker-compose.test.yml +73 -0
  229. package/tests/integration/message-passing.test.ts +109 -0
  230. package/tests/integration/multi-node.test.ts +92 -0
  231. package/tests/integration/p2p-connection.test.ts +83 -0
  232. package/tests/integration/test-config.ts +32 -0
  233. package/tsconfig.json +21 -0
  234. package/vitest.config.ts +26 -0
@@ -0,0 +1,67 @@
1
+ /**
2
+ * F2A 性能基准测试工具
3
+ */
4
+ export interface BenchmarkConfig {
5
+ /** 测试名称 */
6
+ name: string;
7
+ /** 迭代次数 */
8
+ iterations: number;
9
+ /** 预热次数 */
10
+ warmup?: number;
11
+ /** 测试函数 */
12
+ fn: () => void | Promise<void>;
13
+ }
14
+ export interface BenchmarkResult {
15
+ name: string;
16
+ iterations: number;
17
+ totalTime: number;
18
+ avgTime: number;
19
+ minTime: number;
20
+ maxTime: number;
21
+ opsPerSecond: number;
22
+ }
23
+ /**
24
+ * 性能基准测试运行器
25
+ */
26
+ export declare class BenchmarkRunner {
27
+ private results;
28
+ private logger;
29
+ constructor();
30
+ /**
31
+ * 运行单个基准测试
32
+ */
33
+ run(config: BenchmarkConfig): Promise<BenchmarkResult>;
34
+ /**
35
+ * 运行多个基准测试
36
+ */
37
+ runAll(configs: BenchmarkConfig[]): Promise<BenchmarkResult[]>;
38
+ /**
39
+ * 打印结果
40
+ */
41
+ private logResult;
42
+ /**
43
+ * 生成报告
44
+ */
45
+ generateReport(): string;
46
+ /**
47
+ * 获取所有结果
48
+ */
49
+ getResults(): BenchmarkResult[];
50
+ /**
51
+ * 清空结果
52
+ */
53
+ clear(): void;
54
+ }
55
+ /**
56
+ * 加密性能测试
57
+ */
58
+ export declare function benchmarkEncryption(runner: BenchmarkRunner, encryptFn: (data: string) => string, decryptFn: (data: string) => string): Promise<void>;
59
+ /**
60
+ * 消息序列化性能测试
61
+ */
62
+ export declare function benchmarkSerialization(runner: BenchmarkRunner): Promise<void>;
63
+ /**
64
+ * 哈希计算性能测试
65
+ */
66
+ export declare function benchmarkHash(runner: BenchmarkRunner, hashFn: (data: string) => string): Promise<void>;
67
+ //# sourceMappingURL=benchmark.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"benchmark.d.ts","sourceRoot":"","sources":["../../src/utils/benchmark.ts"],"names":[],"mappings":"AAAA;;GAEG;AAKH,MAAM,WAAW,eAAe;IAC9B,WAAW;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW;IACX,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW;IACX,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW;IACX,EAAE,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,OAAO,CAAyB;IACxC,OAAO,CAAC,MAAM,CAAS;;IAMvB;;OAEG;IACG,GAAG,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,eAAe,CAAC;IA8C5D;;OAEG;IACG,MAAM,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;IAOpE;;OAEG;IACH,OAAO,CAAC,SAAS;IAWjB;;OAEG;IACH,cAAc,IAAI,MAAM;IAsBxB;;OAEG;IACH,UAAU,IAAI,eAAe,EAAE;IAI/B;;OAEG;IACH,KAAK,IAAI,IAAI;CAGd;AAMD;;GAEG;AACH,wBAAsB,mBAAmB,CACvC,MAAM,EAAE,eAAe,EACvB,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,EACnC,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,GAClC,OAAO,CAAC,IAAI,CAAC,CAmBf;AAED;;GAEG;AACH,wBAAsB,sBAAsB,CAC1C,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,IAAI,CAAC,CA0Bf;AAED;;GAEG;AACH,wBAAsB,aAAa,CACjC,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,GAC/B,OAAO,CAAC,IAAI,CAAC,CAaf"}
@@ -0,0 +1,179 @@
1
+ /**
2
+ * F2A 性能基准测试工具
3
+ */
4
+ import { performance } from 'perf_hooks';
5
+ import { Logger } from './logger.js';
6
+ /**
7
+ * 性能基准测试运行器
8
+ */
9
+ export class BenchmarkRunner {
10
+ results = [];
11
+ logger;
12
+ constructor() {
13
+ this.logger = new Logger({ component: 'Benchmark' });
14
+ }
15
+ /**
16
+ * 运行单个基准测试
17
+ */
18
+ async run(config) {
19
+ const { name, iterations, warmup = 10, fn } = config;
20
+ this.logger.info(`Running benchmark: ${name}`, { iterations, warmup });
21
+ // 预热
22
+ for (let i = 0; i < warmup; i++) {
23
+ await fn();
24
+ }
25
+ // 正式测试
26
+ const times = [];
27
+ const startTotal = performance.now();
28
+ for (let i = 0; i < iterations; i++) {
29
+ const start = performance.now();
30
+ await fn();
31
+ const end = performance.now();
32
+ times.push(end - start);
33
+ }
34
+ const endTotal = performance.now();
35
+ // 计算统计
36
+ const totalTime = endTotal - startTotal;
37
+ const avgTime = totalTime / iterations;
38
+ const minTime = Math.min(...times);
39
+ const maxTime = Math.max(...times);
40
+ const opsPerSecond = 1000 / avgTime;
41
+ const result = {
42
+ name,
43
+ iterations,
44
+ totalTime,
45
+ avgTime,
46
+ minTime,
47
+ maxTime,
48
+ opsPerSecond
49
+ };
50
+ this.results.push(result);
51
+ this.logResult(result);
52
+ return result;
53
+ }
54
+ /**
55
+ * 运行多个基准测试
56
+ */
57
+ async runAll(configs) {
58
+ for (const config of configs) {
59
+ await this.run(config);
60
+ }
61
+ return this.results;
62
+ }
63
+ /**
64
+ * 打印结果
65
+ */
66
+ logResult(result) {
67
+ this.logger.info(`Benchmark: ${result.name}`, {
68
+ iterations: result.iterations,
69
+ totalTime: `${result.totalTime.toFixed(2)}ms`,
70
+ avgTime: `${result.avgTime.toFixed(3)}ms`,
71
+ minTime: `${result.minTime.toFixed(3)}ms`,
72
+ maxTime: `${result.maxTime.toFixed(3)}ms`,
73
+ opsPerSecond: result.opsPerSecond.toFixed(2)
74
+ });
75
+ }
76
+ /**
77
+ * 生成报告
78
+ */
79
+ generateReport() {
80
+ const lines = [];
81
+ lines.push('# F2A Performance Benchmark Report');
82
+ lines.push('');
83
+ lines.push(`Generated: ${new Date().toISOString()}`);
84
+ lines.push('');
85
+ for (const result of this.results) {
86
+ lines.push(`## ${result.name}`);
87
+ lines.push('');
88
+ lines.push(`- Iterations: ${result.iterations}`);
89
+ lines.push(`- Total Time: ${result.totalTime.toFixed(2)}ms`);
90
+ lines.push(`- Average Time: ${result.avgTime.toFixed(3)}ms`);
91
+ lines.push(`- Min Time: ${result.minTime.toFixed(3)}ms`);
92
+ lines.push(`- Max Time: ${result.maxTime.toFixed(3)}ms`);
93
+ lines.push(`- Ops/Second: ${result.opsPerSecond.toFixed(2)}`);
94
+ lines.push('');
95
+ }
96
+ return lines.join('\n');
97
+ }
98
+ /**
99
+ * 获取所有结果
100
+ */
101
+ getResults() {
102
+ return [...this.results];
103
+ }
104
+ /**
105
+ * 清空结果
106
+ */
107
+ clear() {
108
+ this.results = [];
109
+ }
110
+ }
111
+ // ============================================================================
112
+ // 常用基准测试
113
+ // ============================================================================
114
+ /**
115
+ * 加密性能测试
116
+ */
117
+ export async function benchmarkEncryption(runner, encryptFn, decryptFn) {
118
+ const testData = 'x'.repeat(1024); // 1KB 数据
119
+ await runner.run({
120
+ name: 'Encryption (1KB)',
121
+ iterations: 1000,
122
+ fn: () => {
123
+ encryptFn(testData);
124
+ }
125
+ });
126
+ const encrypted = encryptFn(testData);
127
+ await runner.run({
128
+ name: 'Decryption (1KB)',
129
+ iterations: 1000,
130
+ fn: () => {
131
+ decryptFn(encrypted);
132
+ }
133
+ });
134
+ }
135
+ /**
136
+ * 消息序列化性能测试
137
+ */
138
+ export async function benchmarkSerialization(runner) {
139
+ const message = {
140
+ id: 'test-uuid',
141
+ type: 'TASK_REQUEST',
142
+ from: 'peer-123',
143
+ to: 'peer-456',
144
+ timestamp: Date.now(),
145
+ payload: { data: 'x'.repeat(100) }
146
+ };
147
+ await runner.run({
148
+ name: 'Message Serialization',
149
+ iterations: 10000,
150
+ fn: () => {
151
+ JSON.stringify(message);
152
+ }
153
+ });
154
+ const serialized = JSON.stringify(message);
155
+ await runner.run({
156
+ name: 'Message Deserialization',
157
+ iterations: 10000,
158
+ fn: () => {
159
+ JSON.parse(serialized);
160
+ }
161
+ });
162
+ }
163
+ /**
164
+ * 哈希计算性能测试
165
+ */
166
+ export async function benchmarkHash(runner, hashFn) {
167
+ const sizes = [100, 1000, 10000]; // 100B, 1KB, 10KB
168
+ for (const size of sizes) {
169
+ const data = 'x'.repeat(size);
170
+ await runner.run({
171
+ name: `Hash (${size}B)`,
172
+ iterations: 1000,
173
+ fn: () => {
174
+ hashFn(data);
175
+ }
176
+ });
177
+ }
178
+ }
179
+ //# sourceMappingURL=benchmark.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"benchmark.js","sourceRoot":"","sources":["../../src/utils/benchmark.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,105 @@
1
+ /**
2
+ * F2A 结构化日志系统
3
+ * 基于 Pino 的日志实现,支持结构化输出和级别控制
4
+ */
5
+ import { LogLevel } from '../types/index.js';
6
+ export interface LogEntry {
7
+ level: string;
8
+ msg: string;
9
+ timestamp: string;
10
+ component?: string;
11
+ [key: string]: unknown;
12
+ }
13
+ export interface LoggerOptions {
14
+ level?: LogLevel;
15
+ component?: string;
16
+ enableConsole?: boolean;
17
+ enableFile?: boolean;
18
+ filePath?: string;
19
+ /** 是否使用 JSON 格式输出(生产环境推荐) */
20
+ jsonMode?: boolean;
21
+ /** 文件流重试配置 */
22
+ maxRetries?: number;
23
+ /** 重试间隔(毫秒) */
24
+ retryDelayMs?: number;
25
+ }
26
+ /**
27
+ * 结构化日志记录器
28
+ */
29
+ export declare class Logger {
30
+ private level;
31
+ private component;
32
+ private enableConsole;
33
+ private enableFile;
34
+ private filePath;
35
+ private jsonMode;
36
+ private fileStream;
37
+ private maxRetries;
38
+ private retryDelayMs;
39
+ private retryCount;
40
+ private isReconnecting;
41
+ constructor(options?: LoggerOptions);
42
+ /**
43
+ * 初始化文件写入流(带重试机制)
44
+ */
45
+ private initFileStream;
46
+ /**
47
+ * 处理流错误
48
+ */
49
+ private handleStreamError;
50
+ /**
51
+ * 调度重连
52
+ */
53
+ private scheduleReconnect;
54
+ /**
55
+ * 检查日志级别是否启用
56
+ */
57
+ private isLevelEnabled;
58
+ /**
59
+ * 格式化日志条目
60
+ */
61
+ private formatLog;
62
+ /**
63
+ * 输出日志
64
+ */
65
+ private output;
66
+ /**
67
+ * 记录 DEBUG 级别日志
68
+ */
69
+ debug(message: string, meta?: Record<string, unknown>): void;
70
+ /**
71
+ * 记录 INFO 级别日志
72
+ */
73
+ info(message: string, meta?: Record<string, unknown>): void;
74
+ /**
75
+ * 记录 WARN 级别日志
76
+ */
77
+ warn(message: string, meta?: Record<string, unknown>): void;
78
+ /**
79
+ * 记录 ERROR 级别日志
80
+ */
81
+ error(message: string, meta?: Record<string, unknown>): void;
82
+ /**
83
+ * 设置日志级别
84
+ */
85
+ setLevel(level: LogLevel): void;
86
+ /**
87
+ * 获取当前日志级别
88
+ */
89
+ getLevel(): LogLevel;
90
+ /**
91
+ * 启用文件日志
92
+ */
93
+ setFileLogging(enabled: boolean, filePath?: string): void;
94
+ /**
95
+ * 创建子日志记录器
96
+ */
97
+ child(component: string): Logger;
98
+ /**
99
+ * 关闭日志记录器,释放资源
100
+ */
101
+ close(): void;
102
+ }
103
+ export declare const defaultLogger: Logger;
104
+ export declare const logger: Logger;
105
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAa7C,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAGD,MAAM,WAAW,aAAa;IAC5B,KAAK,CAAC,EAAE,QAAQ,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,qBAAa,MAAM;IACjB,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,UAAU,CAAU;IAC5B,OAAO,CAAC,QAAQ,CAAqB;IACrC,OAAO,CAAC,QAAQ,CAAU;IAC1B,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,cAAc,CAAkB;gBAE5B,OAAO,GAAE,aAAkB;IAiBvC;;OAEG;IACH,OAAO,CAAC,cAAc;IAqDtB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAkBzB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IA8BzB;;OAEG;IACH,OAAO,CAAC,cAAc;IAItB;;OAEG;IACH,OAAO,CAAC,SAAS;IAUjB;;OAEG;IACH,OAAO,CAAC,MAAM;IA4Bd;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAK5D;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAK3D;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAK3D;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAK5D;;OAEG;IACH,QAAQ,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAI/B;;OAEG;IACH,QAAQ,IAAI,QAAQ;IAIpB;;OAEG;IACH,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI;IAiBzD;;OAEG;IACH,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAWhC;;OAEG;IACH,KAAK,IAAI,IAAI;CAMd;AAGD,eAAO,MAAM,aAAa,QAAmC,CAAC;AAG9D,eAAO,MAAM,MAAM,QAAgB,CAAC"}
@@ -0,0 +1,275 @@
1
+ /**
2
+ * F2A 结构化日志系统
3
+ * 基于 Pino 的日志实现,支持结构化输出和级别控制
4
+ */
5
+ import * as fs from 'fs';
6
+ import * as path from 'path';
7
+ // 日志级别权重
8
+ const LOG_LEVELS = {
9
+ 'DEBUG': 0,
10
+ 'INFO': 1,
11
+ 'WARN': 2,
12
+ 'ERROR': 3
13
+ };
14
+ /**
15
+ * 结构化日志记录器
16
+ */
17
+ export class Logger {
18
+ level;
19
+ component;
20
+ enableConsole;
21
+ enableFile;
22
+ filePath;
23
+ jsonMode;
24
+ fileStream;
25
+ maxRetries;
26
+ retryDelayMs;
27
+ retryCount = 0;
28
+ isReconnecting = false;
29
+ constructor(options = {}) {
30
+ this.level = options.level || 'INFO';
31
+ this.component = options.component || 'F2A';
32
+ this.enableConsole = options.enableConsole !== false;
33
+ this.enableFile = options.enableFile ?? false;
34
+ this.filePath = options.filePath;
35
+ // 自动检测:生产环境默认使用 JSON 格式
36
+ this.jsonMode = options.jsonMode ?? (process.env.NODE_ENV === 'production');
37
+ this.maxRetries = options.maxRetries ?? 3;
38
+ this.retryDelayMs = options.retryDelayMs ?? 1000;
39
+ // 初始化文件流
40
+ if (this.enableFile && this.filePath) {
41
+ this.initFileStream();
42
+ }
43
+ }
44
+ /**
45
+ * 初始化文件写入流(带重试机制)
46
+ */
47
+ initFileStream() {
48
+ if (!this.filePath)
49
+ return;
50
+ const attemptInit = (attempt) => {
51
+ if (attempt > this.maxRetries) {
52
+ console.error(`[Logger] Failed to initialize file stream after ${this.maxRetries} attempts`);
53
+ this.enableFile = false;
54
+ return;
55
+ }
56
+ try {
57
+ // 确保目录存在
58
+ const dir = path.dirname(this.filePath);
59
+ if (!fs.existsSync(dir)) {
60
+ fs.mkdirSync(dir, { recursive: true });
61
+ }
62
+ // 创建写入流(追加模式)
63
+ this.fileStream = fs.createWriteStream(this.filePath, {
64
+ flags: 'a',
65
+ encoding: 'utf8'
66
+ });
67
+ this.fileStream.on('error', (err) => {
68
+ console.error(`[Logger] File stream error: ${err.message}`);
69
+ this.handleStreamError(err);
70
+ });
71
+ this.fileStream.on('open', () => {
72
+ // 成功打开,重置重试计数
73
+ this.retryCount = 0;
74
+ this.isReconnecting = false;
75
+ });
76
+ this.fileStream.on('close', () => {
77
+ // 流关闭,如果需要文件日志则尝试重连
78
+ if (this.enableFile && !this.isReconnecting) {
79
+ this.scheduleReconnect();
80
+ }
81
+ });
82
+ }
83
+ catch (err) {
84
+ console.error(`[Logger] Failed to initialize file stream (attempt ${attempt}/${this.maxRetries}): ${err}`);
85
+ this.retryCount = attempt;
86
+ // 延迟后重试
87
+ setTimeout(() => attemptInit(attempt + 1), this.retryDelayMs);
88
+ }
89
+ };
90
+ attemptInit(1);
91
+ }
92
+ /**
93
+ * 处理流错误
94
+ */
95
+ handleStreamError(err) {
96
+ // 检查是否是可恢复的错误
97
+ const isRecoverable = err.message.includes('ENOENT') || // 文件不存在
98
+ err.message.includes('EACCES') || // 权限问题(可能临时)
99
+ err.message.includes('EMFILE') || // 文件描述符不足
100
+ err.message.includes('ENOSPC'); // 磁盘空间不足
101
+ if (isRecoverable && this.retryCount < this.maxRetries) {
102
+ this.scheduleReconnect();
103
+ }
104
+ else {
105
+ // 不可恢复或超过重试次数,降级到控制台
106
+ console.warn(`[Logger] File logging disabled due to unrecoverable error: ${err.message}`);
107
+ this.fileStream = undefined;
108
+ this.enableFile = false;
109
+ }
110
+ }
111
+ /**
112
+ * 调度重连
113
+ */
114
+ scheduleReconnect() {
115
+ if (this.isReconnecting)
116
+ return;
117
+ this.isReconnecting = true;
118
+ this.retryCount++;
119
+ if (this.retryCount > this.maxRetries) {
120
+ console.warn(`[Logger] Max reconnection attempts (${this.maxRetries}) reached, file logging disabled`);
121
+ this.enableFile = false;
122
+ this.isReconnecting = false;
123
+ return;
124
+ }
125
+ console.log(`[Logger] Attempting to reconnect file stream (attempt ${this.retryCount}/${this.maxRetries})...`);
126
+ // 关闭旧流
127
+ if (this.fileStream) {
128
+ try {
129
+ this.fileStream.destroy();
130
+ }
131
+ catch { /* ignore */ }
132
+ this.fileStream = undefined;
133
+ }
134
+ // 延迟后重试
135
+ setTimeout(() => {
136
+ this.isReconnecting = false;
137
+ this.initFileStream();
138
+ }, this.retryDelayMs * this.retryCount); // 指数退避
139
+ }
140
+ /**
141
+ * 检查日志级别是否启用
142
+ */
143
+ isLevelEnabled(level) {
144
+ return LOG_LEVELS[level] >= LOG_LEVELS[this.level];
145
+ }
146
+ /**
147
+ * 格式化日志条目
148
+ */
149
+ formatLog(level, message, meta) {
150
+ return {
151
+ level,
152
+ msg: message,
153
+ timestamp: new Date().toISOString(),
154
+ component: this.component,
155
+ ...meta
156
+ };
157
+ }
158
+ /**
159
+ * 输出日志
160
+ */
161
+ output(entry) {
162
+ const jsonLine = JSON.stringify(entry);
163
+ // 控制台输出
164
+ if (this.enableConsole) {
165
+ if (this.jsonMode) {
166
+ // 生产环境:JSON 一行,便于日志系统收集
167
+ console.log(jsonLine);
168
+ }
169
+ else {
170
+ // 开发环境:人类可读
171
+ const { level, msg, timestamp, component, ...meta } = entry;
172
+ const prefix = `[${timestamp.split('T')[1].split('.')[0]}] [${component}] [${level}]`;
173
+ if (Object.keys(meta).length > 0) {
174
+ // 结构化输出(开发环境可读格式)
175
+ console.log(`${prefix} ${msg}`, meta);
176
+ }
177
+ else {
178
+ console.log(`${prefix} ${msg}`);
179
+ }
180
+ }
181
+ }
182
+ // 文件输出
183
+ if (this.enableFile && this.fileStream && this.fileStream.writable) {
184
+ this.fileStream.write(jsonLine + '\n');
185
+ }
186
+ }
187
+ /**
188
+ * 记录 DEBUG 级别日志
189
+ */
190
+ debug(message, meta) {
191
+ if (!this.isLevelEnabled('DEBUG'))
192
+ return;
193
+ this.output(this.formatLog('DEBUG', message, meta));
194
+ }
195
+ /**
196
+ * 记录 INFO 级别日志
197
+ */
198
+ info(message, meta) {
199
+ if (!this.isLevelEnabled('INFO'))
200
+ return;
201
+ this.output(this.formatLog('INFO', message, meta));
202
+ }
203
+ /**
204
+ * 记录 WARN 级别日志
205
+ */
206
+ warn(message, meta) {
207
+ if (!this.isLevelEnabled('WARN'))
208
+ return;
209
+ this.output(this.formatLog('WARN', message, meta));
210
+ }
211
+ /**
212
+ * 记录 ERROR 级别日志
213
+ */
214
+ error(message, meta) {
215
+ if (!this.isLevelEnabled('ERROR'))
216
+ return;
217
+ this.output(this.formatLog('ERROR', message, meta));
218
+ }
219
+ /**
220
+ * 设置日志级别
221
+ */
222
+ setLevel(level) {
223
+ this.level = level;
224
+ }
225
+ /**
226
+ * 获取当前日志级别
227
+ */
228
+ getLevel() {
229
+ return this.level;
230
+ }
231
+ /**
232
+ * 启用文件日志
233
+ */
234
+ setFileLogging(enabled, filePath) {
235
+ // 关闭现有流
236
+ if (this.fileStream) {
237
+ this.fileStream.end();
238
+ this.fileStream = undefined;
239
+ }
240
+ this.enableFile = enabled;
241
+ if (filePath) {
242
+ this.filePath = filePath;
243
+ }
244
+ if (enabled && this.filePath) {
245
+ this.initFileStream();
246
+ }
247
+ }
248
+ /**
249
+ * 创建子日志记录器
250
+ */
251
+ child(component) {
252
+ return new Logger({
253
+ level: this.level,
254
+ component: `${this.component}:${component}`,
255
+ enableConsole: this.enableConsole,
256
+ enableFile: this.enableFile,
257
+ filePath: this.filePath,
258
+ jsonMode: this.jsonMode
259
+ });
260
+ }
261
+ /**
262
+ * 关闭日志记录器,释放资源
263
+ */
264
+ close() {
265
+ if (this.fileStream) {
266
+ this.fileStream.end();
267
+ this.fileStream = undefined;
268
+ }
269
+ }
270
+ }
271
+ // 默认日志记录器实例
272
+ export const defaultLogger = new Logger({ component: 'F2A' });
273
+ // 便捷导出
274
+ export const logger = defaultLogger;
275
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}