@renxqoo/renx-code 0.0.9 → 0.0.10

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 (286) hide show
  1. package/README.md +14 -0
  2. package/bin/renx.cjs +79 -42
  3. package/bin/renx.exe +0 -0
  4. package/package.json +10 -28
  5. package/src/App.tsx +0 -297
  6. package/src/agent/runtime/event-format.ts +0 -258
  7. package/src/agent/runtime/model-types.ts +0 -13
  8. package/src/agent/runtime/runtime.context-usage.test.ts +0 -192
  9. package/src/agent/runtime/runtime.error-handling.test.ts +0 -235
  10. package/src/agent/runtime/runtime.simple.test.ts +0 -16
  11. package/src/agent/runtime/runtime.test.ts +0 -296
  12. package/src/agent/runtime/runtime.ts +0 -875
  13. package/src/agent/runtime/runtime.usage-forwarding.test.ts +0 -228
  14. package/src/agent/runtime/source-modules.test.ts +0 -38
  15. package/src/agent/runtime/source-modules.ts +0 -370
  16. package/src/agent/runtime/tool-call-buffer.test.ts +0 -65
  17. package/src/agent/runtime/tool-call-buffer.ts +0 -60
  18. package/src/agent/runtime/tool-confirmation.test.ts +0 -56
  19. package/src/agent/runtime/tool-confirmation.ts +0 -15
  20. package/src/agent/runtime/types.ts +0 -99
  21. package/src/commands/slash-commands.test.ts +0 -216
  22. package/src/commands/slash-commands.ts +0 -64
  23. package/src/components/chat/assistant-reply.test.tsx +0 -47
  24. package/src/components/chat/assistant-reply.tsx +0 -136
  25. package/src/components/chat/assistant-segment.test.ts +0 -99
  26. package/src/components/chat/assistant-segment.tsx +0 -125
  27. package/src/components/chat/assistant-tool-group.tsx +0 -900
  28. package/src/components/chat/code-block.test.tsx +0 -206
  29. package/src/components/chat/code-block.tsx +0 -313
  30. package/src/components/chat/prompt-card.tsx +0 -81
  31. package/src/components/chat/segment-groups.test.ts +0 -52
  32. package/src/components/chat/segment-groups.ts +0 -106
  33. package/src/components/chat/turn-item.tsx +0 -39
  34. package/src/components/conversation-panel.tsx +0 -43
  35. package/src/components/file-mention-menu.tsx +0 -77
  36. package/src/components/file-picker-dialog.tsx +0 -206
  37. package/src/components/footer-hints.tsx +0 -75
  38. package/src/components/model-picker-dialog.tsx +0 -248
  39. package/src/components/prompt.tsx +0 -233
  40. package/src/components/slash-command-menu.tsx +0 -65
  41. package/src/components/tool-confirm-dialog-content.test.ts +0 -103
  42. package/src/components/tool-confirm-dialog-content.ts +0 -186
  43. package/src/components/tool-confirm-dialog.tsx +0 -187
  44. package/src/components/tool-display-config.ts +0 -119
  45. package/src/context-usage-regressions.test.ts +0 -26
  46. package/src/files/attachment-capabilities.test.ts +0 -30
  47. package/src/files/attachment-capabilities.ts +0 -50
  48. package/src/files/attachment-content.ts +0 -153
  49. package/src/files/file-mention-query.test.ts +0 -34
  50. package/src/files/file-mention-query.ts +0 -32
  51. package/src/files/prompt-display.ts +0 -13
  52. package/src/files/types.ts +0 -5
  53. package/src/files/workspace-files.ts +0 -61
  54. package/src/hooks/agent-event-handlers.test.ts +0 -207
  55. package/src/hooks/agent-event-handlers.ts +0 -196
  56. package/src/hooks/chat-local-replies.fixed.test.ts +0 -119
  57. package/src/hooks/chat-local-replies.test.ts +0 -153
  58. package/src/hooks/chat-local-replies.ts +0 -63
  59. package/src/hooks/turn-updater.test.ts +0 -70
  60. package/src/hooks/turn-updater.ts +0 -166
  61. package/src/hooks/use-agent-chat.context.test.ts +0 -10
  62. package/src/hooks/use-agent-chat.status.test.ts +0 -14
  63. package/src/hooks/use-agent-chat.test.ts +0 -80
  64. package/src/hooks/use-agent-chat.ts +0 -621
  65. package/src/hooks/use-file-mention-menu.ts +0 -196
  66. package/src/hooks/use-file-picker.ts +0 -185
  67. package/src/hooks/use-model-picker.ts +0 -196
  68. package/src/hooks/use-slash-command-menu.ts +0 -154
  69. package/src/index.tsx +0 -55
  70. package/src/runtime/clipboard.test.ts +0 -43
  71. package/src/runtime/clipboard.ts +0 -89
  72. package/src/runtime/exit.test.ts +0 -177
  73. package/src/runtime/exit.ts +0 -98
  74. package/src/runtime/runtime-support.test.ts +0 -31
  75. package/src/runtime/terminal-theme.test.ts +0 -55
  76. package/src/runtime/terminal-theme.ts +0 -196
  77. package/src/types/chat.ts +0 -32
  78. package/src/types/message-content.ts +0 -48
  79. package/src/ui/open-code-theme.ts +0 -176
  80. package/src/ui/opencode-markdown.ts +0 -211
  81. package/src/ui/theme.simple.test.ts +0 -52
  82. package/src/ui/theme.test.ts +0 -151
  83. package/src/ui/theme.ts +0 -152
  84. package/src/utils/time.test.ts +0 -144
  85. package/src/utils/time.ts +0 -7
  86. package/tsconfig.json +0 -30
  87. package/vendor/agent-root/src/agent/ENTERPRISE_ACCEPTANCE_CHECKLIST.md +0 -95
  88. package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.html +0 -1345
  89. package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.md +0 -1353
  90. package/vendor/agent-root/src/agent/ERROR_CONTRACT.md +0 -60
  91. package/vendor/agent-root/src/agent/TEST_COVERAGE_ANALYSIS.md +0 -278
  92. package/vendor/agent-root/src/agent/__test__/error-contract.test.ts +0 -72
  93. package/vendor/agent-root/src/agent/__test__/types.test.ts +0 -137
  94. package/vendor/agent-root/src/agent/agent/__test__/abort-runtime.test.ts +0 -83
  95. package/vendor/agent-root/src/agent/agent/__test__/callback-safety.test.ts +0 -34
  96. package/vendor/agent-root/src/agent/agent/__test__/compaction.test.ts +0 -323
  97. package/vendor/agent-root/src/agent/agent/__test__/concurrency.test.ts +0 -290
  98. package/vendor/agent-root/src/agent/agent/__test__/error-normalizer.test.ts +0 -377
  99. package/vendor/agent-root/src/agent/agent/__test__/error.test.ts +0 -212
  100. package/vendor/agent-root/src/agent/agent/__test__/fault-injection.test.ts +0 -295
  101. package/vendor/agent-root/src/agent/agent/__test__/index.test.ts +0 -3607
  102. package/vendor/agent-root/src/agent/agent/__test__/logger.test.ts +0 -35
  103. package/vendor/agent-root/src/agent/agent/__test__/message-utils.test.ts +0 -517
  104. package/vendor/agent-root/src/agent/agent/__test__/telemetry.test.ts +0 -97
  105. package/vendor/agent-root/src/agent/agent/__test__/timeout-budget.test.ts +0 -479
  106. package/vendor/agent-root/src/agent/agent/__test__/tool-call-merge.test.ts +0 -80
  107. package/vendor/agent-root/src/agent/agent/__test__/tool-execution-ledger.test.ts +0 -76
  108. package/vendor/agent-root/src/agent/agent/__test__/write-buffer.test.ts +0 -173
  109. package/vendor/agent-root/src/agent/agent/__test__/write-file-session.test.ts +0 -109
  110. package/vendor/agent-root/src/agent/agent/abort-runtime.ts +0 -71
  111. package/vendor/agent-root/src/agent/agent/callback-safety.ts +0 -33
  112. package/vendor/agent-root/src/agent/agent/compaction.ts +0 -291
  113. package/vendor/agent-root/src/agent/agent/concurrency.ts +0 -103
  114. package/vendor/agent-root/src/agent/agent/error-normalizer.ts +0 -190
  115. package/vendor/agent-root/src/agent/agent/error.ts +0 -198
  116. package/vendor/agent-root/src/agent/agent/index.ts +0 -1772
  117. package/vendor/agent-root/src/agent/agent/logger.ts +0 -65
  118. package/vendor/agent-root/src/agent/agent/message-utils.ts +0 -101
  119. package/vendor/agent-root/src/agent/agent/stream-events.ts +0 -61
  120. package/vendor/agent-root/src/agent/agent/telemetry.ts +0 -123
  121. package/vendor/agent-root/src/agent/agent/timeout-budget.ts +0 -227
  122. package/vendor/agent-root/src/agent/agent/tool-call-merge.ts +0 -111
  123. package/vendor/agent-root/src/agent/agent/tool-execution-ledger.ts +0 -164
  124. package/vendor/agent-root/src/agent/agent/write-buffer.ts +0 -188
  125. package/vendor/agent-root/src/agent/agent/write-file-session.ts +0 -238
  126. package/vendor/agent-root/src/agent/app/__test__/agent-app-service.test.ts +0 -1053
  127. package/vendor/agent-root/src/agent/app/__test__/minimal-agent-application.test.ts +0 -158
  128. package/vendor/agent-root/src/agent/app/__test__/sqlite-agent-app-store.test.ts +0 -437
  129. package/vendor/agent-root/src/agent/app/agent-app-service.ts +0 -748
  130. package/vendor/agent-root/src/agent/app/contracts.ts +0 -109
  131. package/vendor/agent-root/src/agent/app/index.ts +0 -5
  132. package/vendor/agent-root/src/agent/app/minimal-agent-application.ts +0 -151
  133. package/vendor/agent-root/src/agent/app/ports.ts +0 -72
  134. package/vendor/agent-root/src/agent/app/sqlite-agent-app-store.ts +0 -1182
  135. package/vendor/agent-root/src/agent/app/sqlite-client.ts +0 -177
  136. package/vendor/agent-root/src/agent/docs/cli-app-layer/00-README.md +0 -36
  137. package/vendor/agent-root/src/agent/docs/cli-app-layer/01-scope-and-goals.md +0 -33
  138. package/vendor/agent-root/src/agent/docs/cli-app-layer/02-architecture-overview.md +0 -40
  139. package/vendor/agent-root/src/agent/docs/cli-app-layer/03-domain-model-and-contracts.md +0 -91
  140. package/vendor/agent-root/src/agent/docs/cli-app-layer/04-ports-and-interfaces.md +0 -116
  141. package/vendor/agent-root/src/agent/docs/cli-app-layer/05-run-orchestration-and-state-machine.md +0 -52
  142. package/vendor/agent-root/src/agent/docs/cli-app-layer/06-cli-commands-and-ux.md +0 -53
  143. package/vendor/agent-root/src/agent/docs/cli-app-layer/07-storage-design-local.md +0 -52
  144. package/vendor/agent-root/src/agent/docs/cli-app-layer/08-error-and-observability.md +0 -40
  145. package/vendor/agent-root/src/agent/docs/cli-app-layer/09-security-and-policy-boundary.md +0 -19
  146. package/vendor/agent-root/src/agent/docs/cli-app-layer/10-test-plan-and-acceptance.md +0 -28
  147. package/vendor/agent-root/src/agent/docs/cli-app-layer/11-implementation-phases.md +0 -26
  148. package/vendor/agent-root/src/agent/docs/cli-app-layer/12-open-questions-and-risks.md +0 -30
  149. package/vendor/agent-root/src/agent/docs/cli-app-layer/13-sqlite-schema-fields-and-rationale.md +0 -567
  150. package/vendor/agent-root/src/agent/docs/cli-app-layer/14-project-flow-mermaid.md +0 -583
  151. package/vendor/agent-root/src/agent/docs/cli-app-layer/15-openclaw-style-project-blueprint.md +0 -972
  152. package/vendor/agent-root/src/agent/error-contract.ts +0 -154
  153. package/vendor/agent-root/src/agent/prompts/system.ts +0 -246
  154. package/vendor/agent-root/src/agent/prompts/system1.ts +0 -208
  155. package/vendor/agent-root/src/agent/storage/__test__/file-history-store.test.ts +0 -98
  156. package/vendor/agent-root/src/agent/storage/file-history-store.ts +0 -313
  157. package/vendor/agent-root/src/agent/storage/file-storage-config.ts +0 -94
  158. package/vendor/agent-root/src/agent/storage/file-system.ts +0 -31
  159. package/vendor/agent-root/src/agent/storage/file-write-service.ts +0 -21
  160. package/vendor/agent-root/src/agent/tool/__test__/base-tool.test.ts +0 -413
  161. package/vendor/agent-root/src/agent/tool/__test__/bash-policy.test.ts +0 -356
  162. package/vendor/agent-root/src/agent/tool/__test__/bash.mocked-coverage.test.ts +0 -375
  163. package/vendor/agent-root/src/agent/tool/__test__/bash.test.ts +0 -372
  164. package/vendor/agent-root/src/agent/tool/__test__/error.test.ts +0 -108
  165. package/vendor/agent-root/src/agent/tool/__test__/file-edit-tool.test.ts +0 -258
  166. package/vendor/agent-root/src/agent/tool/__test__/file-history-tools.test.ts +0 -121
  167. package/vendor/agent-root/src/agent/tool/__test__/file-read-tool.test.ts +0 -210
  168. package/vendor/agent-root/src/agent/tool/__test__/glob.test.ts +0 -139
  169. package/vendor/agent-root/src/agent/tool/__test__/grep.mocked-coverage.test.ts +0 -456
  170. package/vendor/agent-root/src/agent/tool/__test__/grep.test.ts +0 -192
  171. package/vendor/agent-root/src/agent/tool/__test__/lsp.test.ts +0 -300
  172. package/vendor/agent-root/src/agent/tool/__test__/outside-workspace-confirmation.test.ts +0 -214
  173. package/vendor/agent-root/src/agent/tool/__test__/path-security.test.ts +0 -336
  174. package/vendor/agent-root/src/agent/tool/__test__/skill-loader.test.ts +0 -494
  175. package/vendor/agent-root/src/agent/tool/__test__/skill-parser.test.ts +0 -543
  176. package/vendor/agent-root/src/agent/tool/__test__/skill-tool.test.ts +0 -172
  177. package/vendor/agent-root/src/agent/tool/__test__/task-concurrency-and-version.test.ts +0 -116
  178. package/vendor/agent-root/src/agent/tool/__test__/task-create-get-list-update.test.ts +0 -267
  179. package/vendor/agent-root/src/agent/tool/__test__/task-create.test.ts +0 -519
  180. package/vendor/agent-root/src/agent/tool/__test__/task-errors.test.ts +0 -225
  181. package/vendor/agent-root/src/agent/tool/__test__/task-output-blocking.test.ts +0 -223
  182. package/vendor/agent-root/src/agent/tool/__test__/task-output.test.ts +0 -184
  183. package/vendor/agent-root/src/agent/tool/__test__/task-parent-abort.test.ts +0 -287
  184. package/vendor/agent-root/src/agent/tool/__test__/task-real-runner-adapter.test.ts +0 -190
  185. package/vendor/agent-root/src/agent/tool/__test__/task-run-lifecycle.test.ts +0 -352
  186. package/vendor/agent-root/src/agent/tool/__test__/task-store-runner-branches.test.ts +0 -395
  187. package/vendor/agent-root/src/agent/tool/__test__/task-store.test.ts +0 -391
  188. package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config-integration.test.ts +0 -176
  189. package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config.test.ts +0 -68
  190. package/vendor/agent-root/src/agent/tool/__test__/task-tools-core-edges.test.ts +0 -630
  191. package/vendor/agent-root/src/agent/tool/__test__/task-tools-runtime-edges.test.ts +0 -732
  192. package/vendor/agent-root/src/agent/tool/__test__/task-types.test.ts +0 -494
  193. package/vendor/agent-root/src/agent/tool/__test__/task-utils-branches.test.ts +0 -175
  194. package/vendor/agent-root/src/agent/tool/__test__/tool-manager.test.ts +0 -505
  195. package/vendor/agent-root/src/agent/tool/__test__/types.test.ts +0 -55
  196. package/vendor/agent-root/src/agent/tool/__test__/web-fetch.test.ts +0 -244
  197. package/vendor/agent-root/src/agent/tool/__test__/web-search.test.ts +0 -290
  198. package/vendor/agent-root/src/agent/tool/__test__/write-file.test.ts +0 -368
  199. package/vendor/agent-root/src/agent/tool/base-tool.ts +0 -345
  200. package/vendor/agent-root/src/agent/tool/bash-policy.ts +0 -636
  201. package/vendor/agent-root/src/agent/tool/bash.ts +0 -688
  202. package/vendor/agent-root/src/agent/tool/error.ts +0 -131
  203. package/vendor/agent-root/src/agent/tool/file-edit-tool.ts +0 -264
  204. package/vendor/agent-root/src/agent/tool/file-history-list.ts +0 -103
  205. package/vendor/agent-root/src/agent/tool/file-history-restore.ts +0 -149
  206. package/vendor/agent-root/src/agent/tool/file-read-tool.ts +0 -211
  207. package/vendor/agent-root/src/agent/tool/glob.ts +0 -171
  208. package/vendor/agent-root/src/agent/tool/grep.ts +0 -496
  209. package/vendor/agent-root/src/agent/tool/lsp.ts +0 -481
  210. package/vendor/agent-root/src/agent/tool/path-security.ts +0 -117
  211. package/vendor/agent-root/src/agent/tool/search/common.ts +0 -153
  212. package/vendor/agent-root/src/agent/tool/skill/index.ts +0 -13
  213. package/vendor/agent-root/src/agent/tool/skill/loader.ts +0 -229
  214. package/vendor/agent-root/src/agent/tool/skill/parser.ts +0 -124
  215. package/vendor/agent-root/src/agent/tool/skill/types.ts +0 -27
  216. package/vendor/agent-root/src/agent/tool/skill-tool.ts +0 -143
  217. package/vendor/agent-root/src/agent/tool/task-create.ts +0 -186
  218. package/vendor/agent-root/src/agent/tool/task-errors.ts +0 -42
  219. package/vendor/agent-root/src/agent/tool/task-get.ts +0 -116
  220. package/vendor/agent-root/src/agent/tool/task-graph.ts +0 -78
  221. package/vendor/agent-root/src/agent/tool/task-list.ts +0 -141
  222. package/vendor/agent-root/src/agent/tool/task-mock-runner-adapter.ts +0 -232
  223. package/vendor/agent-root/src/agent/tool/task-output.ts +0 -223
  224. package/vendor/agent-root/src/agent/tool/task-parent-abort.ts +0 -115
  225. package/vendor/agent-root/src/agent/tool/task-real-runner-adapter.ts +0 -336
  226. package/vendor/agent-root/src/agent/tool/task-runner-adapter.ts +0 -55
  227. package/vendor/agent-root/src/agent/tool/task-stop.ts +0 -187
  228. package/vendor/agent-root/src/agent/tool/task-store.ts +0 -217
  229. package/vendor/agent-root/src/agent/tool/task-subagent-config.ts +0 -149
  230. package/vendor/agent-root/src/agent/tool/task-types.ts +0 -264
  231. package/vendor/agent-root/src/agent/tool/task-update.ts +0 -315
  232. package/vendor/agent-root/src/agent/tool/task.ts +0 -209
  233. package/vendor/agent-root/src/agent/tool/tool-manager.ts +0 -361
  234. package/vendor/agent-root/src/agent/tool/tool-prompts.ts +0 -242
  235. package/vendor/agent-root/src/agent/tool/types.ts +0 -116
  236. package/vendor/agent-root/src/agent/tool/web-fetch.ts +0 -227
  237. package/vendor/agent-root/src/agent/tool/web-search.ts +0 -208
  238. package/vendor/agent-root/src/agent/tool/write-file.ts +0 -497
  239. package/vendor/agent-root/src/agent/types.ts +0 -232
  240. package/vendor/agent-root/src/agent/utils/__tests__/index.test.ts +0 -18
  241. package/vendor/agent-root/src/agent/utils/__tests__/message-utils.test.ts +0 -610
  242. package/vendor/agent-root/src/agent/utils/__tests__/message.test.ts +0 -223
  243. package/vendor/agent-root/src/agent/utils/__tests__/token.test.ts +0 -42
  244. package/vendor/agent-root/src/agent/utils/index.ts +0 -16
  245. package/vendor/agent-root/src/agent/utils/message.ts +0 -171
  246. package/vendor/agent-root/src/agent/utils/token.ts +0 -28
  247. package/vendor/agent-root/src/config/__tests__/load-config-to-env.test.ts +0 -238
  248. package/vendor/agent-root/src/config/__tests__/loader.test.ts +0 -361
  249. package/vendor/agent-root/src/config/__tests__/runtime.test.ts +0 -88
  250. package/vendor/agent-root/src/config/index.ts +0 -55
  251. package/vendor/agent-root/src/config/loader.ts +0 -494
  252. package/vendor/agent-root/src/config/paths.ts +0 -30
  253. package/vendor/agent-root/src/config/runtime.ts +0 -163
  254. package/vendor/agent-root/src/config/types.ts +0 -96
  255. package/vendor/agent-root/src/logger/index.ts +0 -57
  256. package/vendor/agent-root/src/logger/logger.ts +0 -819
  257. package/vendor/agent-root/src/logger/types.ts +0 -150
  258. package/vendor/agent-root/src/providers/__tests__/errors.test.ts +0 -441
  259. package/vendor/agent-root/src/providers/__tests__/index.test.ts +0 -16
  260. package/vendor/agent-root/src/providers/__tests__/openai-compatible.options.test.ts +0 -318
  261. package/vendor/agent-root/src/providers/__tests__/openai-compatible.test.ts +0 -600
  262. package/vendor/agent-root/src/providers/__tests__/registry.test.ts +0 -523
  263. package/vendor/agent-root/src/providers/__tests__/responses-adapter.test.ts +0 -298
  264. package/vendor/agent-root/src/providers/adapters/__tests__/anthropic.test.ts +0 -354
  265. package/vendor/agent-root/src/providers/adapters/__tests__/kimi.test.ts +0 -58
  266. package/vendor/agent-root/src/providers/adapters/__tests__/standard.test.ts +0 -261
  267. package/vendor/agent-root/src/providers/adapters/anthropic.ts +0 -572
  268. package/vendor/agent-root/src/providers/adapters/base.ts +0 -131
  269. package/vendor/agent-root/src/providers/adapters/kimi.ts +0 -48
  270. package/vendor/agent-root/src/providers/adapters/responses.ts +0 -732
  271. package/vendor/agent-root/src/providers/adapters/standard.ts +0 -120
  272. package/vendor/agent-root/src/providers/http/__tests__/client.timeout.test.ts +0 -313
  273. package/vendor/agent-root/src/providers/http/client.ts +0 -289
  274. package/vendor/agent-root/src/providers/http/stream-parser.ts +0 -109
  275. package/vendor/agent-root/src/providers/index.ts +0 -76
  276. package/vendor/agent-root/src/providers/kimi-headers.ts +0 -177
  277. package/vendor/agent-root/src/providers/openai-compatible.ts +0 -387
  278. package/vendor/agent-root/src/providers/registry/model-config.ts +0 -477
  279. package/vendor/agent-root/src/providers/registry/provider-factory.ts +0 -127
  280. package/vendor/agent-root/src/providers/registry.ts +0 -135
  281. package/vendor/agent-root/src/providers/types/api.ts +0 -284
  282. package/vendor/agent-root/src/providers/types/config.ts +0 -58
  283. package/vendor/agent-root/src/providers/types/errors.ts +0 -323
  284. package/vendor/agent-root/src/providers/types/index.ts +0 -72
  285. package/vendor/agent-root/src/providers/types/provider.ts +0 -45
  286. package/vendor/agent-root/src/providers/types/registry.ts +0 -68
