@wingman-ai/gateway 0.5.3 → 0.5.4

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 (311) hide show
  1. package/dist/agent/config/agentConfig.cjs +4 -0
  2. package/dist/agent/config/agentConfig.d.ts +12 -0
  3. package/dist/agent/config/agentConfig.js +4 -0
  4. package/dist/agent/config/toolRegistry.cjs +75 -1
  5. package/dist/agent/config/toolRegistry.d.ts +3 -0
  6. package/dist/agent/config/toolRegistry.js +75 -1
  7. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  8. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  9. package/dist/agent/middleware/large-tool-results.js +173 -0
  10. package/dist/agent/tools/browser_control.cjs +9 -1231
  11. package/dist/agent/tools/browser_control.d.ts +126 -234
  12. package/dist/agent/tools/browser_control.js +7 -1226
  13. package/dist/agent/tools/browser_runtime.cjs +1189 -0
  14. package/dist/agent/tools/browser_runtime.d.ts +560 -0
  15. package/dist/agent/tools/browser_runtime.js +1122 -0
  16. package/dist/agent/tools/browser_session.cjs +153 -0
  17. package/dist/agent/tools/browser_session.d.ts +741 -0
  18. package/dist/agent/tools/browser_session.js +110 -0
  19. package/dist/agent/tools/browser_session_manager.cjs +202 -0
  20. package/dist/agent/tools/browser_session_manager.d.ts +64 -0
  21. package/dist/agent/tools/browser_session_manager.js +165 -0
  22. package/dist/cli/commands/init.cjs +5 -1
  23. package/dist/cli/commands/init.js +5 -1
  24. package/dist/cli/config/loader.cjs +0 -5
  25. package/dist/cli/config/loader.js +0 -5
  26. package/dist/cli/config/schema.cjs +3 -7
  27. package/dist/cli/config/schema.d.ts +6 -6
  28. package/dist/cli/config/schema.js +3 -7
  29. package/dist/cli/core/agentInvoker.cjs +86 -22
  30. package/dist/cli/core/agentInvoker.d.ts +10 -3
  31. package/dist/cli/core/agentInvoker.js +86 -25
  32. package/dist/cli/core/outputManager.cjs +7 -2
  33. package/dist/cli/core/outputManager.d.ts +2 -2
  34. package/dist/cli/core/outputManager.js +7 -2
  35. package/dist/cli/types.d.ts +2 -1
  36. package/dist/webui/assets/index-XrEnkZiq.css +11 -0
  37. package/dist/webui/assets/index-mDs6HbKM.js +215 -0
  38. package/dist/webui/index.html +2 -2
  39. package/package.json +10 -10
  40. package/templates/agents/README.md +2 -1
  41. package/templates/agents/coding/agent.md +6 -13
  42. package/templates/agents/coding-v2/agent.md +6 -1
  43. package/templates/agents/game-dev/agent.md +8 -2
  44. package/templates/agents/game-dev/game-designer.md +4 -0
  45. package/templates/agents/game-dev/scene-engineer.md +4 -0
  46. package/templates/agents/main/agent.md +5 -0
  47. package/templates/agents/researcher/agent.md +11 -0
  48. package/templates/agents/stock-trader/agent.md +4 -0
  49. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  50. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  51. package/dist/agent/tests/agentConfig.test.js +0 -218
  52. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  53. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  54. package/dist/agent/tests/agentLoader.test.js +0 -329
  55. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  56. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  57. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  58. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  59. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  60. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  61. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  62. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  63. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  64. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  65. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  66. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  67. package/dist/agent/tests/internet_search.test.cjs +0 -107
  68. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  69. package/dist/agent/tests/internet_search.test.js +0 -101
  70. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  71. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  72. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  73. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  74. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  75. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  76. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  77. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  78. package/dist/agent/tests/modelFactory.test.js +0 -184
  79. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  80. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  81. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  82. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  83. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  84. package/dist/agent/tests/test-agent-loader.js +0 -27
  85. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  86. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  87. package/dist/agent/tests/test-subagent-loading.js +0 -93
  88. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  89. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  90. package/dist/agent/tests/toolRegistry.test.js +0 -141
  91. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  92. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  93. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  94. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  95. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  96. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  97. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  98. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  99. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  100. package/dist/tests/agent-config-voice.test.cjs +0 -25
  101. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  102. package/dist/tests/agent-config-voice.test.js +0 -19
  103. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  104. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  105. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  106. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  107. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  108. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  109. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  110. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  111. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  112. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  113. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  114. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  115. package/dist/tests/agents-api.test.cjs +0 -324
  116. package/dist/tests/agents-api.test.d.ts +0 -1
  117. package/dist/tests/agents-api.test.js +0 -318
  118. package/dist/tests/attachments-utils.test.cjs +0 -46
  119. package/dist/tests/attachments-utils.test.d.ts +0 -1
  120. package/dist/tests/attachments-utils.test.js +0 -40
  121. package/dist/tests/browser-command.test.cjs +0 -264
  122. package/dist/tests/browser-command.test.d.ts +0 -1
  123. package/dist/tests/browser-command.test.js +0 -258
  124. package/dist/tests/browser-relay-server.test.cjs +0 -20
  125. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  126. package/dist/tests/browser-relay-server.test.js +0 -14
  127. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  128. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  129. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  130. package/dist/tests/candleRange.test.cjs +0 -48
  131. package/dist/tests/candleRange.test.d.ts +0 -1
  132. package/dist/tests/candleRange.test.js +0 -42
  133. package/dist/tests/cli-config-loader.test.cjs +0 -532
  134. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  135. package/dist/tests/cli-config-loader.test.js +0 -526
  136. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  137. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  138. package/dist/tests/cli-config-warnings.test.js +0 -88
  139. package/dist/tests/cli-init.test.cjs +0 -225
  140. package/dist/tests/cli-init.test.d.ts +0 -1
  141. package/dist/tests/cli-init.test.js +0 -219
  142. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  143. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  144. package/dist/tests/cli-workspace-root.test.js +0 -108
  145. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  146. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  147. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  148. package/dist/tests/codex-provider.test.cjs +0 -383
  149. package/dist/tests/codex-provider.test.d.ts +0 -1
  150. package/dist/tests/codex-provider.test.js +0 -377
  151. package/dist/tests/config-json-schema.test.cjs +0 -37
  152. package/dist/tests/config-json-schema.test.d.ts +0 -1
  153. package/dist/tests/config-json-schema.test.js +0 -31
  154. package/dist/tests/discord-adapter.test.cjs +0 -89
  155. package/dist/tests/discord-adapter.test.d.ts +0 -1
  156. package/dist/tests/discord-adapter.test.js +0 -83
  157. package/dist/tests/falRuntime.test.cjs +0 -78
  158. package/dist/tests/falRuntime.test.d.ts +0 -1
  159. package/dist/tests/falRuntime.test.js +0 -72
  160. package/dist/tests/falSummary.test.cjs +0 -51
  161. package/dist/tests/falSummary.test.d.ts +0 -1
  162. package/dist/tests/falSummary.test.js +0 -45
  163. package/dist/tests/fs-api.test.cjs +0 -138
  164. package/dist/tests/fs-api.test.d.ts +0 -1
  165. package/dist/tests/fs-api.test.js +0 -132
  166. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  167. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  168. package/dist/tests/gateway-command-workspace.test.js +0 -144
  169. package/dist/tests/gateway-http-security.test.cjs +0 -318
  170. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  171. package/dist/tests/gateway-http-security.test.js +0 -312
  172. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  173. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  174. package/dist/tests/gateway-node-mode.test.js +0 -168
  175. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  176. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  177. package/dist/tests/gateway-origin-policy.test.js +0 -76
  178. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  179. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  180. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  181. package/dist/tests/gateway.test.cjs +0 -700
  182. package/dist/tests/gateway.test.d.ts +0 -1
  183. package/dist/tests/gateway.test.js +0 -694
  184. package/dist/tests/hooks-matcher.test.cjs +0 -309
  185. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  186. package/dist/tests/hooks-matcher.test.js +0 -303
  187. package/dist/tests/hooks-merger.test.cjs +0 -528
  188. package/dist/tests/hooks-merger.test.d.ts +0 -1
  189. package/dist/tests/hooks-merger.test.js +0 -522
  190. package/dist/tests/imagePersistence.test.cjs +0 -169
  191. package/dist/tests/imagePersistence.test.d.ts +0 -1
  192. package/dist/tests/imagePersistence.test.js +0 -163
  193. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  194. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  195. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  196. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  197. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  198. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  199. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  200. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  201. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  202. package/dist/tests/logger.test.cjs +0 -353
  203. package/dist/tests/logger.test.d.ts +0 -1
  204. package/dist/tests/logger.test.js +0 -347
  205. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  206. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  207. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  208. package/dist/tests/node-tools.test.cjs +0 -77
  209. package/dist/tests/node-tools.test.d.ts +0 -1
  210. package/dist/tests/node-tools.test.js +0 -71
  211. package/dist/tests/nodes-api.test.cjs +0 -86
  212. package/dist/tests/nodes-api.test.d.ts +0 -1
  213. package/dist/tests/nodes-api.test.js +0 -80
  214. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  215. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  216. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  217. package/dist/tests/provider-command-codex.test.cjs +0 -57
  218. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  219. package/dist/tests/provider-command-codex.test.js +0 -51
  220. package/dist/tests/routines-api.test.cjs +0 -107
  221. package/dist/tests/routines-api.test.d.ts +0 -1
  222. package/dist/tests/routines-api.test.js +0 -101
  223. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  224. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  225. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  226. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  227. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  228. package/dist/tests/sessionManager-uionly.test.js +0 -44
  229. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  230. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  231. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  232. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  233. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  234. package/dist/tests/sessionMessageRole.test.js +0 -38
  235. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  236. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  237. package/dist/tests/sessionStateMessages.test.js +0 -230
  238. package/dist/tests/sessions-api.test.cjs +0 -250
  239. package/dist/tests/sessions-api.test.d.ts +0 -1
  240. package/dist/tests/sessions-api.test.js +0 -244
  241. package/dist/tests/skill-activation.test.cjs +0 -86
  242. package/dist/tests/skill-activation.test.d.ts +0 -1
  243. package/dist/tests/skill-activation.test.js +0 -80
  244. package/dist/tests/skill-metadata.test.cjs +0 -119
  245. package/dist/tests/skill-metadata.test.d.ts +0 -1
  246. package/dist/tests/skill-metadata.test.js +0 -113
  247. package/dist/tests/skill-repository.test.cjs +0 -469
  248. package/dist/tests/skill-repository.test.d.ts +0 -1
  249. package/dist/tests/skill-repository.test.js +0 -463
  250. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  251. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  252. package/dist/tests/skill-security-scanner.test.js +0 -120
  253. package/dist/tests/sms-api.test.cjs +0 -183
  254. package/dist/tests/sms-api.test.d.ts +0 -1
  255. package/dist/tests/sms-api.test.js +0 -177
  256. package/dist/tests/sms-commands.test.cjs +0 -90
  257. package/dist/tests/sms-commands.test.d.ts +0 -1
  258. package/dist/tests/sms-commands.test.js +0 -84
  259. package/dist/tests/sms-policy-store.test.cjs +0 -69
  260. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  261. package/dist/tests/sms-policy-store.test.js +0 -63
  262. package/dist/tests/teams-adapter.test.cjs +0 -58
  263. package/dist/tests/teams-adapter.test.d.ts +0 -1
  264. package/dist/tests/teams-adapter.test.js +0 -52
  265. package/dist/tests/technicalIndicators.test.cjs +0 -82
  266. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  267. package/dist/tests/technicalIndicators.test.js +0 -76
  268. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  269. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  270. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  271. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  272. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  273. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  274. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  275. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  276. package/dist/tests/terminal-bench-config.test.js +0 -56
  277. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  278. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  279. package/dist/tests/terminal-bench-official.test.js +0 -188
  280. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  281. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  282. package/dist/tests/terminal-bench-runner.test.js +0 -76
  283. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  284. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  286. package/dist/tests/terminalProbe.test.cjs +0 -45
  287. package/dist/tests/terminalProbe.test.d.ts +0 -1
  288. package/dist/tests/terminalProbe.test.js +0 -39
  289. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  290. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  291. package/dist/tests/terminalProbeAuth.test.js +0 -79
  292. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  293. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  294. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  295. package/dist/tests/uv.test.cjs +0 -47
  296. package/dist/tests/uv.test.d.ts +0 -1
  297. package/dist/tests/uv.test.js +0 -41
  298. package/dist/tests/voice-config.test.cjs +0 -35
  299. package/dist/tests/voice-config.test.d.ts +0 -1
  300. package/dist/tests/voice-config.test.js +0 -29
  301. package/dist/tests/websocket-transport.test.cjs +0 -31
  302. package/dist/tests/websocket-transport.test.d.ts +0 -1
  303. package/dist/tests/websocket-transport.test.js +0 -25
  304. package/dist/tests/yahooCandles.test.cjs +0 -111
  305. package/dist/tests/yahooCandles.test.d.ts +0 -1
  306. package/dist/tests/yahooCandles.test.js +0 -105
  307. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  308. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  309. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  310. package/dist/webui/assets/index-BMf95nv5.js +0 -215
  311. package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
