@contractspec/example.agent-console 3.7.6 → 3.8.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 (288) hide show
  1. package/.turbo/turbo-build.log +126 -105
  2. package/AGENTS.md +52 -31
  3. package/CHANGELOG.md +29 -0
  4. package/README.md +112 -83
  5. package/dist/agent/agent.event.js +1 -1
  6. package/dist/agent/agent.handler.d.ts +3 -0
  7. package/dist/agent/agent.handler.js +730 -1
  8. package/dist/agent/agent.operation.js +1 -1
  9. package/dist/agent/index.d.ts +5 -5
  10. package/dist/agent/index.js +74 -73
  11. package/dist/agent.feature.js +179 -0
  12. package/dist/browser/agent/agent.event.js +1 -1
  13. package/dist/browser/agent/agent.handler.js +730 -1
  14. package/dist/browser/agent/agent.operation.js +1 -1
  15. package/dist/browser/agent/index.js +74 -73
  16. package/dist/browser/agent.feature.js +179 -0
  17. package/dist/browser/docs/agent-console.docblock.js +11 -8
  18. package/dist/browser/docs/index.js +11 -8
  19. package/dist/browser/example.js +2 -3
  20. package/dist/browser/handlers/agent.handlers.js +1883 -2
  21. package/dist/browser/handlers/index.js +2142 -8
  22. package/dist/browser/index.js +4075 -3161
  23. package/dist/browser/presentations/index.js +51 -51
  24. package/dist/browser/run/index.js +380 -374
  25. package/dist/browser/run/run.event.js +2 -2
  26. package/dist/browser/run/run.handler.js +666 -1
  27. package/dist/browser/run/run.presentation.js +2 -2
  28. package/dist/browser/shared/index.js +293 -1
  29. package/dist/browser/shared/mock-runs.js +5 -0
  30. package/dist/browser/tool/index.js +161 -161
  31. package/dist/browser/tool/tool.event.js +1 -1
  32. package/dist/browser/tool/tool.handler.js +479 -3
  33. package/dist/browser/tool/tool.presentation.js +2 -2
  34. package/dist/browser/ui/AgentDashboard.js +1816 -931
  35. package/dist/browser/ui/AgentDashboard.visualizations.js +217 -0
  36. package/dist/browser/ui/AgentRunList.js +360 -128
  37. package/dist/browser/ui/AgentToolRegistry.js +9 -9
  38. package/dist/browser/ui/hooks/index.js +611 -161
  39. package/dist/browser/ui/hooks/useAgentList.js +1 -1
  40. package/dist/browser/ui/hooks/useAgentMutations.js +444 -9
  41. package/dist/browser/ui/hooks/useRunList.js +26 -11
  42. package/dist/browser/ui/hooks/useToolList.js +1 -1
  43. package/dist/browser/ui/index.js +2161 -1258
  44. package/dist/browser/ui/modals/AgentActionsModal.js +13 -13
  45. package/dist/browser/ui/modals/CreateAgentModal.js +15 -15
  46. package/dist/browser/ui/modals/index.js +297 -297
  47. package/dist/browser/ui/renderers/agent-list.markdown.js +14 -5
  48. package/dist/browser/ui/renderers/agent-list.renderer.js +7 -7
  49. package/dist/browser/ui/renderers/dashboard.markdown.js +207 -36
  50. package/dist/browser/ui/renderers/index.js +359 -163
  51. package/dist/browser/ui/renderers/run-list.markdown.js +9 -4
  52. package/dist/browser/ui/renderers/tool-registry.markdown.js +15 -4
  53. package/dist/browser/ui/views/AgentListView.js +7 -7
  54. package/dist/browser/ui/views/RunDataTable.js +326 -0
  55. package/dist/browser/ui/views/RunListView.js +360 -128
  56. package/dist/browser/ui/views/ToolRegistryView.js +9 -9
  57. package/dist/browser/ui/views/index.js +478 -246
  58. package/dist/browser/ui/views/run-data-table.columns.js +271 -0
  59. package/dist/browser/ui/views/run-list.shared.js +177 -0
  60. package/dist/browser/visualizations/catalog.js +134 -0
  61. package/dist/browser/visualizations/index.js +187 -0
  62. package/dist/browser/visualizations/selectors.js +181 -0
  63. package/dist/docs/agent-console.docblock.js +11 -8
  64. package/dist/docs/index.js +11 -8
  65. package/dist/example.js +2 -3
  66. package/dist/example.test.d.ts +1 -0
  67. package/dist/handlers/agent.handlers.d.ts +2 -0
  68. package/dist/handlers/agent.handlers.js +1883 -2
  69. package/dist/handlers/index.d.ts +2 -4
  70. package/dist/handlers/index.js +2142 -8
  71. package/dist/handlers/mock-handlers.test.d.ts +1 -0
  72. package/dist/index.d.ts +6 -4
  73. package/dist/index.js +4075 -3161
  74. package/dist/node/agent/agent.event.js +1 -1
  75. package/dist/node/agent/agent.handler.js +730 -1
  76. package/dist/node/agent/agent.operation.js +1 -1
  77. package/dist/node/agent/index.js +74 -73
  78. package/dist/node/agent.feature.js +179 -0
  79. package/dist/node/docs/agent-console.docblock.js +11 -8
  80. package/dist/node/docs/index.js +11 -8
  81. package/dist/node/example.js +2 -3
  82. package/dist/node/handlers/agent.handlers.js +1883 -2
  83. package/dist/node/handlers/index.js +2142 -8
  84. package/dist/node/index.js +4075 -3161
  85. package/dist/node/presentations/index.js +51 -51
  86. package/dist/node/run/index.js +380 -374
  87. package/dist/node/run/run.event.js +2 -2
  88. package/dist/node/run/run.handler.js +666 -1
  89. package/dist/node/run/run.presentation.js +2 -2
  90. package/dist/node/shared/index.js +293 -1
  91. package/dist/node/shared/mock-runs.js +5 -0
  92. package/dist/node/tool/index.js +161 -161
  93. package/dist/node/tool/tool.event.js +1 -1
  94. package/dist/node/tool/tool.handler.js +479 -3
  95. package/dist/node/tool/tool.presentation.js +2 -2
  96. package/dist/node/ui/AgentDashboard.js +1816 -931
  97. package/dist/node/ui/AgentDashboard.visualizations.js +217 -0
  98. package/dist/node/ui/AgentRunList.js +360 -128
  99. package/dist/node/ui/AgentToolRegistry.js +9 -9
  100. package/dist/node/ui/hooks/index.js +611 -161
  101. package/dist/node/ui/hooks/useAgentList.js +1 -1
  102. package/dist/node/ui/hooks/useAgentMutations.js +444 -9
  103. package/dist/node/ui/hooks/useRunList.js +26 -11
  104. package/dist/node/ui/hooks/useToolList.js +1 -1
  105. package/dist/node/ui/index.js +2161 -1258
  106. package/dist/node/ui/modals/AgentActionsModal.js +13 -13
  107. package/dist/node/ui/modals/CreateAgentModal.js +15 -15
  108. package/dist/node/ui/modals/index.js +297 -297
  109. package/dist/node/ui/renderers/agent-list.markdown.js +14 -5
  110. package/dist/node/ui/renderers/agent-list.renderer.js +7 -7
  111. package/dist/node/ui/renderers/dashboard.markdown.js +207 -36
  112. package/dist/node/ui/renderers/index.js +359 -163
  113. package/dist/node/ui/renderers/run-list.markdown.js +9 -4
  114. package/dist/node/ui/renderers/tool-registry.markdown.js +15 -4
  115. package/dist/node/ui/views/AgentListView.js +7 -7
  116. package/dist/node/ui/views/RunDataTable.js +326 -0
  117. package/dist/node/ui/views/RunListView.js +360 -128
  118. package/dist/node/ui/views/ToolRegistryView.js +9 -9
  119. package/dist/node/ui/views/index.js +478 -246
  120. package/dist/node/ui/views/run-data-table.columns.js +271 -0
  121. package/dist/node/ui/views/run-list.shared.js +177 -0
  122. package/dist/node/visualizations/catalog.js +134 -0
  123. package/dist/node/visualizations/index.js +187 -0
  124. package/dist/node/visualizations/selectors.js +181 -0
  125. package/dist/presentations/index.d.ts +3 -5
  126. package/dist/presentations/index.js +51 -51
  127. package/dist/proof/index.d.ts +2 -0
  128. package/dist/proof/meetup-proof.d.ts +10 -0
  129. package/dist/proof/meetup-proof.runtime.d.ts +22 -0
  130. package/dist/proof/meetup-proof.scenario.d.ts +2 -0
  131. package/dist/proof/meetup-proof.suite.d.ts +1 -0
  132. package/dist/proof/meetup-proof.test.d.ts +1 -0
  133. package/dist/run/index.d.ts +7 -7
  134. package/dist/run/index.js +380 -374
  135. package/dist/run/run.event.js +2 -2
  136. package/dist/run/run.handler.d.ts +7 -0
  137. package/dist/run/run.handler.js +666 -1
  138. package/dist/run/run.presentation.js +2 -2
  139. package/dist/shared/demo-dashboard-data.d.ts +16 -0
  140. package/dist/shared/demo-runtime-seed.d.ts +17 -0
  141. package/dist/shared/demo-runtime.d.ts +8 -0
  142. package/dist/shared/demo-runtime.test.d.ts +1 -0
  143. package/dist/shared/index.d.ts +4 -1
  144. package/dist/shared/index.js +293 -1
  145. package/dist/shared/mock-runs.d.ts +4 -0
  146. package/dist/shared/mock-runs.js +5 -0
  147. package/dist/tool/index.d.ts +7 -7
  148. package/dist/tool/index.js +161 -161
  149. package/dist/tool/tool.event.js +1 -1
  150. package/dist/tool/tool.handler.d.ts +3 -0
  151. package/dist/tool/tool.handler.js +479 -3
  152. package/dist/tool/tool.presentation.js +2 -2
  153. package/dist/ui/AgentDashboard.js +1816 -931
  154. package/dist/ui/AgentDashboard.sandbox.test.d.ts +1 -0
  155. package/dist/ui/AgentDashboard.visualizations.d.ts +4 -0
  156. package/dist/ui/AgentDashboard.visualizations.js +218 -0
  157. package/dist/ui/AgentRunList.js +360 -128
  158. package/dist/ui/AgentToolRegistry.js +9 -9
  159. package/dist/ui/hooks/index.d.ts +4 -4
  160. package/dist/ui/hooks/index.js +611 -161
  161. package/dist/ui/hooks/useAgentList.d.ts +5 -0
  162. package/dist/ui/hooks/useAgentList.js +1 -1
  163. package/dist/ui/hooks/useAgentMutations.d.ts +9 -2
  164. package/dist/ui/hooks/useAgentMutations.js +444 -9
  165. package/dist/ui/hooks/useRunList.d.ts +13 -2
  166. package/dist/ui/hooks/useRunList.js +26 -11
  167. package/dist/ui/hooks/useToolList.d.ts +5 -0
  168. package/dist/ui/hooks/useToolList.js +1 -1
  169. package/dist/ui/index.d.ts +3 -3
  170. package/dist/ui/index.js +2161 -1258
  171. package/dist/ui/modals/AgentActionsModal.js +13 -13
  172. package/dist/ui/modals/CreateAgentModal.js +15 -15
  173. package/dist/ui/modals/index.d.ts +1 -1
  174. package/dist/ui/modals/index.js +297 -297
  175. package/dist/ui/renderers/agent-list.markdown.d.ts +5 -0
  176. package/dist/ui/renderers/agent-list.markdown.js +14 -5
  177. package/dist/ui/renderers/agent-list.renderer.js +7 -7
  178. package/dist/ui/renderers/dashboard.markdown.d.ts +5 -0
  179. package/dist/ui/renderers/dashboard.markdown.js +207 -36
  180. package/dist/ui/renderers/index.d.ts +2 -2
  181. package/dist/ui/renderers/index.js +359 -163
  182. package/dist/ui/renderers/run-list.markdown.d.ts +5 -0
  183. package/dist/ui/renderers/run-list.markdown.js +9 -4
  184. package/dist/ui/renderers/tool-registry.markdown.d.ts +6 -1
  185. package/dist/ui/renderers/tool-registry.markdown.js +15 -4
  186. package/dist/ui/views/AgentListView.js +7 -7
  187. package/dist/ui/views/RunDataTable.d.ts +18 -0
  188. package/dist/ui/views/RunDataTable.js +327 -0
  189. package/dist/ui/views/RunListView.js +360 -128
  190. package/dist/ui/views/ToolRegistryView.js +9 -9
  191. package/dist/ui/views/index.js +478 -246
  192. package/dist/ui/views/run-data-table.columns.d.ts +3 -0
  193. package/dist/ui/views/run-data-table.columns.js +272 -0
  194. package/dist/ui/views/run-list.shared.d.ts +14 -0
  195. package/dist/ui/views/run-list.shared.js +178 -0
  196. package/dist/visualizations/catalog.d.ts +10 -0
  197. package/dist/visualizations/catalog.js +135 -0
  198. package/dist/visualizations/index.d.ts +2 -0
  199. package/dist/visualizations/index.js +188 -0
  200. package/dist/visualizations/selectors.d.ts +3 -0
  201. package/dist/visualizations/selectors.js +182 -0
  202. package/dist/visualizations/selectors.test.d.ts +1 -0
  203. package/package.json +114 -12
  204. package/proofs/agent-console-meetup.replay.json +220 -0
  205. package/src/agent/agent.entity.ts +111 -111
  206. package/src/agent/agent.enum.ts +12 -12
  207. package/src/agent/agent.event.ts +91 -91
  208. package/src/agent/agent.handler.ts +144 -127
  209. package/src/agent/agent.operation.ts +400 -400
  210. package/src/agent/agent.presentation.ts +62 -62
  211. package/src/agent/agent.schema.ts +175 -175
  212. package/src/agent/agent.test-spec.ts +48 -48
  213. package/src/agent/index.ts +46 -51
  214. package/src/agent.capability.ts +11 -11
  215. package/src/agent.feature.ts +134 -131
  216. package/src/docs/agent-console.docblock.ts +52 -49
  217. package/src/example.test.ts +75 -0
  218. package/src/example.ts +34 -35
  219. package/src/handlers/agent.handlers.ts +576 -522
  220. package/src/handlers/index.ts +30 -14
  221. package/src/handlers/mock-handlers.test.ts +77 -0
  222. package/src/index.ts +10 -9
  223. package/src/presentations/index.ts +11 -13
  224. package/src/proof/index.ts +2 -0
  225. package/src/proof/meetup-proof.runtime.ts +196 -0
  226. package/src/proof/meetup-proof.scenario.ts +99 -0
  227. package/src/proof/meetup-proof.suite.ts +29 -0
  228. package/src/proof/meetup-proof.test.ts +28 -0
  229. package/src/proof/meetup-proof.ts +130 -0
  230. package/src/run/index.ts +49 -54
  231. package/src/run/run.entity.ts +137 -137
  232. package/src/run/run.enum.ts +18 -18
  233. package/src/run/run.event.ts +174 -174
  234. package/src/run/run.handler.ts +113 -96
  235. package/src/run/run.operation.ts +474 -474
  236. package/src/run/run.presentation.ts +42 -42
  237. package/src/run/run.schema.ts +126 -126
  238. package/src/run/run.test-spec.ts +48 -48
  239. package/src/seeders/index.ts +21 -21
  240. package/src/shared/demo-dashboard-data.ts +58 -0
  241. package/src/shared/demo-runtime-seed.ts +139 -0
  242. package/src/shared/demo-runtime.test.ts +169 -0
  243. package/src/shared/demo-runtime.ts +260 -0
  244. package/src/shared/index.ts +12 -1
  245. package/src/shared/mock-agents.ts +76 -76
  246. package/src/shared/mock-runs.ts +107 -102
  247. package/src/shared/mock-tools.ts +140 -140
  248. package/src/shared/overlay-types.ts +23 -23
  249. package/src/tool/index.ts +39 -44
  250. package/src/tool/tool.entity.ts +73 -73
  251. package/src/tool/tool.enum.ts +13 -13
  252. package/src/tool/tool.event.ts +80 -80
  253. package/src/tool/tool.handler.ts +124 -107
  254. package/src/tool/tool.operation.ts +328 -328
  255. package/src/tool/tool.presentation.ts +43 -43
  256. package/src/tool/tool.schema.ts +106 -106
  257. package/src/tool/tool.test-spec.ts +48 -48
  258. package/src/ui/AgentDashboard.sandbox.test.tsx +312 -0
  259. package/src/ui/AgentDashboard.tsx +351 -348
  260. package/src/ui/AgentDashboard.visualizations.tsx +35 -0
  261. package/src/ui/hooks/index.ts +7 -7
  262. package/src/ui/hooks/useAgentList.ts +57 -56
  263. package/src/ui/hooks/useAgentMutations.ts +168 -159
  264. package/src/ui/hooks/useRunList.ts +90 -57
  265. package/src/ui/hooks/useToolList.ts +102 -101
  266. package/src/ui/index.ts +6 -9
  267. package/src/ui/modals/AgentActionsModal.tsx +262 -262
  268. package/src/ui/modals/CreateAgentModal.tsx +232 -232
  269. package/src/ui/modals/index.ts +1 -1
  270. package/src/ui/overlays/demo-overlays.ts +52 -52
  271. package/src/ui/renderers/agent-list.markdown.ts +81 -61
  272. package/src/ui/renderers/agent-list.renderer.tsx +14 -14
  273. package/src/ui/renderers/dashboard.markdown.ts +135 -139
  274. package/src/ui/renderers/index.ts +3 -4
  275. package/src/ui/renderers/run-list.markdown.ts +56 -47
  276. package/src/ui/renderers/tool-registry.markdown.ts +79 -66
  277. package/src/ui/views/AgentListView.tsx +90 -90
  278. package/src/ui/views/RunDataTable.tsx +74 -0
  279. package/src/ui/views/RunListView.tsx +84 -158
  280. package/src/ui/views/ToolRegistryView.tsx +113 -113
  281. package/src/ui/views/run-data-table.columns.tsx +102 -0
  282. package/src/ui/views/run-list.shared.tsx +139 -0
  283. package/src/visualizations/catalog.ts +132 -0
  284. package/src/visualizations/index.ts +2 -0
  285. package/src/visualizations/selectors.test.ts +12 -0
  286. package/src/visualizations/selectors.ts +70 -0
  287. package/tsconfig.json +7 -8
  288. package/tsdown.config.js +24 -3