@@ -1,116 +0,0 @@
1
- /* v8 ignore file */
2
- /* c8 ignore file */
3
- export interface Tool {
4
- name: string;
5
- description: string;
6
- parameters: unknown;
7
- }
8
-
9
- export interface LLMTool {
10
- type: 'function';
11
- function: Tool;
12
- }
13
-
14
- export interface ToolCallFunction {
15
- name: string;
16
- arguments: string;
17
- }
18
-
19
- export interface ToolCall {
20
- id: string;
21
- type: string;
22
- index: number;
23
- function: ToolCallFunction;
24
- }
25
-
26
- export interface ToolStreamChunk {
27
- type: 'stdout' | 'stderr' | 'progress';
28
- data: string;
29
- }
30
-
31
- export interface ToolConfirmInfo {
32
- toolCallId: string;
33
- toolName: string;
34
- arguments: string;
35
- reason?: string;
36
- metadata?: Record<string, unknown>;
37
- }
38
-
39
- export interface ToolDecision {
40
- approved: boolean;
41
- message?: string;
42
- }
43
-
44
- export interface ToolPolicyCheckInfo {
45
- toolCallId: string;
46
- toolName: string;
47
- arguments: string;
48
- parsedArguments: Record<string, unknown>;
49
- }
50
-
51
- export interface ToolPolicyDecision {
52
- allowed: boolean;
53
- code?: string;
54
- message?: string;
55
- audit?: Record<string, unknown>;
56
- }
57
-
58
- export type ToolConcurrencyMode = 'parallel-safe' | 'exclusive';
59
-
60
- export interface ToolConcurrencyPolicy {
61
- mode: ToolConcurrencyMode;
62
- lockKey?: string;
63
- }
64
-
65
- /**
66
- * 工具流式事件类型
67
- */
68
- export type ToolStreamEventType =
69
- | 'start'
70
- | 'stdout'
71
- | 'stderr'
72
- | 'progress'
73
- | 'artifact'
74
- | 'info'
75
- | 'end'
76
- | 'error';
77
-
78
- /**
79
- * 工具事件输入
80
- */
81
- export interface ToolStreamEventInput {
82
- /** 事件类型 */
83
- type: ToolStreamEventType;
84
- /** 文本内容 */
85
- content?: string;
86
- /** 结构化数据 */
87
- data?: unknown;
88
- /** 自定义序号(可选) */
89
- sequence?: number;
90
- /** 自定义时间戳(可选) */
91
- timestamp?: number;
92
- }
93
-
94
- /**
95
- * 工具执行上下文
96
- *
97
- * 传递给工具执行时的上下文信息
98
- */
99
- export interface ToolExecutionContext {
100
- /** 工具调用 ID */
101
- toolCallId: string;
102
- /** 循环索引 */
103
- loopIndex: number;
104
- /** Agent 实例引用 */
105
- agent: unknown;
106
- /** 工具流式事件发射器(可选) */
107
- onChunk?: (event: ToolStreamEventInput) => void | Promise<void>;
108
- onConfirm?: (info: ToolConfirmInfo) => Promise<ToolDecision>;
109
- onPolicyCheck?: (info: ToolPolicyCheckInfo) => ToolPolicyDecision | Promise<ToolPolicyDecision>;
110
- /** 当前调用是否已通过用户确认 */
111
- confirmationApproved?: boolean;
112
- /** 工具执行中断信号(超时/取消时触发) */
113
- toolAbortSignal?: AbortSignal;
114
- }
115
-
116
- export const AGENT_TOOL_TYPES_MODULE = 'renx-tool-types';
@@ -1,227 +0,0 @@
1
- import { z } from 'zod';
2
- import { BaseTool, type ToolResult } from './base-tool';
3
- import { ToolExecutionError } from './error';
4
- import { WEB_FETCH_TOOL_DESCRIPTION } from './tool-prompts';
5
- import type { ToolExecutionContext } from './types';
6
-
7
- // 安全常量
8
- const MAX_RESPONSE_SIZE = 5 * 1024 * 1024; // 5MB
9
- const DEFAULT_TIMEOUT_MS = 30_000;
10
- const MAX_TIMEOUT_MS = 120_000;
11
-
12
- // SSRF 防护:禁止访问的地址模式
13
- const BLOCKED_HOST_PATTERNS: RegExp[] = [
14
- // localhost 和回环地址
15
- /^(localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\])$/i,
16
- // 内网 IP
17
- /^10\./,
18
- /^172\.(1[6-9]|2[0-9]|3[0-1])\./,
19
- /^192\.168\./,
20
- // 链路本地和云元数据地址
21
- /^169\.254\./,
22
- /^(metadata\.google\.internal|metadata\.azure|169\.254\.169\.254)$/i,
23
- ];
24
-
25
- /**
26
- * 检查 URL 是否为内网或敏感地址(SSRF 防护)
27
- */
28
- function isBlockedAddress(url: string): { blocked: boolean; reason?: string } {
29
- try {
30
- const parsed = new URL(url);
31
- const hostname = parsed.hostname.toLowerCase();
32
-
33
- for (const pattern of BLOCKED_HOST_PATTERNS) {
34
- if (pattern.test(hostname)) {
35
- return { blocked: true, reason: `Blocked address: ${hostname}` };
36
- }
37
- }
38
-
39
- // 检查协议
40
- if (!['http:', 'https:'].includes(parsed.protocol)) {
41
- return { blocked: true, reason: `Unsupported protocol: ${parsed.protocol}` };
42
- }
43
-
44
- return { blocked: false };
45
- } catch {
46
- return { blocked: true, reason: 'Invalid URL format' };
47
- }
48
- }
49
-
50
- /**
51
- * 安全地截断输出,避免内存溢出
52
- */
53
- function truncateOutput(
54
- content: string,
55
- maxLength: number
56
- ): { output: string; truncated: boolean } {
57
- if (content.length <= maxLength) {
58
- return { output: content, truncated: false };
59
- }
60
-
61
- const marker = '\n\n[... Content Truncated ...]\n\n';
62
- const available = maxLength - marker.length;
63
- if (available <= 100) {
64
- return { output: content.slice(0, maxLength), truncated: true };
65
- }
66
-
67
- const headLength = Math.floor(available * 0.7);
68
- const tailLength = available - headLength;
69
-
70
- return {
71
- output: content.slice(0, headLength) + marker + content.slice(content.length - tailLength),
72
- truncated: true,
73
- };
74
- }
75
-
76
- /**
77
- * 简单的 HTML 到纯文本转换(无外部依赖)
78
- */
79
- function htmlToText(html: string): string {
80
- let text = html;
81
- // 移除 script 和 style 标签
82
- text = text.replace(/<script[^>]*>[\s\S]*?<\/script>/gi, '');
83
- text = text.replace(/<style[^>]*>[\s\S]*?<\/style>/gi, '');
84
- // 移除 HTML 标签
85
- text = text.replace(/<[^>]+>/g, ' ');
86
- // 解码常见 HTML 实体
87
- const entities: Record<string, string> = {
88
- '&nbsp;': ' ',
89
- '&amp;': '&',
90
- '&lt;': '<',
91
- '&gt;': '>',
92
- '&quot;': '"',
93
- '&#39;': "'",
94
- '&apos;': "'",
95
- };
96
- for (const [entity, char] of Object.entries(entities)) {
97
- text = text.replace(new RegExp(entity, 'g'), char);
98
- }
99
- // 清理多余空白
100
- return text.replace(/\s+/g, ' ').trim();
101
- }
102
-
103
- const schema = z
104
- .object({
105
- url: z.string().url().describe('The URL to fetch'),
106
- extractMode: z
107
- .enum(['text', 'markdown', 'html'])
108
- .default('text')
109
- .describe('Content extraction mode: text (plain text), markdown (simplified), or html (raw)'),
110
- maxChars: z
111
- .number()
112
- .int()
113
- .min(100)
114
- .max(100_000)
115
- .default(30_000)
116
- .describe('Maximum characters to return'),
117
- timeout: z
118
- .number()
119
- .int()
120
- .min(1000)
121
- .max(MAX_TIMEOUT_MS)
122
- .default(DEFAULT_TIMEOUT_MS)
123
- .describe('Request timeout in milliseconds'),
124
- })
125
- .strict();
126
-
127
- export class WebFetchTool extends BaseTool<typeof schema> {
128
- readonly name = 'web_fetch';
129
- readonly description = WEB_FETCH_TOOL_DESCRIPTION;
130
- readonly parameters = schema;
131
-
132
- async execute(
133
- args: z.input<typeof schema>,
134
- _context?: ToolExecutionContext
135
- ): Promise<ToolResult> {
136
- // Apply defaults (zod defaults may not be applied when calling execute directly)
137
- const url = args.url;
138
- const extractMode = args.extractMode ?? 'text';
139
- const maxChars = args.maxChars ?? 30_000;
140
- const timeout = args.timeout ?? DEFAULT_TIMEOUT_MS;
141
-
142
- // SSRF 防护检查
143
- const blockCheck = isBlockedAddress(url);
144
- if (blockCheck.blocked) {
145
- throw new ToolExecutionError(`Security: ${blockCheck.reason}`, 2010);
146
- }
147
-
148
- const controller = new AbortController();
149
- const timeoutId = setTimeout(() => controller.abort(), timeout);
150
-
151
- try {
152
- const response = await fetch(url, {
153
- signal: controller.signal,
154
- headers: {
155
- 'User-Agent': 'Mozilla/5.0 (compatible; AgentBot/1.0)',
156
- Accept: 'text/html,text/plain,application/json,*/*',
157
- },
158
- redirect: 'follow',
159
- });
160
-
161
- if (!response.ok) {
162
- throw new ToolExecutionError(`HTTP ${response.status}: ${response.statusText}`, 2011);
163
- }
164
-
165
- // 检查内容大小
166
- const contentLength = response.headers.get('content-length');
167
- if (contentLength && parseInt(contentLength) > MAX_RESPONSE_SIZE) {
168
- throw new ToolExecutionError(
169
- `Response too large: ${contentLength} bytes exceeds limit of ${MAX_RESPONSE_SIZE}`,
170
- 2012
171
- );
172
- }
173
-
174
- const contentType = response.headers.get('content-type') || '';
175
- let body = await response.text();
176
-
177
- // 限制响应大小
178
- if (body.length > MAX_RESPONSE_SIZE) {
179
- body = body.slice(0, MAX_RESPONSE_SIZE);
180
- }
181
-
182
- // 根据模式提取内容
183
- let extractedContent: string;
184
- switch (extractMode) {
185
- case 'html':
186
- extractedContent = body;
187
- break;
188
- case 'markdown':
189
- case 'text':
190
- default:
191
- extractedContent = htmlToText(body);
192
- break;
193
- }
194
-
195
- // 截断到指定长度
196
- const { output, truncated } = truncateOutput(extractedContent, maxChars);
197
-
198
- return {
199
- success: true,
200
- output: `URL: ${url}\nContent-Type: ${contentType}\nExtracted: ${extractMode}\n${truncated ? '(Content truncated)\n' : ''}\n${output}`,
201
- metadata: {
202
- url,
203
- contentType,
204
- extractMode,
205
- truncated,
206
- originalLength: extractedContent.length,
207
- returnedLength: output.length,
208
- },
209
- };
210
- } catch (error) {
211
- if (error instanceof ToolExecutionError) {
212
- throw error;
213
- }
214
- if (error instanceof Error && error.name === 'AbortError') {
215
- throw new ToolExecutionError(`Request timeout after ${timeout}ms`, 2013);
216
- }
217
- throw new ToolExecutionError(
218
- `Fetch failed: ${error instanceof Error ? error.message : String(error)}`,
219
- 2014
220
- );
221
- } finally {
222
- clearTimeout(timeoutId);
223
- }
224
- }
225
- }
226
-
227
- export default WebFetchTool;
@@ -1,208 +0,0 @@
1
- import { z } from 'zod';
2
- import { BaseTool, type ToolResult } from './base-tool';
3
- import { ToolExecutionError } from './error';
4
- import { WEB_SEARCH_TOOL_DESCRIPTION } from './tool-prompts';
5
- import type { ToolExecutionContext } from './types';
6
-
7
- // 搜索结果接口
8
- interface SearchResult {
9
- title: string;
10
- url: string;
11
- snippet: string;
12
- score?: number;
13
- }
14
-
15
- interface SearchResponse {
16
- query: string;
17
- results: SearchResult[];
18
- provider: string;
19
- }
20
-
21
- /**
22
- * Tavily 搜索实现
23
- */
24
- async function searchWithTavily(query: string, maxResults: number): Promise<SearchResponse> {
25
- const apiKey = process.env.TAVILY_API_KEY;
26
- if (!apiKey) {
27
- throw new ToolExecutionError('TAVILY_API_KEY environment variable is not set', 2020);
28
- }
29
-
30
- const response = await fetch('https://api.tavily.com/search', {
31
- method: 'POST',
32
- headers: {
33
- 'Content-Type': 'application/json',
34
- Authorization: `Bearer ${apiKey}`,
35
- },
36
- body: JSON.stringify({
37
- query,
38
- max_results: maxResults,
39
- search_depth: 'basic',
40
- include_answer: false,
41
- include_raw_content: false,
42
- }),
43
- });
44
-
45
- if (!response.ok) {
46
- throw new ToolExecutionError(
47
- `Tavily API error: ${response.status} ${response.statusText}`,
48
- 2021
49
- );
50
- }
51
-
52
- const data = (await response.json()) as {
53
- query?: string;
54
- results?: Array<{ title?: string; url?: string; content?: string; score?: number }>;
55
- };
56
-
57
- return {
58
- query: data.query || query,
59
- provider: 'tavily',
60
- results: (data.results || []).map((r) => ({
61
- title: r.title || 'No title',
62
- url: r.url || '',
63
- snippet: r.content || '',
64
- score: r.score,
65
- })),
66
- };
67
- }
68
-
69
- /**
70
- * Brave Search 实现
71
- */
72
- async function searchWithBrave(query: string, maxResults: number): Promise<SearchResponse> {
73
- const apiKey = process.env.BRAVE_SEARCH_API_KEY;
74
- if (!apiKey) {
75
- throw new ToolExecutionError('BRAVE_SEARCH_API_KEY environment variable is not set', 2022);
76
- }
77
-
78
- const url = new URL('https://api.search.brave.com/res/v1/web/search');
79
- url.searchParams.set('q', query);
80
- url.searchParams.set('count', String(maxResults));
81
-
82
- const response = await fetch(url.toString(), {
83
- headers: {
84
- Accept: 'application/json',
85
- 'Accept-Encoding': 'identity',
86
- 'X-Subscription-Token': apiKey,
87
- },
88
- });
89
-
90
- if (!response.ok) {
91
- throw new ToolExecutionError(
92
- `Brave Search API error: ${response.status} ${response.statusText}`,
93
- 2023
94
- );
95
- }
96
-
97
- const data = (await response.json()) as {
98
- query?: { original?: string };
99
- web?: { results?: Array<{ title?: string; url?: string; description?: string }> };
100
- };
101
-
102
- return {
103
- query: data.query?.original || query,
104
- provider: 'brave',
105
- results: (data.web?.results || []).map((r) => ({
106
- title: r.title || 'No title',
107
- url: r.url || '',
108
- snippet: r.description || '',
109
- })),
110
- };
111
- }
112
-
113
- /**
114
- * 根据可用的 API Key 选择搜索提供商
115
- */
116
- function getSearchProvider(): 'tavily' | 'brave' {
117
- if (process.env.TAVILY_API_KEY) return 'tavily';
118
- if (process.env.BRAVE_SEARCH_API_KEY) return 'brave';
119
- throw new ToolExecutionError(
120
- 'No search API key configured. Set TAVILY_API_KEY or BRAVE_SEARCH_API_KEY environment variable.',
121
- 2024
122
- );
123
- }
124
-
125
- const schema = z
126
- .object({
127
- query: z.string().min(1).max(500).describe('Search query'),
128
- maxResults: z
129
- .number()
130
- .int()
131
- .min(1)
132
- .max(10)
133
- .default(5)
134
- .describe('Maximum number of results (1-10)'),
135
- provider: z
136
- .enum(['tavily', 'brave', 'auto'])
137
- .default('auto')
138
- .describe('Search provider: tavily, brave, or auto (uses first available)'),
139
- })
140
- .strict();
141
-
142
- export class WebSearchTool extends BaseTool<typeof schema> {
143
- readonly name = 'web_search';
144
- readonly description = WEB_SEARCH_TOOL_DESCRIPTION;
145
- readonly parameters = schema;
146
-
147
- async execute(
148
- args: z.input<typeof schema>,
149
- _context?: ToolExecutionContext
150
- ): Promise<ToolResult> {
151
- // Apply defaults (zod defaults may not be applied when calling execute directly)
152
- const query = args.query;
153
- const maxResults = args.maxResults ?? 5;
154
- const provider = args.provider ?? 'auto';
155
-
156
- // 确定使用的搜索提供商
157
- const selectedProvider = provider === 'auto' ? getSearchProvider() : provider;
158
-
159
- // 执行搜索
160
- let response: SearchResponse;
161
- switch (selectedProvider) {
162
- case 'tavily':
163
- response = await searchWithTavily(query, maxResults);
164
- break;
165
- case 'brave':
166
- response = await searchWithBrave(query, maxResults);
167
- break;
168
- default:
169
- throw new ToolExecutionError(`Unknown search provider: ${selectedProvider}`, 2025);
170
- }
171
-
172
- // 格式化输出
173
- const lines: string[] = [
174
- `Search: "${response.query}"`,
175
- `Provider: ${response.provider}`,
176
- `Results: ${response.results.length}`,
177
- '',
178
- ];
179
-
180
- for (let i = 0; i < response.results.length; i++) {
181
- const r = response.results[i];
182
- lines.push(`[${i + 1}] ${r.title}`);
183
- lines.push(` URL: ${r.url}`);
184
- if (r.score !== undefined) {
185
- lines.push(` Score: ${r.score.toFixed(2)}`);
186
- }
187
- if (r.snippet) {
188
- // 截断过长的摘要
189
- const snippet = r.snippet.length > 300 ? r.snippet.slice(0, 300) + '...' : r.snippet;
190
- lines.push(` ${snippet}`);
191
- }
192
- lines.push('');
193
- }
194
-
195
- return {
196
- success: true,
197
- output: lines.join('\n'),
198
- metadata: {
199
- query: response.query,
200
- provider: response.provider,
201
- resultCount: response.results.length,
202
- results: response.results,
203
- },
204
- };
205
- }
206
- }
207
-
208
- export default WebSearchTool;