@@ -1,463 +0,0 @@
1
- import { afterEach, describe, expect, it, vi } from "vitest";
2
- import { SkillRepository } from "../cli/services/skillRepository.js";
3
- describe("SkillRepository clawhub provider", ()=>{
4
- const originalFetch = globalThis.fetch;
5
- afterEach(()=>{
6
- globalThis.fetch = originalFetch;
7
- vi.restoreAllMocks();
8
- });
9
- it("lists skills from ClawHub", async ()=>{
10
- const fetchMock = vi.fn().mockResolvedValue(new Response(JSON.stringify({
11
- items: [
12
- {
13
- slug: "gog",
14
- displayName: "Gog",
15
- summary: "Google workspace tooling",
16
- latestVersion: {
17
- version: "1.0.0"
18
- }
19
- }
20
- ],
21
- nextCursor: null
22
- }), {
23
- status: 200
24
- }));
25
- globalThis.fetch = fetchMock;
26
- const repository = new SkillRepository({
27
- provider: "clawhub",
28
- clawhubBaseUrl: "https://clawhub.ai"
29
- });
30
- const skills = await repository.listAvailableSkills();
31
- expect(skills).toEqual([
32
- {
33
- name: "gog",
34
- description: "Google workspace tooling",
35
- path: "gog",
36
- metadata: {
37
- name: "gog",
38
- description: "Google workspace tooling"
39
- }
40
- }
41
- ]);
42
- expect(fetchMock).toHaveBeenCalledTimes(1);
43
- expect(fetchMock.mock.calls[0][0]).toBe("https://clawhub.ai/api/v1/skills?sort=downloads&limit=100");
44
- });
45
- it("downloads files for a ClawHub skill", async ()=>{
46
- const fetchMock = vi.fn(async (input)=>{
47
- const url = input.toString();
48
- if ("https://clawhub.ai/api/v1/skills/gog" === url) return new Response(JSON.stringify({
49
- skill: {
50
- slug: "gog",
51
- summary: "Google workspace tooling"
52
- },
53
- latestVersion: {
54
- version: "1.0.0"
55
- }
56
- }), {
57
- status: 200
58
- });
59
- if ("https://clawhub.ai/api/v1/skills/gog/versions/1.0.0" === url) return new Response(JSON.stringify({
60
- version: {
61
- version: "1.0.0",
62
- files: [
63
- {
64
- path: "SKILL.md"
65
- },
66
- {
67
- path: "examples.md"
68
- }
69
- ]
70
- }
71
- }), {
72
- status: 200
73
- });
74
- if (url.includes("/api/v1/skills/gog/file?")) {
75
- const parsed = new URL(url);
76
- const requestedPath = parsed.searchParams.get("path");
77
- if ("SKILL.md" === requestedPath) return new Response("---\nname: gog\ndescription: Test\n---\n", {
78
- status: 200
79
- });
80
- if ("examples.md" === requestedPath) return new Response("# Examples", {
81
- status: 200
82
- });
83
- }
84
- return new Response("Not Found", {
85
- status: 404
86
- });
87
- });
88
- globalThis.fetch = fetchMock;
89
- const repository = new SkillRepository({
90
- provider: "clawhub",
91
- clawhubBaseUrl: "https://clawhub.ai"
92
- });
93
- const files = await repository.downloadSkill("gog");
94
- expect(files.size).toBe(2);
95
- expect(Buffer.isBuffer(files.get("SKILL.md"))).toBe(true);
96
- expect(files.get("SKILL.md")?.toString("utf-8")).toContain("name: gog");
97
- expect(files.get("examples.md")?.toString("utf-8")).toContain("Examples");
98
- expect(fetchMock).toHaveBeenCalledTimes(4);
99
- });
100
- });
101
- describe("SkillRepository github provider", ()=>{
102
- const originalFetch = globalThis.fetch;
103
- afterEach(()=>{
104
- globalThis.fetch = originalFetch;
105
- vi.restoreAllMocks();
106
- });
107
- it("merges skills across repositories with later sources overriding earlier ones", async ()=>{
108
- const encodeSkill = (name, description)=>Buffer.from(`---\nname: ${name}\ndescription: ${description}\n---\n`, "utf-8").toString("base64");
109
- const fetchMock = vi.fn(async (input)=>{
110
- const url = input.toString();
111
- if (url.endsWith("/repos/example-org/community-skills/contents/skills")) return new Response(JSON.stringify([
112
- {
113
- name: "gog",
114
- path: "skills/gog",
115
- type: "dir",
116
- url: "https://api.github.com/repos/example-org/community-skills/contents/skills/gog"
117
- },
118
- {
119
- name: "alpha",
120
- path: "skills/alpha",
121
- type: "dir",
122
- url: "https://api.github.com/repos/example-org/community-skills/contents/skills/alpha"
123
- }
124
- ]), {
125
- status: 200
126
- });
127
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills")) return new Response(JSON.stringify([
128
- {
129
- name: "alpha",
130
- path: "skills/alpha",
131
- type: "dir",
132
- url: "https://api.github.com/repos/example-team/custom-skills/contents/skills/alpha"
133
- },
134
- {
135
- name: "wingman-special",
136
- path: "skills/wingman-special",
137
- type: "dir",
138
- url: "https://api.github.com/repos/example-team/custom-skills/contents/skills/wingman-special"
139
- }
140
- ]), {
141
- status: 200
142
- });
143
- if (url.endsWith("/repos/example-org/community-skills/contents/skills/gog/SKILL.md")) return new Response(JSON.stringify({
144
- type: "file",
145
- content: encodeSkill("gog", "Community gog skill")
146
- }), {
147
- status: 200
148
- });
149
- if (url.endsWith("/repos/example-org/community-skills/contents/skills/alpha/SKILL.md")) return new Response(JSON.stringify({
150
- type: "file",
151
- content: encodeSkill("alpha", "Community alpha skill")
152
- }), {
153
- status: 200
154
- });
155
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/alpha/SKILL.md")) return new Response(JSON.stringify({
156
- type: "file",
157
- content: encodeSkill("alpha", "Custom alpha override")
158
- }), {
159
- status: 200
160
- });
161
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/wingman-special/SKILL.md")) return new Response(JSON.stringify({
162
- type: "file",
163
- content: encodeSkill("wingman-special", "Custom-only skill")
164
- }), {
165
- status: 200
166
- });
167
- return new Response("Not Found", {
168
- status: 404
169
- });
170
- });
171
- globalThis.fetch = fetchMock;
172
- const repository = new SkillRepository({
173
- provider: "github",
174
- repositories: [
175
- {
176
- owner: "example-org",
177
- name: "community-skills"
178
- },
179
- {
180
- owner: "example-team",
181
- name: "custom-skills"
182
- }
183
- ]
184
- });
185
- const skills = await repository.listAvailableSkills();
186
- expect(skills).toEqual([
187
- {
188
- name: "gog",
189
- description: "Community gog skill",
190
- path: "skills/gog",
191
- metadata: {
192
- name: "gog",
193
- description: "Community gog skill"
194
- }
195
- },
196
- {
197
- name: "alpha",
198
- description: "Custom alpha override",
199
- path: "skills/alpha",
200
- metadata: {
201
- name: "alpha",
202
- description: "Custom alpha override"
203
- }
204
- },
205
- {
206
- name: "wingman-special",
207
- description: "Custom-only skill",
208
- path: "skills/wingman-special",
209
- metadata: {
210
- name: "wingman-special",
211
- description: "Custom-only skill"
212
- }
213
- }
214
- ]);
215
- });
216
- it("downloads a skill from the highest-priority matching repository", async ()=>{
217
- const encodedSkill = Buffer.from("---\nname: alpha\ndescription: Custom alpha override\n---\n", "utf-8").toString("base64");
218
- const encodedExample = Buffer.from("# Custom Example\n", "utf-8").toString("base64");
219
- const fetchMock = vi.fn(async (input)=>{
220
- const url = input.toString();
221
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/alpha/SKILL.md")) return new Response(JSON.stringify({
222
- type: "file",
223
- content: encodedSkill,
224
- encoding: "base64"
225
- }), {
226
- status: 200
227
- });
228
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/alpha")) return new Response(JSON.stringify([
229
- {
230
- type: "file",
231
- name: "SKILL.md",
232
- path: "skills/alpha/SKILL.md",
233
- content: encodedSkill,
234
- encoding: "base64"
235
- },
236
- {
237
- type: "file",
238
- name: "examples.md",
239
- path: "skills/alpha/examples.md",
240
- content: encodedExample,
241
- encoding: "base64"
242
- }
243
- ]), {
244
- status: 200
245
- });
246
- return new Response("Not Found", {
247
- status: 404
248
- });
249
- });
250
- globalThis.fetch = fetchMock;
251
- const repository = new SkillRepository({
252
- provider: "github",
253
- repositories: [
254
- {
255
- owner: "example-org",
256
- name: "community-skills"
257
- },
258
- {
259
- owner: "example-team",
260
- name: "custom-skills"
261
- }
262
- ]
263
- });
264
- const files = await repository.downloadSkill("alpha");
265
- expect(files.size).toBe(2);
266
- expect(files.get("SKILL.md")?.toString("utf-8")).toContain("Custom alpha override");
267
- expect(files.get("examples.md")?.toString("utf-8")).toContain("Custom Example");
268
- const requestedUrls = fetchMock.mock.calls.map((call)=>call[0].toString());
269
- expect(requestedUrls.some((url)=>url.includes("/repos/example-org/community-skills/contents/skills/alpha"))).toBe(false);
270
- });
271
- it("uses legacy repositoryOwner/repositoryName when repositories are not provided", async ()=>{
272
- const fetchMock = vi.fn(async (input)=>{
273
- const url = input.toString();
274
- if (url.endsWith("/repos/myorg/myskills/contents/skills")) return new Response(JSON.stringify([
275
- {
276
- name: "legacy-skill",
277
- path: "skills/legacy-skill",
278
- type: "dir",
279
- url: "https://api.github.com/repos/myorg/myskills/contents/skills/legacy-skill"
280
- }
281
- ]), {
282
- status: 200
283
- });
284
- if (url.endsWith("/repos/myorg/myskills/contents/skills/legacy-skill/SKILL.md")) return new Response(JSON.stringify({
285
- type: "file",
286
- content: Buffer.from("---\nname: legacy-skill\ndescription: Legacy source\n---\n", "utf-8").toString("base64")
287
- }), {
288
- status: 200
289
- });
290
- return new Response("Not Found", {
291
- status: 404
292
- });
293
- });
294
- globalThis.fetch = fetchMock;
295
- const repository = new SkillRepository({
296
- provider: "github",
297
- repositoryOwner: "myorg",
298
- repositoryName: "myskills"
299
- });
300
- const skills = await repository.listAvailableSkills();
301
- expect(skills).toHaveLength(1);
302
- expect(skills[0]?.name).toBe("legacy-skill");
303
- });
304
- it("fails clearly when github provider has no configured repositories", async ()=>{
305
- const repository = new SkillRepository({
306
- provider: "github"
307
- });
308
- await expect(repository.listAvailableSkills()).rejects.toThrow("No GitHub skill repositories configured");
309
- });
310
- });
311
- describe("SkillRepository hybrid provider", ()=>{
312
- const originalFetch = globalThis.fetch;
313
- afterEach(()=>{
314
- globalThis.fetch = originalFetch;
315
- vi.restoreAllMocks();
316
- });
317
- it("merges ClawHub and GitHub skills, with GitHub overriding conflicts", async ()=>{
318
- const encodeSkill = (name, description)=>Buffer.from(`---\nname: ${name}\ndescription: ${description}\n---\n`, "utf-8").toString("base64");
319
- const fetchMock = vi.fn(async (input)=>{
320
- const url = input.toString();
321
- if ("https://clawhub.ai/api/v1/skills?sort=downloads&limit=100" === url) return new Response(JSON.stringify({
322
- items: [
323
- {
324
- slug: "alpha",
325
- summary: "ClawHub alpha skill"
326
- },
327
- {
328
- slug: "weather",
329
- summary: "ClawHub weather skill"
330
- }
331
- ],
332
- nextCursor: null
333
- }), {
334
- status: 200
335
- });
336
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills")) return new Response(JSON.stringify([
337
- {
338
- name: "alpha",
339
- path: "skills/alpha",
340
- type: "dir",
341
- url: "https://api.github.com/repos/example-team/custom-skills/contents/skills/alpha"
342
- },
343
- {
344
- name: "wingman-special",
345
- path: "skills/wingman-special",
346
- type: "dir",
347
- url: "https://api.github.com/repos/example-team/custom-skills/contents/skills/wingman-special"
348
- }
349
- ]), {
350
- status: 200
351
- });
352
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/alpha/SKILL.md")) return new Response(JSON.stringify({
353
- type: "file",
354
- content: encodeSkill("alpha", "GitHub alpha override")
355
- }), {
356
- status: 200
357
- });
358
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/wingman-special/SKILL.md")) return new Response(JSON.stringify({
359
- type: "file",
360
- content: encodeSkill("wingman-special", "GitHub only skill")
361
- }), {
362
- status: 200
363
- });
364
- return new Response("Not Found", {
365
- status: 404
366
- });
367
- });
368
- globalThis.fetch = fetchMock;
369
- const repository = new SkillRepository({
370
- provider: "hybrid",
371
- repositories: [
372
- {
373
- owner: "example-team",
374
- name: "custom-skills"
375
- }
376
- ],
377
- clawhubBaseUrl: "https://clawhub.ai"
378
- });
379
- const skills = await repository.listAvailableSkills();
380
- expect(skills).toEqual([
381
- {
382
- name: "weather",
383
- description: "ClawHub weather skill",
384
- path: "weather",
385
- metadata: {
386
- name: "weather",
387
- description: "ClawHub weather skill"
388
- }
389
- },
390
- {
391
- name: "alpha",
392
- description: "GitHub alpha override",
393
- path: "skills/alpha",
394
- metadata: {
395
- name: "alpha",
396
- description: "GitHub alpha override"
397
- }
398
- },
399
- {
400
- name: "wingman-special",
401
- description: "GitHub only skill",
402
- path: "skills/wingman-special",
403
- metadata: {
404
- name: "wingman-special",
405
- description: "GitHub only skill"
406
- }
407
- }
408
- ]);
409
- });
410
- it("falls back to ClawHub when a skill is missing from configured GitHub repos", async ()=>{
411
- const fetchMock = vi.fn(async (input)=>{
412
- const url = input.toString();
413
- if (url.endsWith("/repos/example-team/custom-skills/contents/skills/gog/SKILL.md")) return new Response("Not Found", {
414
- status: 404
415
- });
416
- if ("https://clawhub.ai/api/v1/skills/gog" === url) return new Response(JSON.stringify({
417
- skill: {
418
- slug: "gog",
419
- summary: "Google workspace tooling"
420
- },
421
- latestVersion: {
422
- version: "1.0.0"
423
- }
424
- }), {
425
- status: 200
426
- });
427
- if ("https://clawhub.ai/api/v1/skills/gog/versions/1.0.0" === url) return new Response(JSON.stringify({
428
- version: {
429
- version: "1.0.0",
430
- files: [
431
- {
432
- path: "SKILL.md"
433
- }
434
- ]
435
- }
436
- }), {
437
- status: 200
438
- });
439
- if (url.includes("/api/v1/skills/gog/file?")) return new Response("---\nname: gog\ndescription: Test\n---\n", {
440
- status: 200
441
- });
442
- return new Response("Not Found", {
443
- status: 404
444
- });
445
- });
446
- globalThis.fetch = fetchMock;
447
- const repository = new SkillRepository({
448
- provider: "hybrid",
449
- repositories: [
450
- {
451
- owner: "example-team",
452
- name: "custom-skills"
453
- }
454
- ],
455
- clawhubBaseUrl: "https://clawhub.ai"
456
- });
457
- const metadata = await repository.getSkillMetadata("gog");
458
- expect(metadata.name).toBe("gog");
459
- expect(metadata.description).toContain("Google workspace tooling");
460
- const files = await repository.downloadSkill("gog");
461
- expect(files.has("SKILL.md")).toBe(true);
462
- });
463
- });
@@ -1,126 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_node_events_namespaceObject = require("node:events");
4
- const external_vitest_namespaceObject = require("vitest");
5
- const skillSecurityScanner_cjs_namespaceObject = require("../cli/services/skillSecurityScanner.cjs");
6
- const { mockSpawn, mockEnsureUvAvailableForFeature } = external_vitest_namespaceObject.vi.hoisted(()=>({
7
- mockSpawn: external_vitest_namespaceObject.vi.fn(),
8
- mockEnsureUvAvailableForFeature: external_vitest_namespaceObject.vi.fn()
9
- }));
10
- external_vitest_namespaceObject.vi.mock("node:child_process", ()=>({
11
- spawn: mockSpawn
12
- }));
13
- external_vitest_namespaceObject.vi.mock("@/utils/uv.js", ()=>({
14
- ensureUvAvailableForFeature: mockEnsureUvAvailableForFeature
15
- }));
16
- const createMockChildProcess = (input)=>{
17
- const child = new external_node_events_namespaceObject.EventEmitter();
18
- child.stdout = new external_node_events_namespaceObject.EventEmitter();
19
- child.stderr = new external_node_events_namespaceObject.EventEmitter();
20
- queueMicrotask(()=>{
21
- if (input.stdout) child.stdout.emit("data", Buffer.from(input.stdout));
22
- if (input.stderr) child.stderr.emit("data", Buffer.from(input.stderr));
23
- child.emit("close", input.exitCode);
24
- });
25
- return child;
26
- };
27
- const createLogger = ()=>({
28
- debug: external_vitest_namespaceObject.vi.fn(),
29
- info: external_vitest_namespaceObject.vi.fn(),
30
- warn: external_vitest_namespaceObject.vi.fn(),
31
- error: external_vitest_namespaceObject.vi.fn()
32
- });
33
- (0, external_vitest_namespaceObject.describe)("skill security scanner", ()=>{
34
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
35
- mockSpawn.mockReset();
36
- mockEnsureUvAvailableForFeature.mockReset();
37
- });
38
- (0, external_vitest_namespaceObject.it)("skips execution when scanOnInstall is disabled", async ()=>{
39
- const logger = createLogger();
40
- await (0, skillSecurityScanner_cjs_namespaceObject.scanSkillDirectory)("/tmp/skill", logger, {
41
- scanOnInstall: false
42
- });
43
- (0, external_vitest_namespaceObject.expect)(mockEnsureUvAvailableForFeature).not.toHaveBeenCalled();
44
- (0, external_vitest_namespaceObject.expect)(mockSpawn).not.toHaveBeenCalled();
45
- });
46
- (0, external_vitest_namespaceObject.it)("blocks installation when blocking issue codes are reported", async ()=>{
47
- const logger = createLogger();
48
- mockSpawn.mockReturnValue(createMockChildProcess({
49
- exitCode: 0,
50
- stdout: JSON.stringify({
51
- "/tmp/skill": {
52
- issues: [
53
- {
54
- code: "MCP501",
55
- message: "dangerous behavior"
56
- }
57
- ]
58
- }
59
- })
60
- }));
61
- await (0, external_vitest_namespaceObject.expect)((0, skillSecurityScanner_cjs_namespaceObject.scanSkillDirectory)("/tmp/skill", logger, {
62
- scannerCommand: "uvx",
63
- scannerArgs: [
64
- "scan",
65
- "--json"
66
- ],
67
- blockIssueCodes: [
68
- "MCP501"
69
- ]
70
- })).rejects.toThrow(/MCP501/);
71
- (0, external_vitest_namespaceObject.expect)(mockEnsureUvAvailableForFeature).toHaveBeenCalledWith("uvx", "skills.security.scanOnInstall");
72
- (0, external_vitest_namespaceObject.expect)(mockSpawn).toHaveBeenCalledWith("uvx", [
73
- "scan",
74
- "--json",
75
- "/tmp/skill"
76
- ], external_vitest_namespaceObject.expect.objectContaining({
77
- stdio: [
78
- "ignore",
79
- "pipe",
80
- "pipe"
81
- ]
82
- }));
83
- });
84
- (0, external_vitest_namespaceObject.it)("logs non-blocking issues and continues", async ()=>{
85
- const logger = createLogger();
86
- mockSpawn.mockReturnValue(createMockChildProcess({
87
- exitCode: 0,
88
- stdout: JSON.stringify({
89
- "/tmp/skill": {
90
- issues: [
91
- {
92
- code: "MCP999",
93
- message: "informational"
94
- }
95
- ]
96
- }
97
- })
98
- }));
99
- await (0, external_vitest_namespaceObject.expect)((0, skillSecurityScanner_cjs_namespaceObject.scanSkillDirectory)("/tmp/skill", logger, {
100
- blockIssueCodes: [
101
- "MCP501"
102
- ]
103
- })).resolves.toBeUndefined();
104
- (0, external_vitest_namespaceObject.expect)(logger.warn).toHaveBeenCalledWith(external_vitest_namespaceObject.expect.stringContaining("MCP999"));
105
- });
106
- (0, external_vitest_namespaceObject.it)("parses JSON output when scanner emits extra log lines", async ()=>{
107
- const logger = createLogger();
108
- mockSpawn.mockReturnValue(createMockChildProcess({
109
- exitCode: 0,
110
- stdout: "scanner starting\n{\"/tmp/skill\":{\"issues\":[]}}\nscanner complete"
111
- }));
112
- await (0, external_vitest_namespaceObject.expect)((0, skillSecurityScanner_cjs_namespaceObject.scanSkillDirectory)("/tmp/skill", logger)).resolves.toBeUndefined();
113
- });
114
- (0, external_vitest_namespaceObject.it)("fails when the scanner command exits non-zero", async ()=>{
115
- const logger = createLogger();
116
- mockSpawn.mockReturnValue(createMockChildProcess({
117
- exitCode: 2,
118
- stderr: "scan failed"
119
- }));
120
- await (0, external_vitest_namespaceObject.expect)((0, skillSecurityScanner_cjs_namespaceObject.scanSkillDirectory)("/tmp/skill", logger)).rejects.toThrow(/exit code 2: scan failed/);
121
- });
122
- });
123
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
124
- Object.defineProperty(exports, '__esModule', {
125
- value: true
126
- });
@@ -1 +0,0 @@
1
- export {};