@@ -1,14 +1,14 @@
1
1
  import {
2
- defineCommand,
3
- defineQuery,
2
+ defineCommand,
3
+ defineQuery,
4
4
  } from '@contractspec/lib.contracts-spec/operations';
5
5
  import { defineSchemaModel, ScalarTypeEnum } from '@contractspec/lib.schema';
6
6
  import { ToolCategoryEnum, ToolStatusEnum } from './tool.enum';
7
7
  import {
8
- CreateToolInputModel,
9
- ToolModel,
10
- ToolSummaryModel,
11
- UpdateToolInputModel,
8
+ CreateToolInputModel,
9
+ ToolModel,
10
+ ToolSummaryModel,
11
+ UpdateToolInputModel,
12
12
  } from './tool.schema';
13
13
 
14
14
  const OWNERS = ['@agent-console-team'] as const;
@@ -17,350 +17,350 @@ const OWNERS = ['@agent-console-team'] as const;
17
17
  * CreateToolCommand - Creates a new tool definition.
18
18
  */
19
19
  export const CreateToolCommand = defineCommand({
20
- meta: {
21
- key: 'agent.tool.create',
22
- version: '1.0.0',
23
- stability: 'stable',
24
- owners: [...OWNERS],
25
- tags: ['tool', 'create'],
26
- description: 'Creates a new AI tool definition.',
27
- goal: 'Allow users to define new tools that agents can use.',
28
- context: 'Called from the tool builder UI when creating a new tool.',
29
- },
30
- io: {
31
- input: CreateToolInputModel,
32
- output: defineSchemaModel({
33
- name: 'CreateToolOutput',
34
- fields: {
35
- id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
36
- name: { type: ScalarTypeEnum.NonEmptyString(), isOptional: false },
37
- slug: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
38
- status: { type: ToolStatusEnum, isOptional: false },
39
- },
40
- }),
41
- errors: {
42
- SLUG_EXISTS: {
43
- description: 'A tool with this slug already exists in the organization',
44
- http: 409,
45
- gqlCode: 'SLUG_EXISTS',
46
- when: 'Slug is already taken',
47
- },
48
- },
49
- },
50
- policy: { auth: 'user' },
51
- sideEffects: {
52
- emits: [
53
- {
54
- key: 'tool.created',
55
- version: '1.0.0',
56
- stability: 'stable',
57
- owners: [...OWNERS],
58
- tags: ['tool', 'created'],
59
- when: 'Tool is successfully created',
60
- payload: ToolSummaryModel,
61
- },
62
- ],
63
- audit: ['tool.created'],
64
- },
65
- acceptance: {
66
- scenarios: [
67
- {
68
- key: 'create-tool-happy-path',
69
- given: ['User is authenticated', 'Organization exists'],
70
- when: ['User submits valid tool configuration'],
71
- then: ['New tool is created', 'ToolCreated event is emitted'],
72
- },
73
- {
74
- key: 'create-tool-slug-conflict',
75
- given: ['Tool with same slug exists'],
76
- when: ['User submits tool with duplicate slug'],
77
- then: ['SLUG_EXISTS error is returned'],
78
- },
79
- ],
80
- examples: [
81
- {
82
- key: 'create-api-tool',
83
- input: {
84
- name: 'Weather API',
85
- slug: 'weather-api',
86
- category: 'api',
87
- description: 'Fetches weather data',
88
- },
89
- output: {
90
- id: 'tool-123',
91
- name: 'Weather API',
92
- slug: 'weather-api',
93
- status: 'draft',
94
- },
95
- },
96
- ],
97
- },
20
+ meta: {
21
+ key: 'agent.tool.create',
22
+ version: '1.0.0',
23
+ stability: 'stable',
24
+ owners: [...OWNERS],
25
+ tags: ['tool', 'create'],
26
+ description: 'Creates a new AI tool definition.',
27
+ goal: 'Allow users to define new tools that agents can use.',
28
+ context: 'Called from the tool builder UI when creating a new tool.',
29
+ },
30
+ io: {
31
+ input: CreateToolInputModel,
32
+ output: defineSchemaModel({
33
+ name: 'CreateToolOutput',
34
+ fields: {
35
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
36
+ name: { type: ScalarTypeEnum.NonEmptyString(), isOptional: false },
37
+ slug: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
38
+ status: { type: ToolStatusEnum, isOptional: false },
39
+ },
40
+ }),
41
+ errors: {
42
+ SLUG_EXISTS: {
43
+ description: 'A tool with this slug already exists in the organization',
44
+ http: 409,
45
+ gqlCode: 'SLUG_EXISTS',
46
+ when: 'Slug is already taken',
47
+ },
48
+ },
49
+ },
50
+ policy: { auth: 'user' },
51
+ sideEffects: {
52
+ emits: [
53
+ {
54
+ key: 'tool.created',
55
+ version: '1.0.0',
56
+ stability: 'stable',
57
+ owners: [...OWNERS],
58
+ tags: ['tool', 'created'],
59
+ when: 'Tool is successfully created',
60
+ payload: ToolSummaryModel,
61
+ },
62
+ ],
63
+ audit: ['tool.created'],
64
+ },
65
+ acceptance: {
66
+ scenarios: [
67
+ {
68
+ key: 'create-tool-happy-path',
69
+ given: ['User is authenticated', 'Organization exists'],
70
+ when: ['User submits valid tool configuration'],
71
+ then: ['New tool is created', 'ToolCreated event is emitted'],
72
+ },
73
+ {
74
+ key: 'create-tool-slug-conflict',
75
+ given: ['Tool with same slug exists'],
76
+ when: ['User submits tool with duplicate slug'],
77
+ then: ['SLUG_EXISTS error is returned'],
78
+ },
79
+ ],
80
+ examples: [
81
+ {
82
+ key: 'create-api-tool',
83
+ input: {
84
+ name: 'Weather API',
85
+ slug: 'weather-api',
86
+ category: 'api',
87
+ description: 'Fetches weather data',
88
+ },
89
+ output: {
90
+ id: 'tool-123',
91
+ name: 'Weather API',
92
+ slug: 'weather-api',
93
+ status: 'draft',
94
+ },
95
+ },
96
+ ],
97
+ },
98
98
  });
