@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,5 +1,5 @@
1
1
  import { defineEvent } from '@contractspec/lib.contracts-spec';
2
- import { ScalarTypeEnum, defineSchemaModel } from '@contractspec/lib.schema';
2
+ import { defineSchemaModel, ScalarTypeEnum } from '@contractspec/lib.schema';
3
3
 
4
4
  const OWNERS = ['@agent-console-team'] as const;
5
5
 
@@ -7,136 +7,136 @@ const OWNERS = ['@agent-console-team'] as const;
7
7
  * Payload for agent created event.
8
8
  */
9
9
  const AgentCreatedPayload = defineSchemaModel({
10
- name: 'AgentCreatedPayload',
11
- description: 'Payload for agent created event',
12
- fields: {
13
- id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
14
- organizationId: {
15
- type: ScalarTypeEnum.String_unsecure(),
16
- isOptional: false,
17
- },
18
- name: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
19
- slug: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
20
- modelProvider: {
21
- type: ScalarTypeEnum.String_unsecure(),
22
- isOptional: false,
23
- },
24
- modelName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
25
- toolCount: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
26
- createdById: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
27
- createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
28
- },
10
+ name: 'AgentCreatedPayload',
11
+ description: 'Payload for agent created event',
12
+ fields: {
13
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
14
+ organizationId: {
15
+ type: ScalarTypeEnum.String_unsecure(),
16
+ isOptional: false,
17
+ },
18
+ name: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
19
+ slug: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
20
+ modelProvider: {
21
+ type: ScalarTypeEnum.String_unsecure(),
22
+ isOptional: false,
23
+ },
24
+ modelName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
25
+ toolCount: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
26
+ createdById: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
27
+ createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
28
+ },
29
29
  });
30
30
 
31
31
  /**
32
32
  * AgentCreatedEvent - A new agent was created.
33
33
  */
34
34
  export const AgentCreatedEvent = defineEvent({
35
- meta: {
36
- key: 'agent-console.agent.created',
37
- version: '1.0.0',
38
- description: 'A new AI agent was configured.',
39
- stability: 'stable',
40
- owners: [...OWNERS],
41
- tags: ['agent', 'created'],
42
- },
43
- payload: AgentCreatedPayload,
35
+ meta: {
36
+ key: 'agent-console.agent.created',
37
+ version: '1.0.0',
38
+ description: 'A new AI agent was configured.',
39
+ stability: 'stable',
40
+ owners: [...OWNERS],
41
+ tags: ['agent', 'created'],
42
+ },
43
+ payload: AgentCreatedPayload,
44
44
  });
45
45
 
46
46
  /**
47
47
  * Payload for agent updated event.
48
48
  */
49
49
  const AgentUpdatedPayload = defineSchemaModel({
50
- name: 'AgentUpdatedPayload',
51
- description: 'Payload for agent updated event',
52
- fields: {
53
- id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
54
- organizationId: {
55
- type: ScalarTypeEnum.String_unsecure(),
56
- isOptional: false,
57
- },
58
- name: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
59
- status: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
60
- updatedFields: {
61
- type: ScalarTypeEnum.String_unsecure(),
62
- isArray: true,
63
- isOptional: false,
64
- },
65
- updatedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
66
- },
50
+ name: 'AgentUpdatedPayload',
51
+ description: 'Payload for agent updated event',
52
+ fields: {
53
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
54
+ organizationId: {
55
+ type: ScalarTypeEnum.String_unsecure(),
56
+ isOptional: false,
57
+ },
58
+ name: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
59
+ status: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
60
+ updatedFields: {
61
+ type: ScalarTypeEnum.String_unsecure(),
62
+ isArray: true,
63
+ isOptional: false,
64
+ },
65
+ updatedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
66
+ },
67
67
  });
68
68
 
69
69
  /**
70
70
  * AgentUpdatedEvent - An agent was updated.
71
71
  */
72
72
  export const AgentUpdatedEvent = defineEvent({
73
- meta: {
74
- key: 'agent-console.agent.updated',
75
- version: '1.0.0',
76
- description: 'An AI agent configuration was updated.',
77
- stability: 'stable',
78
- owners: [...OWNERS],
79
- tags: ['agent', 'updated'],
80
- },
81
- payload: AgentUpdatedPayload,
73
+ meta: {
74
+ key: 'agent-console.agent.updated',
75
+ version: '1.0.0',
76
+ description: 'An AI agent configuration was updated.',
77
+ stability: 'stable',
78
+ owners: [...OWNERS],
79
+ tags: ['agent', 'updated'],
80
+ },
81
+ payload: AgentUpdatedPayload,
82
82
  });
83
83
 
84
84
  /**
85
85
  * Payload for agent tool assigned event.
86
86
  */
87
87
  const AgentToolAssignedPayload = defineSchemaModel({
88
- name: 'AgentToolAssignedPayload',
89
- description: 'Payload for agent tool assigned event',
90
- fields: {
91
- agentId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
92
- toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
93
- agentName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
94
- toolName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
95
- assignedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
96
- },
88
+ name: 'AgentToolAssignedPayload',
89
+ description: 'Payload for agent tool assigned event',
90
+ fields: {
91
+ agentId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
92
+ toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
93
+ agentName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
94
+ toolName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
95
+ assignedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
96
+ },
97
97
  });
98
98
 
99
99
  /**
100
100
  * AgentToolAssignedEvent - A tool was assigned to an agent.
101
101
  */
102
102
  export const AgentToolAssignedEvent = defineEvent({
103
- meta: {
104
- key: 'agent-console.agent.toolAssigned',
105
- version: '1.0.0',
106
- description: 'A tool was assigned to an agent.',
107
- stability: 'stable',
108
- owners: [...OWNERS],
109
- tags: ['agent', 'tool', 'assigned'],
110
- },
111
- payload: AgentToolAssignedPayload,
103
+ meta: {
104
+ key: 'agent-console.agent.toolAssigned',
105
+ version: '1.0.0',
106
+ description: 'A tool was assigned to an agent.',
107
+ stability: 'stable',
108
+ owners: [...OWNERS],
109
+ tags: ['agent', 'tool', 'assigned'],
110
+ },
111
+ payload: AgentToolAssignedPayload,
112
112
  });
113
113
 
114
114
  /**
115
115
  * Payload for agent tool removed event.
116
116
  */
117
117
  const AgentToolRemovedPayload = defineSchemaModel({
118
- name: 'AgentToolRemovedPayload',
119
- description: 'Payload for agent tool removed event',
120
- fields: {
121
- agentId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
122
- toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
123
- agentName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
124
- toolName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
125
- removedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
126
- },
118
+ name: 'AgentToolRemovedPayload',
119
+ description: 'Payload for agent tool removed event',
120
+ fields: {
121
+ agentId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
122
+ toolId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
123
+ agentName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
124
+ toolName: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
125
+ removedAt: { type: ScalarTypeEnum.DateTime(), isOptional: false },
126
+ },
127
127
  });
128
128
 
129
129
  /**
130
130
  * AgentToolRemovedEvent - A tool was removed from an agent.
131
131
  */
132
132
  export const AgentToolRemovedEvent = defineEvent({
133
- meta: {
134
- key: 'agent-console.agent.toolRemoved',
135
- version: '1.0.0',
136
- description: 'A tool was removed from an agent.',
137
- stability: 'stable',
138
- owners: [...OWNERS],
139
- tags: ['agent', 'tool', 'removed'],
140
- },
141
- payload: AgentToolRemovedPayload,
133
+ meta: {
134
+ key: 'agent-console.agent.toolRemoved',
135
+ version: '1.0.0',
136
+ description: 'A tool was removed from an agent.',
137
+ stability: 'stable',
138
+ owners: [...OWNERS],
139
+ tags: ['agent', 'tool', 'removed'],
140
+ },
141
+ payload: AgentToolRemovedPayload,
142
142
  });
@@ -1,178 +1,195 @@
1
1
  /**
2
2
  * Mock handlers for Agent contracts.
3
3
  */
4
+
4
5
  import { MOCK_AGENTS } from '../shared/mock-agents';
5
6
  import { MOCK_TOOLS } from '../shared/mock-tools';
7
+ import {
8
+ CreateAgentCommand,
9
+ GetAgentQuery,
10
+ ListAgentsQuery,
11
+ UpdateAgentCommand,
12
+ } from './agent.operation';
13
+
14
+ const AGENT_HANDLER_CONTRACTS = [
15
+ CreateAgentCommand,
16
+ GetAgentQuery,
17
+ ListAgentsQuery,
18
+ UpdateAgentCommand,
19
+ ] as const;
20
+ void AGENT_HANDLER_CONTRACTS;
21
+
22
+ let nextMockAgentId = MOCK_AGENTS.length + 1;
6
23
 
7
24
  export interface ListAgentsInput {
8
- organizationId: string;
9
- status?: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
10
- modelProvider?: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
11
- search?: string;
12
- limit?: number;
13
- offset?: number;
25
+ organizationId: string;
26
+ status?: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
27
+ modelProvider?: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
28
+ search?: string;
29
+ limit?: number;
30
+ offset?: number;
14
31
  }
15
32
 