99
99
 
100
100
  /**
101
101
  * UpdateToolCommand - Updates an existing tool.
102
102
  */
103
103
  export const UpdateToolCommand = defineCommand({
104
- meta: {
105
- key: 'agent.tool.update',
106
- version: '1.0.0',
107
- stability: 'stable',
108
- owners: [...OWNERS],
109
- tags: ['tool', 'update'],
110
- description: 'Updates an existing AI tool definition.',
111
- goal: 'Allow users to modify tool settings and configuration.',
112
- context: 'Called from the tool settings UI.',
113
- },
114
- io: {
115
- input: UpdateToolInputModel,
116
- output: defineSchemaModel({
117
- name: 'UpdateToolOutput',
118
- fields: {
119
- id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
120
- name: { type: ScalarTypeEnum.NonEmptyString(), isOptional: false },
121
- status: { type: ToolStatusEnum, isOptional: false },
122
- updatedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
123
- },
124
- }),
125
- errors: {
126
- TOOL_NOT_FOUND: {
127
- description: 'The specified tool does not exist',
128
- http: 404,
129
- gqlCode: 'TOOL_NOT_FOUND',
130
- when: 'Tool ID is invalid',
131
- },
132
- },
133
- },
134
- policy: { auth: 'user' },
135
- sideEffects: {
136
- emits: [
137
- {
138
- key: 'tool.updated',
139
- version: '1.0.0',
140
- stability: 'stable',
141
- owners: [...OWNERS],
142
- tags: ['tool', 'updated'],
143
- when: 'Tool is updated',
144
- payload: ToolSummaryModel,
145
- },
146
- ],
147
- audit: ['tool.updated'],
148
- },
149
- acceptance: {
150
- scenarios: [
151
- {
152
- key: 'update-tool-happy-path',
153
- given: ['Tool exists', 'User owns the tool'],
154
- when: ['User submits updated configuration'],
155
- then: ['Tool is updated', 'ToolUpdated event is emitted'],
156
- },
157
- ],
158
- examples: [
159
- {
160
- key: 'update-description',
161
- input: { toolId: 'tool-123', description: 'Updated weather API tool' },
162
- output: {
163
- id: 'tool-123',
164
- name: 'Weather API',
165
- status: 'draft',
166
- updatedAt: '2025-01-01T00:00:00Z',
167
- },
168
- },
169
- ],
170
- },
104
+ meta: {
105
+ key: 'agent.tool.update',
106
+ version: '1.0.0',
107
+ stability: 'stable',
108
+ owners: [...OWNERS],
109
+ tags: ['tool', 'update'],
110
+ description: 'Updates an existing AI tool definition.',
111
+ goal: 'Allow users to modify tool settings and configuration.',
112
+ context: 'Called from the tool settings UI.',
113
+ },
114
+ io: {
115
+ input: UpdateToolInputModel,
116
+ output: defineSchemaModel({
117
+ name: 'UpdateToolOutput',
118
+ fields: {
119
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
120
+ name: { type: ScalarTypeEnum.NonEmptyString(), isOptional: false },
121
+ status: { type: ToolStatusEnum, isOptional: false },
122
+ updatedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
123
+ },
124
+ }),
125
+ errors: {
126
+ TOOL_NOT_FOUND: {
127
+ description: 'The specified tool does not exist',
128
+ http: 404,
129
+ gqlCode: 'TOOL_NOT_FOUND',
130
+ when: 'Tool ID is invalid',
131
+ },
132
+ },
133
+ },
134
+ policy: { auth: 'user' },
135
+ sideEffects: {
136
+ emits: [
137
+ {
138
+ key: 'tool.updated',
139
+ version: '1.0.0',
140
+ stability: 'stable',
141
+ owners: [...OWNERS],
142
+ tags: ['tool', 'updated'],
143
+ when: 'Tool is updated',
144
+ payload: ToolSummaryModel,
145
+ },
146
+ ],
147
+ audit: ['tool.updated'],
148
+ },
149
+ acceptance: {
150
+ scenarios: [
151
+ {
152
+ key: 'update-tool-happy-path',
153
+ given: ['Tool exists', 'User owns the tool'],
154
+ when: ['User submits updated configuration'],
155
+ then: ['Tool is updated', 'ToolUpdated event is emitted'],
156
+ },
157
+ ],
158
+ examples: [
159
+ {
160
+ key: 'update-description',
161
+ input: { toolId: 'tool-123', description: 'Updated weather API tool' },
162
+ output: {
163
+ id: 'tool-123',
164
+ name: 'Weather API',
165
+ status: 'draft',
166
+ updatedAt: '2025-01-01T00:00:00Z',
167
+ },
168
+ },
169
+ ],
170
+ },
171
171
  });