16
33
  export interface AgentSummary {
17
- id: string;
18
- name: string;
19
- slug: string;
20
- description?: string;
21
- status: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
22
- modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
23
- modelName: string;
24
- version: string;
25
- createdAt: Date;
34
+ id: string;
35
+ name: string;
36
+ slug: string;
37
+ description?: string;
38
+ status: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
39
+ modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
40
+ modelName: string;
41
+ version: string;
42
+ createdAt: Date;
26
43
  }
27
44
 
28
45
  export interface ListAgentsOutput {
29
- items: AgentSummary[];
30
- total: number;
31
- hasMore: boolean;
46
+ items: AgentSummary[];
47
+ total: number;
48
+ hasMore: boolean;
32
49
  }
33
50
 
34
51
  export interface GetAgentInput {
35
- agentId: string;
36
- includeTools?: boolean;
52
+ agentId: string;
53
+ includeTools?: boolean;
37
54
  }
38
55
 
39
56
  export interface AgentToolRef {
40
- id: string;
41
- name: string;
42
- slug: string;
43
- description: string;
44
- category: string;
57
+ id: string;
58
+ name: string;
59
+ slug: string;
60
+ description: string;
61
+ category: string;
45
62
  }
46
63
 
47
64
  export interface AgentWithTools {
48
- id: string;
49
- organizationId: string;
50
- name: string;
51
- slug: string;
52
- description?: string;
53
- status: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
54
- modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
55
- modelName: string;
56
- modelConfig?: Record<string, unknown>;
57
- systemPrompt: string;
58
- userPromptTemplate?: string;
59
- toolIds?: string[];
60
- toolChoice: 'auto' | 'required' | 'none';
61
- maxIterations: number;
62
- maxTokensPerRun?: number;
63
- timeoutMs: number;
64
- version: string;
65
- tags?: string[];
66
- createdAt: Date;
67
- updatedAt: Date;
68
- tools?: AgentToolRef[];
65
+ id: string;
66
+ organizationId: string;
67
+ name: string;
68
+ slug: string;
69
+ description?: string;
70
+ status: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
71
+ modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
72
+ modelName: string;
73
+ modelConfig?: Record<string, unknown>;
74
+ systemPrompt: string;
75
+ userPromptTemplate?: string;
76
+ toolIds?: string[];
77
+ toolChoice: 'auto' | 'required' | 'none';
78
+ maxIterations: number;
79
+ maxTokensPerRun?: number;
80
+ timeoutMs: number;
81
+ version: string;
82
+ tags?: string[];
83
+ createdAt: Date;
84
+ updatedAt: Date;
85
+ tools?: AgentToolRef[];
69
86
  }
70
87
 
71
88
  /**
72
89
  * Mock handler for ListAgentsQuery.
73
90
  */
74
91
  export async function mockListAgentsHandler(
75
- input: ListAgentsInput
92
+ input: ListAgentsInput
76
93
  ): Promise<ListAgentsOutput> {
77
- const {
78
- organizationId,
79
- status,
80
- modelProvider,
81
- search,
82
- limit = 20,
83
- offset = 0,
84
- } = input;
85
-
86
- let filtered = MOCK_AGENTS.filter((a) => a.organizationId === organizationId);
87
- if (status) filtered = filtered.filter((a) => a.status === status);
88
- if (modelProvider)
89
- filtered = filtered.filter((a) => a.modelProvider === modelProvider);
90
- if (search) {
91
- const q = search.toLowerCase();
92
- filtered = filtered.filter(
93
- (a) =>
94
- a.name.toLowerCase().includes(q) ||
95
- a.description?.toLowerCase().includes(q) ||
96
- a.tags?.some((t) => t.toLowerCase().includes(q))
97
- );
98
- }
99
-
100
- const total = filtered.length;
101
- const items = filtered.slice(offset, offset + limit).map((a) => ({
102
- id: a.id,
103
- name: a.name,
104
- slug: a.slug,
105
- description: a.description,
106
- status: a.status,
107
- modelProvider: a.modelProvider,
108
- modelName: a.modelName,
109
- version: a.version,
110
- createdAt: a.createdAt,
111
- }));
112
-
113
- return { items, total, hasMore: offset + limit < total };
94
+ const {
95
+ organizationId,
96
+ status,
97
+ modelProvider,
98
+ search,
99
+ limit = 20,
100
+ offset = 0,
101
+ } = input;
102
+
103
+ let filtered = MOCK_AGENTS.filter((a) => a.organizationId === organizationId);
104
+ if (status) filtered = filtered.filter((a) => a.status === status);
105
+ if (modelProvider)
106
+ filtered = filtered.filter((a) => a.modelProvider === modelProvider);
107
+ if (search) {
108
+ const q = search.toLowerCase();
109
+ filtered = filtered.filter(
110
+ (a) =>
111
+ a.name.toLowerCase().includes(q) ||
112
+ a.description?.toLowerCase().includes(q) ||
113
+ a.tags?.some((t) => t.toLowerCase().includes(q))
114
+ );
115
+ }
116
+
117
+ const total = filtered.length;
118
+ const items = filtered.slice(offset, offset + limit).map((a) => ({
119
+ id: a.id,
120
+ name: a.name,
121
+ slug: a.slug,
122
+ description: a.description,
123
+ status: a.status,
124
+ modelProvider: a.modelProvider,
125
+ modelName: a.modelName,
126
+ version: a.version,
127
+ createdAt: a.createdAt,
128
+ }));
129
+
130
+ return { items, total, hasMore: offset + limit < total };
114
131
  }