172
172
 
173
173
  /**
174
174
  * GetToolQuery - Retrieves a tool by ID.
175
175
  */
176
176
  export const GetToolQuery = defineQuery({
177
- meta: {
178
- key: 'agent.tool.get',
179
- version: '1.0.0',
180
- stability: 'stable',
181
- owners: [...OWNERS],
182
- tags: ['tool', 'get'],
183
- description: 'Retrieves a tool by its ID.',
184
- goal: 'View detailed tool configuration.',
185
- context: 'Called when viewing tool details or editing.',
186
- },
187
- io: {
188
- input: defineSchemaModel({
189
- name: 'GetToolInput',
190
- fields: {
191
- toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
192
- },
193
- }),
194
- output: ToolModel,
195
- errors: {
196
- TOOL_NOT_FOUND: {
197
- description: 'The specified tool does not exist',
198
- http: 404,
199
- gqlCode: 'TOOL_NOT_FOUND',
200
- when: 'Tool ID is invalid',
201
- },
202
- },
203
- },
204
- policy: { auth: 'user' },
205
- acceptance: {
206
- scenarios: [
207
- {
208
- key: 'get-tool-happy-path',
209
- given: ['Tool exists'],
210
- when: ['User requests tool by ID'],
211
- then: ['Tool details are returned'],
212
- },
213
- ],
214
- examples: [
215
- {
216
- key: 'get-basic',
217
- input: { toolId: 'tool-123' },
218
- output: {
219
- id: 'tool-123',
220
- name: 'Weather API',
221
- status: 'active',
222
- category: 'api',
223
- },
224
- },
225
- ],
226
- },
177
+ meta: {
178
+ key: 'agent.tool.get',
179
+ version: '1.0.0',
180
+ stability: 'stable',
181
+ owners: [...OWNERS],
182
+ tags: ['tool', 'get'],
183
+ description: 'Retrieves a tool by its ID.',
184
+ goal: 'View detailed tool configuration.',
185
+ context: 'Called when viewing tool details or editing.',
186
+ },
187
+ io: {
188
+ input: defineSchemaModel({
189
+ name: 'GetToolInput',
190
+ fields: {
191
+ toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
192
+ },
193
+ }),
194
+ output: ToolModel,
195
+ errors: {
196
+ TOOL_NOT_FOUND: {
197
+ description: 'The specified tool does not exist',
198
+ http: 404,
199
+ gqlCode: 'TOOL_NOT_FOUND',
200
+ when: 'Tool ID is invalid',
201
+ },
202
+ },
203
+ },
204
+ policy: { auth: 'user' },
205
+ acceptance: {
206
+ scenarios: [
207
+ {
208
+ key: 'get-tool-happy-path',
209
+ given: ['Tool exists'],
210
+ when: ['User requests tool by ID'],
211
+ then: ['Tool details are returned'],
212
+ },
213
+ ],
214
+ examples: [
215
+ {
216
+ key: 'get-basic',
217
+ input: { toolId: 'tool-123' },
218
+ output: {
219
+ id: 'tool-123',
220
+ name: 'Weather API',
221
+ status: 'active',
222
+ category: 'api',
223
+ },
224
+ },
225
+ ],
226
+ },
227
227
  });