115
132
 
116
133
  /**
117
134
  * Mock handler for GetAgentQuery.
118
135
  */
119
136
  export async function mockGetAgentHandler(
120
- input: GetAgentInput
137
+ input: GetAgentInput
121
138
  ): Promise<AgentWithTools> {
122
- const agent = MOCK_AGENTS.find((a) => a.id === input.agentId);
123
- if (!agent) throw new Error('AGENT_NOT_FOUND');
124
-
125
- const result: AgentWithTools = { ...agent, toolIds: ['tool-1', 'tool-2'] };
126
- if (input.includeTools) {
127
- result.tools = MOCK_TOOLS.slice(0, 2).map((t) => ({
128
- id: t.id,
129
- name: t.name,
130
- slug: t.slug,
131
- description: t.description,
132
- category: t.category,
133
- }));
134
- }
135
- return result;
139
+ const agent = MOCK_AGENTS.find((a) => a.id === input.agentId);
140
+ if (!agent) throw new Error('AGENT_NOT_FOUND');
141
+
142
+ const result: AgentWithTools = { ...agent, toolIds: ['tool-1', 'tool-2'] };
143
+ if (input.includeTools) {
144
+ result.tools = MOCK_TOOLS.slice(0, 2).map((t) => ({
145
+ id: t.id,
146
+ name: t.name,
147
+ slug: t.slug,
148
+ description: t.description,
149
+ category: t.category,
150
+ }));
151
+ }
152
+ return result;
136
153
  }
137
154
 
138
155
  /**
139
156
  * Mock handler for CreateAgentCommand.
140
157
  */
141
158
  export async function mockCreateAgentHandler(input: {
142
- organizationId: string;
143
- name: string;
144
- slug: string;
145
- description?: string;
146
- modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
147
- modelName: string;
148
- systemPrompt: string;
159
+ organizationId: string;
160
+ name: string;
161
+ slug: string;
162
+ description?: string;
163
+ modelProvider: 'OPENAI' | 'ANTHROPIC' | 'GOOGLE' | 'MISTRAL' | 'CUSTOM';
164
+ modelName: string;
165
+ systemPrompt: string;
149
166
  }) {
150
- const exists = MOCK_AGENTS.some(
151
- (a) => a.organizationId === input.organizationId && a.slug === input.slug
152
- );
153
- if (exists) throw new Error('SLUG_EXISTS');
154
- return {
155
- id: `agent-${Date.now()}`,
156
- name: input.name,
157
- slug: input.slug,
158
- status: 'DRAFT' as const,
159
- };
167
+ const exists = MOCK_AGENTS.some(
168
+ (a) => a.organizationId === input.organizationId && a.slug === input.slug
169
+ );
170
+ if (exists) throw new Error('SLUG_EXISTS');
171
+ return {
172
+ id: `agent-${nextMockAgentId++}`,
173
+ name: input.name,
174
+ slug: input.slug,
175
+ status: 'DRAFT' as const,
176
+ };
160
177
  }
161
178
 
162
179
  /**
163
180
  * Mock handler for UpdateAgentCommand.
164
181
  */
165
182
  export async function mockUpdateAgentHandler(input: {
166
- agentId: string;
167
- name?: string;
168
- status?: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
183
+ agentId: string;
184
+ name?: string;
185
+ status?: 'DRAFT' | 'ACTIVE' | 'PAUSED' | 'ARCHIVED';
169
186
  }) {
170
- const agent = MOCK_AGENTS.find((a) => a.id === input.agentId);
171
- if (!agent) throw new Error('AGENT_NOT_FOUND');
172
- return {
173
- id: agent.id,
174
- name: input.name ?? agent.name,
175
- status: input.status ?? agent.status,
176
- updatedAt: new Date(),
177
- };
187
+ const agent = MOCK_AGENTS.find((a) => a.id === input.agentId);
188
+ if (!agent) throw new Error('AGENT_NOT_FOUND');
189
+ return {
190
+ id: agent.id,
191
+ name: input.name ?? agent.name,
192
+ status: input.status ?? agent.status,
193
+ updatedAt: new Date(),
194
+ };
178
195
  }