228
228
 
229
229
  /**
230
230
  * ListToolsQuery - Lists tools for an organization.
231
231
  */
232
232
  export const ListToolsQuery = defineQuery({
233
- meta: {
234
- key: 'agent.tool.list',
235
- version: '1.0.0',
236
- stability: 'stable',
237
- owners: [...OWNERS],
238
- tags: ['tool', 'list'],
239
- description: 'Lists tools for an organization with optional filtering.',
240
- goal: 'Browse and search available tools.',
241
- context: 'Tool list/dashboard view.',
242
- },
243
- io: {
244
- input: defineSchemaModel({
245
- name: 'ListToolsInput',
246
- fields: {
247
- organizationId: {
248
- type: ScalarTypeEnum.String_unsecure(),
249
- isOptional: false,
250
- },
251
- category: { type: ToolCategoryEnum, isOptional: true },
252
- status: { type: ToolStatusEnum, isOptional: true },
253
- search: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
254
- limit: {
255
- type: ScalarTypeEnum.Int_unsecure(),
256
- isOptional: true,
257
- defaultValue: 20,
258
- },
259
- offset: {
260
- type: ScalarTypeEnum.Int_unsecure(),
261
- isOptional: true,
262
- defaultValue: 0,
263
- },
264
- },
265
- }),
266
- output: defineSchemaModel({
267
- name: 'ListToolsOutput',
268
- fields: {
269
- items: { type: ToolSummaryModel, isArray: true, isOptional: false },
270
- total: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
271
- hasMore: { type: ScalarTypeEnum.Boolean(), isOptional: false },
272
- },
273
- }),
274
- },
275
- policy: { auth: 'user' },
276
- acceptance: {
277
- scenarios: [
278
- {
279
- key: 'list-tools-happy-path',
280
- given: ['Organization has tools'],
281
- when: ['User lists tools'],
282
- then: ['Paginated list of tools is returned'],
283
- },
284
- ],
285
- examples: [
286
- {
287
- key: 'list-by-category',
288
- input: { organizationId: 'org-123', category: 'api', limit: 10 },
289
- output: { items: [], total: 0, hasMore: false },
290
- },
291
- ],
292
- },
233
+ meta: {
234
+ key: 'agent.tool.list',
235
+ version: '1.0.0',
236
+ stability: 'stable',
237
+ owners: [...OWNERS],
238
+ tags: ['tool', 'list'],
239
+ description: 'Lists tools for an organization with optional filtering.',
240
+ goal: 'Browse and search available tools.',
241
+ context: 'Tool list/dashboard view.',
242
+ },
243
+ io: {
244
+ input: defineSchemaModel({
245
+ name: 'ListToolsInput',
246
+ fields: {
247
+ organizationId: {
248
+ type: ScalarTypeEnum.String_unsecure(),
249
+ isOptional: false,
250
+ },
251
+ category: { type: ToolCategoryEnum, isOptional: true },
252
+ status: { type: ToolStatusEnum, isOptional: true },
253
+ search: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
254
+ limit: {
255
+ type: ScalarTypeEnum.Int_unsecure(),
256
+ isOptional: true,
257
+ defaultValue: 20,
258
+ },
259
+ offset: {
260
+ type: ScalarTypeEnum.Int_unsecure(),
261
+ isOptional: true,
262
+ defaultValue: 0,
263
+ },
264
+ },
265
+ }),
266
+ output: defineSchemaModel({
267
+ name: 'ListToolsOutput',
268
+ fields: {
269
+ items: { type: ToolSummaryModel, isArray: true, isOptional: false },
270
+ total: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
271
+ hasMore: { type: ScalarTypeEnum.Boolean(), isOptional: false },
272
+ },
273
+ }),
274
+ },
275
+ policy: { auth: 'user' },
276
+ acceptance: {
277
+ scenarios: [
278
+ {
279
+ key: 'list-tools-happy-path',
280
+ given: ['Organization has tools'],
281
+ when: ['User lists tools'],
282
+ then: ['Paginated list of tools is returned'],
283
+ },
284
+ ],
285
+ examples: [
286
+ {
287
+ key: 'list-by-category',
288
+ input: { organizationId: 'org-123', category: 'api', limit: 10 },
289
+ output: { items: [], total: 0, hasMore: false },
290
+ },
291
+ ],
292
+ },
293
293
  });
294
294
 
295
295
  /**
296
296
  * TestToolCommand - Tests a tool with sample input.
297
297
  */
298
298
  export const TestToolCommand = defineCommand({
299
- meta: {
300
- key: 'agent.tool.test',
301
- version: '1.0.0',
302
- stability: 'stable',
303
- owners: [...OWNERS],
304
- tags: ['tool', 'test'],
305
- description: 'Tests a tool with sample input to verify it works correctly.',
306
- goal: 'Validate tool configuration before deployment.',
307
- context: 'Tool builder UI - test panel.',
308
- },
309
- io: {
310
- input: defineSchemaModel({
311
- name: 'TestToolInput',
312
- fields: {
313
- toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
314
- testInput: { type: ScalarTypeEnum.JSONObject(), isOptional: false },
315
- },
316
- }),
317
- output: defineSchemaModel({
318
- name: 'TestToolOutput',
319
- fields: {
320
- success: { type: ScalarTypeEnum.Boolean(), isOptional: false },
321
- output: { type: ScalarTypeEnum.JSONObject(), isOptional: true },
322
- error: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
323
- durationMs: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
324
- },
325
- }),
326
- errors: {
327
- TOOL_NOT_FOUND: {
328
- description: 'The specified tool does not exist',
329
- http: 404,
330
- gqlCode: 'TOOL_NOT_FOUND',
331
- when: 'Tool ID is invalid',
332
- },
333
- TOOL_EXECUTION_ERROR: {
334
- description: 'Tool execution failed',
335
- http: 500,
336
- gqlCode: 'TOOL_EXECUTION_ERROR',
337
- when: 'Tool returns an error',
338
- },
339
- },
340
- },
341
- policy: { auth: 'user' },
342
- sideEffects: { audit: ['tool.tested'] },
343
- acceptance: {
344
- scenarios: [
345
- {
346
- key: 'test-tool-success',
347
- given: ['Tool exists', 'Tool is configured correctly'],
348
- when: ['User runs test with valid input'],
349
- then: ['Tool executes successfully', 'Output is returned'],
350
- },
351
- {
352
- key: 'test-tool-failure',
353
- given: ['Tool exists', 'Tool has configuration error'],
354
- when: ['User runs test'],
355
- then: ['TOOL_EXECUTION_ERROR is returned'],
356
- },
357
- ],
358
- examples: [
359
- {
360
- key: 'test-weather-api',
361
- input: { toolId: 'tool-123', testInput: { city: 'Paris' } },
362
- output: { success: true, output: { temperature: 22 }, durationMs: 150 },
363
- },
364
- ],
365
- },
299
+ meta: {
300
+ key: 'agent.tool.test',
301
+ version: '1.0.0',
302
+ stability: 'stable',
303
+ owners: [...OWNERS],
304
+ tags: ['tool', 'test'],
305
+ description: 'Tests a tool with sample input to verify it works correctly.',
306
+ goal: 'Validate tool configuration before deployment.',
307
+ context: 'Tool builder UI - test panel.',
308
+ },
309
+ io: {
310
+ input: defineSchemaModel({
311
+ name: 'TestToolInput',
312
+ fields: {
313
+ toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
314
+ testInput: { type: ScalarTypeEnum.JSONObject(), isOptional: false },
315
+ },
316
+ }),
317
+ output: defineSchemaModel({
318
+ name: 'TestToolOutput',
319
+ fields: {
320
+ success: { type: ScalarTypeEnum.Boolean(), isOptional: false },
321
+ output: { type: ScalarTypeEnum.JSONObject(), isOptional: true },
322
+ error: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
323
+ durationMs: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
324
+ },
325
+ }),
326
+ errors: {
327
+ TOOL_NOT_FOUND: {
328
+ description: 'The specified tool does not exist',
329
+ http: 404,
330
+ gqlCode: 'TOOL_NOT_FOUND',
331
+ when: 'Tool ID is invalid',
332
+ },
333
+ TOOL_EXECUTION_ERROR: {
334
+ description: 'Tool execution failed',
335
+ http: 500,
336
+ gqlCode: 'TOOL_EXECUTION_ERROR',
337
+ when: 'Tool returns an error',
338
+ },
339
+ },
340
+ },
341
+ policy: { auth: 'user' },
342
+ sideEffects: { audit: ['tool.tested'] },
343
+ acceptance: {
344
+ scenarios: [
345
+ {
346
+ key: 'test-tool-success',
347
+ given: ['Tool exists', 'Tool is configured correctly'],
348
+ when: ['User runs test with valid input'],
349
+ then: ['Tool executes successfully', 'Output is returned'],
350
+ },
351
+ {
352
+ key: 'test-tool-failure',
353
+ given: ['Tool exists', 'Tool has configuration error'],
354
+ when: ['User runs test'],
355
+ then: ['TOOL_EXECUTION_ERROR is returned'],
356
+ },
357
+ ],
358
+ examples: [
359
+ {
360
+ key: 'test-weather-api',
361
+ input: { toolId: 'tool-123', testInput: { city: 'Paris' } },
362
+ output: { success: true, output: { temperature: 22 }, durationMs: 150 },
363
+ },
364
+ ],
365
+ },
366
366
  });