flock-core 0.4.542__py3-none-any.whl → 0.5.0__py3-none-any.whl

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.

Potentially problematic release.


This version of flock-core might be problematic. Click here for more details.

Files changed (501) hide show
  1. flock/__init__.py +12 -217
  2. flock/agent.py +1079 -0
  3. flock/api/themes.py +71 -0
  4. flock/artifacts.py +86 -0
  5. flock/cli.py +147 -0
  6. flock/components.py +189 -0
  7. flock/dashboard/__init__.py +30 -0
  8. flock/dashboard/collector.py +559 -0
  9. flock/dashboard/events.py +188 -0
  10. flock/dashboard/graph_builder.py +563 -0
  11. flock/dashboard/launcher.py +235 -0
  12. flock/dashboard/models/graph.py +156 -0
  13. flock/dashboard/service.py +991 -0
  14. flock/dashboard/static_v2/assets/index-DFRnI_mt.js +111 -0
  15. flock/dashboard/static_v2/assets/index-fPLNdmp1.css +1 -0
  16. flock/dashboard/static_v2/index.html +13 -0
  17. flock/dashboard/websocket.py +246 -0
  18. flock/engines/__init__.py +6 -0
  19. flock/engines/dspy_engine.py +932 -0
  20. flock/examples.py +131 -0
  21. flock/frontend/README.md +778 -0
  22. flock/frontend/docs/DESIGN_SYSTEM.md +1980 -0
  23. flock/frontend/index.html +12 -0
  24. flock/frontend/package-lock.json +4337 -0
  25. flock/frontend/package.json +48 -0
  26. flock/frontend/src/App.tsx +139 -0
  27. flock/frontend/src/__tests__/integration/graph-snapshot.test.tsx +647 -0
  28. flock/frontend/src/__tests__/integration/indexeddb-persistence.test.tsx +699 -0
  29. flock/frontend/src/components/common/BuildInfo.tsx +39 -0
  30. flock/frontend/src/components/common/EmptyState.module.css +115 -0
  31. flock/frontend/src/components/common/EmptyState.tsx +128 -0
  32. flock/frontend/src/components/common/ErrorBoundary.module.css +169 -0
  33. flock/frontend/src/components/common/ErrorBoundary.tsx +118 -0
  34. flock/frontend/src/components/common/KeyboardShortcutsDialog.css +251 -0
  35. flock/frontend/src/components/common/KeyboardShortcutsDialog.tsx +151 -0
  36. flock/frontend/src/components/common/LoadingSpinner.module.css +97 -0
  37. flock/frontend/src/components/common/LoadingSpinner.tsx +29 -0
  38. flock/frontend/src/components/controls/PublishControl.css +547 -0
  39. flock/frontend/src/components/controls/PublishControl.test.tsx +543 -0
  40. flock/frontend/src/components/controls/PublishControl.tsx +432 -0
  41. flock/frontend/src/components/details/DetailWindowContainer.tsx +58 -0
  42. flock/frontend/src/components/details/LiveOutputTab.test.tsx +792 -0
  43. flock/frontend/src/components/details/LiveOutputTab.tsx +220 -0
  44. flock/frontend/src/components/details/MessageDetailWindow.tsx +439 -0
  45. flock/frontend/src/components/details/MessageHistoryTab.tsx +374 -0
  46. flock/frontend/src/components/details/NodeDetailWindow.test.tsx +501 -0
  47. flock/frontend/src/components/details/NodeDetailWindow.tsx +218 -0
  48. flock/frontend/src/components/details/RunStatusTab.tsx +348 -0
  49. flock/frontend/src/components/details/tabs.test.tsx +1015 -0
  50. flock/frontend/src/components/filters/ArtifactTypeFilter.tsx +21 -0
  51. flock/frontend/src/components/filters/CorrelationIDFilter.module.css +102 -0
  52. flock/frontend/src/components/filters/CorrelationIDFilter.test.tsx +197 -0
  53. flock/frontend/src/components/filters/CorrelationIDFilter.tsx +121 -0
  54. flock/frontend/src/components/filters/FilterFlyout.module.css +104 -0
  55. flock/frontend/src/components/filters/FilterFlyout.tsx +80 -0
  56. flock/frontend/src/components/filters/FilterPills.module.css +220 -0
  57. flock/frontend/src/components/filters/FilterPills.test.tsx +189 -0
  58. flock/frontend/src/components/filters/FilterPills.tsx +143 -0
  59. flock/frontend/src/components/filters/ProducerFilter.tsx +21 -0
  60. flock/frontend/src/components/filters/SavedFiltersControl.module.css +60 -0
  61. flock/frontend/src/components/filters/SavedFiltersControl.test.tsx +158 -0
  62. flock/frontend/src/components/filters/SavedFiltersControl.tsx +159 -0
  63. flock/frontend/src/components/filters/TagFilter.tsx +21 -0
  64. flock/frontend/src/components/filters/TimeRangeFilter.module.css +115 -0
  65. flock/frontend/src/components/filters/TimeRangeFilter.test.tsx +154 -0
  66. flock/frontend/src/components/filters/TimeRangeFilter.tsx +110 -0
  67. flock/frontend/src/components/filters/VisibilityFilter.tsx +21 -0
  68. flock/frontend/src/components/graph/AgentNode.test.tsx +77 -0
  69. flock/frontend/src/components/graph/AgentNode.tsx +324 -0
  70. flock/frontend/src/components/graph/GraphCanvas.tsx +613 -0
  71. flock/frontend/src/components/graph/MessageFlowEdge.tsx +128 -0
  72. flock/frontend/src/components/graph/MessageNode.test.tsx +64 -0
  73. flock/frontend/src/components/graph/MessageNode.tsx +129 -0
  74. flock/frontend/src/components/graph/MiniMap.tsx +47 -0
  75. flock/frontend/src/components/graph/TransformEdge.tsx +123 -0
  76. flock/frontend/src/components/layout/DashboardLayout.css +420 -0
  77. flock/frontend/src/components/layout/DashboardLayout.tsx +287 -0
  78. flock/frontend/src/components/layout/Header.module.css +88 -0
  79. flock/frontend/src/components/layout/Header.tsx +52 -0
  80. flock/frontend/src/components/modules/HistoricalArtifactsModule.module.css +288 -0
  81. flock/frontend/src/components/modules/HistoricalArtifactsModule.tsx +450 -0
  82. flock/frontend/src/components/modules/HistoricalArtifactsModuleWrapper.tsx +13 -0
  83. flock/frontend/src/components/modules/JsonAttributeRenderer.tsx +140 -0
  84. flock/frontend/src/components/modules/ModuleRegistry.test.ts +333 -0
  85. flock/frontend/src/components/modules/ModuleRegistry.ts +93 -0
  86. flock/frontend/src/components/modules/ModuleWindow.tsx +223 -0
  87. flock/frontend/src/components/modules/TraceModuleJaeger.tsx +1971 -0
  88. flock/frontend/src/components/modules/TraceModuleJaegerWrapper.tsx +13 -0
  89. flock/frontend/src/components/modules/registerModules.ts +29 -0
  90. flock/frontend/src/components/settings/AdvancedSettings.tsx +175 -0
  91. flock/frontend/src/components/settings/AppearanceSettings.tsx +185 -0
  92. flock/frontend/src/components/settings/GraphSettings.tsx +110 -0
  93. flock/frontend/src/components/settings/MultiSelect.tsx +235 -0
  94. flock/frontend/src/components/settings/SettingsPanel.css +327 -0
  95. flock/frontend/src/components/settings/SettingsPanel.tsx +131 -0
  96. flock/frontend/src/components/settings/ThemeSelector.tsx +298 -0
  97. flock/frontend/src/components/settings/TracingSettings.tsx +404 -0
  98. flock/frontend/src/hooks/useKeyboardShortcuts.ts +148 -0
  99. flock/frontend/src/hooks/useModulePersistence.test.ts +442 -0
  100. flock/frontend/src/hooks/useModulePersistence.ts +154 -0
  101. flock/frontend/src/hooks/useModules.ts +157 -0
  102. flock/frontend/src/hooks/usePersistence.ts +141 -0
  103. flock/frontend/src/main.tsx +13 -0
  104. flock/frontend/src/services/api.ts +337 -0
  105. flock/frontend/src/services/graphService.test.ts +330 -0
  106. flock/frontend/src/services/graphService.ts +75 -0
  107. flock/frontend/src/services/indexeddb.test.ts +793 -0
  108. flock/frontend/src/services/indexeddb.ts +848 -0
  109. flock/frontend/src/services/layout.test.ts +437 -0
  110. flock/frontend/src/services/layout.ts +357 -0
  111. flock/frontend/src/services/themeApplicator.ts +140 -0
  112. flock/frontend/src/services/themeService.ts +77 -0
  113. flock/frontend/src/services/websocket.ts +650 -0
  114. flock/frontend/src/store/filterStore.test.ts +250 -0
  115. flock/frontend/src/store/filterStore.ts +272 -0
  116. flock/frontend/src/store/graphStore.test.ts +570 -0
  117. flock/frontend/src/store/graphStore.ts +462 -0
  118. flock/frontend/src/store/moduleStore.test.ts +253 -0
  119. flock/frontend/src/store/moduleStore.ts +75 -0
  120. flock/frontend/src/store/settingsStore.ts +188 -0
  121. flock/frontend/src/store/streamStore.ts +68 -0
  122. flock/frontend/src/store/uiStore.test.ts +54 -0
  123. flock/frontend/src/store/uiStore.ts +122 -0
  124. flock/frontend/src/store/wsStore.ts +34 -0
  125. flock/frontend/src/styles/index.css +15 -0
  126. flock/frontend/src/styles/scrollbar.css +47 -0
  127. flock/frontend/src/styles/variables.css +488 -0
  128. flock/frontend/src/test/setup.ts +1 -0
  129. flock/frontend/src/types/filters.ts +47 -0
  130. flock/frontend/src/types/graph.ts +95 -0
  131. flock/frontend/src/types/modules.ts +10 -0
  132. flock/frontend/src/types/theme.ts +55 -0
  133. flock/frontend/src/utils/artifacts.ts +24 -0
  134. flock/frontend/src/utils/mockData.ts +98 -0
  135. flock/frontend/src/utils/performance.ts +16 -0
  136. flock/frontend/src/vite-env.d.ts +17 -0
  137. flock/frontend/tsconfig.json +27 -0
  138. flock/frontend/tsconfig.node.json +11 -0
  139. flock/frontend/vite.config.ts +25 -0
  140. flock/frontend/vitest.config.ts +11 -0
  141. flock/{core/util → helper}/cli_helper.py +9 -5
  142. flock/{core/logging → logging}/__init__.py +2 -3
  143. flock/logging/auto_trace.py +159 -0
  144. flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
  145. flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
  146. flock/{core/logging → logging}/formatters/themed_formatter.py +69 -107
  147. flock/{core/logging → logging}/logging.py +78 -61
  148. flock/{core/logging → logging}/telemetry.py +66 -26
  149. flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
  150. flock/logging/telemetry_exporter/duckdb_exporter.py +216 -0
  151. flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +13 -10
  152. flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
  153. flock/logging/trace_and_logged.py +304 -0
  154. flock/mcp/__init__.py +91 -0
  155. flock/{core/mcp/mcp_client.py → mcp/client.py} +131 -158
  156. flock/{core/mcp/mcp_config.py → mcp/config.py} +86 -132
  157. flock/mcp/manager.py +286 -0
  158. flock/mcp/servers/sse/__init__.py +1 -1
  159. flock/mcp/servers/sse/flock_sse_server.py +16 -58
  160. flock/mcp/servers/stdio/__init__.py +1 -1
  161. flock/mcp/servers/stdio/flock_stdio_server.py +13 -53
  162. flock/mcp/servers/streamable_http/flock_streamable_http_server.py +22 -67
  163. flock/mcp/servers/websockets/flock_websocket_server.py +12 -45
  164. flock/{core/mcp/flock_mcp_tool_base.py → mcp/tool.py} +24 -78
  165. flock/mcp/types/__init__.py +42 -0
  166. flock/{core/mcp → mcp}/types/callbacks.py +12 -15
  167. flock/{core/mcp → mcp}/types/factories.py +7 -6
  168. flock/{core/mcp → mcp}/types/handlers.py +13 -18
  169. flock/{core/mcp → mcp}/types/types.py +70 -74
  170. flock/{core/mcp → mcp}/util/helpers.py +3 -3
  171. flock/orchestrator.py +970 -0
  172. flock/registry.py +148 -0
  173. flock/runtime.py +262 -0
  174. flock/service.py +277 -0
  175. flock/store.py +1214 -0
  176. flock/subscription.py +111 -0
  177. flock/themes/andromeda.toml +1 -1
  178. flock/themes/apple-system-colors.toml +1 -1
  179. flock/themes/arcoiris.toml +1 -1
  180. flock/themes/atomonelight.toml +1 -1
  181. flock/themes/ayu copy.toml +1 -1
  182. flock/themes/ayu-light.toml +1 -1
  183. flock/themes/belafonte-day.toml +1 -1
  184. flock/themes/belafonte-night.toml +1 -1
  185. flock/themes/blulocodark.toml +1 -1
  186. flock/themes/breeze.toml +1 -1
  187. flock/themes/broadcast.toml +1 -1
  188. flock/themes/brogrammer.toml +1 -1
  189. flock/themes/builtin-dark.toml +1 -1
  190. flock/themes/builtin-pastel-dark.toml +1 -1
  191. flock/themes/catppuccin-latte.toml +1 -1
  192. flock/themes/catppuccin-macchiato.toml +1 -1
  193. flock/themes/catppuccin-mocha.toml +1 -1
  194. flock/themes/cga.toml +1 -1
  195. flock/themes/chalk.toml +1 -1
  196. flock/themes/ciapre.toml +1 -1
  197. flock/themes/coffee-theme.toml +1 -1
  198. flock/themes/cyberpunkscarletprotocol.toml +1 -1
  199. flock/themes/dark+.toml +1 -1
  200. flock/themes/darkermatrix.toml +1 -1
  201. flock/themes/darkmatrix.toml +2 -2
  202. flock/themes/darkside.toml +1 -1
  203. flock/themes/deep.toml +2 -2
  204. flock/themes/desert.toml +1 -1
  205. flock/themes/django.toml +1 -1
  206. flock/themes/djangosmooth.toml +1 -1
  207. flock/themes/doomone.toml +1 -1
  208. flock/themes/dotgov.toml +1 -1
  209. flock/themes/dracula+.toml +1 -1
  210. flock/themes/duckbones.toml +1 -1
  211. flock/themes/encom.toml +1 -1
  212. flock/themes/espresso.toml +1 -1
  213. flock/themes/everblush.toml +1 -1
  214. flock/themes/fairyfloss.toml +1 -1
  215. flock/themes/fideloper.toml +1 -1
  216. flock/themes/fishtank.toml +1 -1
  217. flock/themes/flexoki-light.toml +1 -1
  218. flock/themes/floraverse.toml +1 -1
  219. flock/themes/framer.toml +1 -1
  220. flock/themes/galizur.toml +1 -1
  221. flock/themes/github.toml +1 -1
  222. flock/themes/grass.toml +1 -1
  223. flock/themes/grey-green.toml +1 -1
  224. flock/themes/gruvboxlight.toml +1 -1
  225. flock/themes/guezwhoz.toml +1 -1
  226. flock/themes/harper.toml +1 -1
  227. flock/themes/hax0r-blue.toml +1 -1
  228. flock/themes/hopscotch.256.toml +1 -1
  229. flock/themes/ic-green-ppl.toml +1 -1
  230. flock/themes/iceberg-dark.toml +1 -1
  231. flock/themes/japanesque.toml +1 -1
  232. flock/themes/jubi.toml +1 -1
  233. flock/themes/kibble.toml +1 -1
  234. flock/themes/kolorit.toml +1 -1
  235. flock/themes/kurokula.toml +1 -1
  236. flock/themes/materialdesigncolors.toml +1 -1
  237. flock/themes/matrix.toml +1 -1
  238. flock/themes/mellifluous.toml +1 -1
  239. flock/themes/midnight-in-mojave.toml +1 -1
  240. flock/themes/monokai-remastered.toml +1 -1
  241. flock/themes/monokai-soda.toml +1 -1
  242. flock/themes/neon.toml +1 -1
  243. flock/themes/neopolitan.toml +5 -5
  244. flock/themes/nord-light.toml +1 -1
  245. flock/themes/ocean.toml +1 -1
  246. flock/themes/onehalfdark.toml +1 -1
  247. flock/themes/onehalflight.toml +1 -1
  248. flock/themes/palenighthc.toml +1 -1
  249. flock/themes/paulmillr.toml +1 -1
  250. flock/themes/pencildark.toml +1 -1
  251. flock/themes/pnevma.toml +1 -1
  252. flock/themes/purple-rain.toml +1 -1
  253. flock/themes/purplepeter.toml +1 -1
  254. flock/themes/raycast-dark.toml +1 -1
  255. flock/themes/red-sands.toml +1 -1
  256. flock/themes/relaxed.toml +1 -1
  257. flock/themes/retro.toml +1 -1
  258. flock/themes/rose-pine.toml +1 -1
  259. flock/themes/royal.toml +1 -1
  260. flock/themes/ryuuko.toml +1 -1
  261. flock/themes/sakura.toml +1 -1
  262. flock/themes/scarlet-protocol.toml +1 -1
  263. flock/themes/seoulbones-dark.toml +1 -1
  264. flock/themes/shades-of-purple.toml +1 -1
  265. flock/themes/smyck.toml +1 -1
  266. flock/themes/softserver.toml +1 -1
  267. flock/themes/solarized-darcula.toml +1 -1
  268. flock/themes/square.toml +1 -1
  269. flock/themes/sugarplum.toml +1 -1
  270. flock/themes/thayer-bright.toml +1 -1
  271. flock/themes/tokyonight.toml +1 -1
  272. flock/themes/tomorrow.toml +1 -1
  273. flock/themes/ubuntu.toml +1 -1
  274. flock/themes/ultradark.toml +1 -1
  275. flock/themes/ultraviolent.toml +1 -1
  276. flock/themes/unikitty.toml +1 -1
  277. flock/themes/urple.toml +1 -1
  278. flock/themes/vesper.toml +1 -1
  279. flock/themes/vimbones.toml +1 -1
  280. flock/themes/wildcherry.toml +1 -1
  281. flock/themes/wilmersdorf.toml +1 -1
  282. flock/themes/wryan.toml +1 -1
  283. flock/themes/xcodedarkhc.toml +1 -1
  284. flock/themes/xcodelight.toml +1 -1
  285. flock/themes/zenbones-light.toml +1 -1
  286. flock/themes/zenwritten-dark.toml +1 -1
  287. flock/utilities.py +301 -0
  288. flock/utility/output_utility_component.py +226 -0
  289. flock/visibility.py +107 -0
  290. flock_core-0.5.0.dist-info/METADATA +964 -0
  291. flock_core-0.5.0.dist-info/RECORD +525 -0
  292. flock_core-0.5.0.dist-info/entry_points.txt +2 -0
  293. {flock_core-0.4.542.dist-info → flock_core-0.5.0.dist-info}/licenses/LICENSE +1 -1
  294. flock/adapter/__init__.py +0 -14
  295. flock/adapter/azure_adapter.py +0 -68
  296. flock/adapter/chroma_adapter.py +0 -73
  297. flock/adapter/faiss_adapter.py +0 -97
  298. flock/adapter/pinecone_adapter.py +0 -51
  299. flock/adapter/vector_base.py +0 -47
  300. flock/cli/assets/release_notes.md +0 -140
  301. flock/cli/config.py +0 -8
  302. flock/cli/constants.py +0 -36
  303. flock/cli/create_agent.py +0 -1
  304. flock/cli/create_flock.py +0 -280
  305. flock/cli/execute_flock.py +0 -620
  306. flock/cli/load_agent.py +0 -1
  307. flock/cli/load_examples.py +0 -1
  308. flock/cli/load_flock.py +0 -192
  309. flock/cli/load_release_notes.py +0 -20
  310. flock/cli/loaded_flock_cli.py +0 -254
  311. flock/cli/manage_agents.py +0 -459
  312. flock/cli/registry_management.py +0 -889
  313. flock/cli/runner.py +0 -41
  314. flock/cli/settings.py +0 -857
  315. flock/cli/utils.py +0 -135
  316. flock/cli/view_results.py +0 -29
  317. flock/cli/yaml_editor.py +0 -396
  318. flock/config.py +0 -56
  319. flock/core/__init__.py +0 -44
  320. flock/core/api/__init__.py +0 -10
  321. flock/core/api/custom_endpoint.py +0 -45
  322. flock/core/api/endpoints.py +0 -262
  323. flock/core/api/main.py +0 -162
  324. flock/core/api/models.py +0 -101
  325. flock/core/api/run_store.py +0 -224
  326. flock/core/api/runner.py +0 -44
  327. flock/core/api/service.py +0 -214
  328. flock/core/config/flock_agent_config.py +0 -11
  329. flock/core/config/scheduled_agent_config.py +0 -40
  330. flock/core/context/context.py +0 -214
  331. flock/core/context/context_manager.py +0 -40
  332. flock/core/context/context_vars.py +0 -11
  333. flock/core/evaluation/utils.py +0 -395
  334. flock/core/execution/batch_executor.py +0 -369
  335. flock/core/execution/evaluation_executor.py +0 -438
  336. flock/core/execution/local_executor.py +0 -31
  337. flock/core/execution/opik_executor.py +0 -103
  338. flock/core/execution/temporal_executor.py +0 -166
  339. flock/core/flock.py +0 -1003
  340. flock/core/flock_agent.py +0 -1258
  341. flock/core/flock_evaluator.py +0 -60
  342. flock/core/flock_factory.py +0 -513
  343. flock/core/flock_module.py +0 -207
  344. flock/core/flock_registry.py +0 -702
  345. flock/core/flock_router.py +0 -83
  346. flock/core/flock_scheduler.py +0 -166
  347. flock/core/flock_server_manager.py +0 -136
  348. flock/core/interpreter/python_interpreter.py +0 -689
  349. flock/core/logging/live_capture.py +0 -137
  350. flock/core/logging/trace_and_logged.py +0 -59
  351. flock/core/mcp/__init__.py +0 -1
  352. flock/core/mcp/flock_mcp_server.py +0 -640
  353. flock/core/mcp/mcp_client_manager.py +0 -201
  354. flock/core/mcp/types/__init__.py +0 -1
  355. flock/core/mixin/dspy_integration.py +0 -445
  356. flock/core/mixin/prompt_parser.py +0 -125
  357. flock/core/serialization/__init__.py +0 -13
  358. flock/core/serialization/callable_registry.py +0 -52
  359. flock/core/serialization/flock_serializer.py +0 -854
  360. flock/core/serialization/json_encoder.py +0 -41
  361. flock/core/serialization/secure_serializer.py +0 -175
  362. flock/core/serialization/serializable.py +0 -342
  363. flock/core/serialization/serialization_utils.py +0 -409
  364. flock/core/util/file_path_utils.py +0 -223
  365. flock/core/util/hydrator.py +0 -309
  366. flock/core/util/input_resolver.py +0 -141
  367. flock/core/util/loader.py +0 -59
  368. flock/core/util/splitter.py +0 -219
  369. flock/di.py +0 -41
  370. flock/evaluators/__init__.py +0 -1
  371. flock/evaluators/declarative/__init__.py +0 -1
  372. flock/evaluators/declarative/declarative_evaluator.py +0 -217
  373. flock/evaluators/memory/memory_evaluator.py +0 -90
  374. flock/evaluators/test/test_case_evaluator.py +0 -38
  375. flock/evaluators/zep/zep_evaluator.py +0 -59
  376. flock/modules/__init__.py +0 -1
  377. flock/modules/assertion/__init__.py +0 -1
  378. flock/modules/assertion/assertion_module.py +0 -286
  379. flock/modules/callback/__init__.py +0 -1
  380. flock/modules/callback/callback_module.py +0 -91
  381. flock/modules/enterprise_memory/README.md +0 -99
  382. flock/modules/enterprise_memory/enterprise_memory_module.py +0 -526
  383. flock/modules/mem0/__init__.py +0 -1
  384. flock/modules/mem0/mem0_module.py +0 -126
  385. flock/modules/mem0_async/__init__.py +0 -1
  386. flock/modules/mem0_async/async_mem0_module.py +0 -126
  387. flock/modules/memory/__init__.py +0 -1
  388. flock/modules/memory/memory_module.py +0 -429
  389. flock/modules/memory/memory_parser.py +0 -125
  390. flock/modules/memory/memory_storage.py +0 -736
  391. flock/modules/output/__init__.py +0 -1
  392. flock/modules/output/output_module.py +0 -196
  393. flock/modules/performance/__init__.py +0 -1
  394. flock/modules/performance/metrics_module.py +0 -678
  395. flock/modules/zep/__init__.py +0 -1
  396. flock/modules/zep/zep_module.py +0 -192
  397. flock/platform/docker_tools.py +0 -49
  398. flock/platform/jaeger_install.py +0 -86
  399. flock/routers/__init__.py +0 -1
  400. flock/routers/agent/__init__.py +0 -1
  401. flock/routers/agent/agent_router.py +0 -236
  402. flock/routers/agent/handoff_agent.py +0 -58
  403. flock/routers/conditional/conditional_router.py +0 -486
  404. flock/routers/default/__init__.py +0 -1
  405. flock/routers/default/default_router.py +0 -80
  406. flock/routers/feedback/feedback_router.py +0 -114
  407. flock/routers/list_generator/list_generator_router.py +0 -166
  408. flock/routers/llm/__init__.py +0 -1
  409. flock/routers/llm/llm_router.py +0 -365
  410. flock/tools/__init__.py +0 -0
  411. flock/tools/azure_tools.py +0 -781
  412. flock/tools/code_tools.py +0 -167
  413. flock/tools/file_tools.py +0 -149
  414. flock/tools/github_tools.py +0 -157
  415. flock/tools/markdown_tools.py +0 -205
  416. flock/tools/system_tools.py +0 -9
  417. flock/tools/text_tools.py +0 -810
  418. flock/tools/web_tools.py +0 -92
  419. flock/tools/zendesk_tools.py +0 -501
  420. flock/webapp/__init__.py +0 -1
  421. flock/webapp/app/__init__.py +0 -0
  422. flock/webapp/app/api/__init__.py +0 -0
  423. flock/webapp/app/api/agent_management.py +0 -237
  424. flock/webapp/app/api/execution.py +0 -503
  425. flock/webapp/app/api/flock_management.py +0 -125
  426. flock/webapp/app/api/registry_viewer.py +0 -29
  427. flock/webapp/app/chat.py +0 -662
  428. flock/webapp/app/config.py +0 -104
  429. flock/webapp/app/dependencies.py +0 -117
  430. flock/webapp/app/main.py +0 -1086
  431. flock/webapp/app/middleware.py +0 -113
  432. flock/webapp/app/models_ui.py +0 -7
  433. flock/webapp/app/services/__init__.py +0 -0
  434. flock/webapp/app/services/feedback_file_service.py +0 -363
  435. flock/webapp/app/services/flock_service.py +0 -345
  436. flock/webapp/app/services/sharing_models.py +0 -81
  437. flock/webapp/app/services/sharing_store.py +0 -597
  438. flock/webapp/app/templates/theme_mapper.html +0 -326
  439. flock/webapp/app/theme_mapper.py +0 -811
  440. flock/webapp/app/utils.py +0 -85
  441. flock/webapp/run.py +0 -219
  442. flock/webapp/static/css/chat.css +0 -301
  443. flock/webapp/static/css/components.css +0 -167
  444. flock/webapp/static/css/header.css +0 -39
  445. flock/webapp/static/css/layout.css +0 -281
  446. flock/webapp/static/css/sidebar.css +0 -127
  447. flock/webapp/static/css/two-pane.css +0 -48
  448. flock/webapp/templates/base.html +0 -389
  449. flock/webapp/templates/chat.html +0 -152
  450. flock/webapp/templates/chat_settings.html +0 -19
  451. flock/webapp/templates/flock_editor.html +0 -16
  452. flock/webapp/templates/index.html +0 -12
  453. flock/webapp/templates/partials/_agent_detail_form.html +0 -93
  454. flock/webapp/templates/partials/_agent_list.html +0 -18
  455. flock/webapp/templates/partials/_agent_manager_view.html +0 -51
  456. flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
  457. flock/webapp/templates/partials/_chat_container.html +0 -15
  458. flock/webapp/templates/partials/_chat_messages.html +0 -57
  459. flock/webapp/templates/partials/_chat_settings_form.html +0 -85
  460. flock/webapp/templates/partials/_create_flock_form.html +0 -50
  461. flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
  462. flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
  463. flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
  464. flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
  465. flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
  466. flock/webapp/templates/partials/_env_vars_table.html +0 -23
  467. flock/webapp/templates/partials/_execution_form.html +0 -127
  468. flock/webapp/templates/partials/_execution_view_container.html +0 -28
  469. flock/webapp/templates/partials/_flock_file_list.html +0 -23
  470. flock/webapp/templates/partials/_flock_properties_form.html +0 -52
  471. flock/webapp/templates/partials/_flock_upload_form.html +0 -16
  472. flock/webapp/templates/partials/_header_flock_status.html +0 -5
  473. flock/webapp/templates/partials/_live_logs.html +0 -13
  474. flock/webapp/templates/partials/_load_manager_view.html +0 -49
  475. flock/webapp/templates/partials/_registry_table.html +0 -25
  476. flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
  477. flock/webapp/templates/partials/_results_display.html +0 -78
  478. flock/webapp/templates/partials/_settings_env_content.html +0 -9
  479. flock/webapp/templates/partials/_settings_theme_content.html +0 -14
  480. flock/webapp/templates/partials/_settings_view.html +0 -36
  481. flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
  482. flock/webapp/templates/partials/_share_link_snippet.html +0 -35
  483. flock/webapp/templates/partials/_sidebar.html +0 -74
  484. flock/webapp/templates/partials/_structured_data_view.html +0 -40
  485. flock/webapp/templates/partials/_theme_preview.html +0 -36
  486. flock/webapp/templates/registry_viewer.html +0 -84
  487. flock/webapp/templates/shared_run_page.html +0 -140
  488. flock/workflow/__init__.py +0 -0
  489. flock/workflow/activities.py +0 -237
  490. flock/workflow/agent_activities.py +0 -24
  491. flock/workflow/agent_execution_activity.py +0 -240
  492. flock/workflow/flock_workflow.py +0 -225
  493. flock/workflow/temporal_config.py +0 -96
  494. flock/workflow/temporal_setup.py +0 -60
  495. flock_core-0.4.542.dist-info/METADATA +0 -676
  496. flock_core-0.4.542.dist-info/RECORD +0 -572
  497. flock_core-0.4.542.dist-info/entry_points.txt +0 -2
  498. /flock/{core/logging → logging}/formatters/themes.py +0 -0
  499. /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
  500. /flock/{core/mcp → mcp}/util/__init__.py +0 -0
  501. {flock_core-0.4.542.dist-info → flock_core-0.5.0.dist-info}/WHEEL +0 -0
flock/api/themes.py ADDED
@@ -0,0 +1,71 @@
1
+ """
2
+ Theme API Endpoints
3
+
4
+ Serves 300+ terminal color themes from TOML files.
5
+ Themes are loaded from src/flock/themes/
6
+ """
7
+
8
+ from pathlib import Path
9
+ from typing import Any
10
+
11
+ import toml
12
+ from fastapi import APIRouter, HTTPException
13
+
14
+
15
+ router = APIRouter()
16
+
17
+ # Path to themes directory
18
+ THEMES_DIR = Path(__file__).parent.parent / "themes"
19
+
20
+
21
+ @router.get("/themes")
22
+ async def list_themes() -> dict[str, list[str]]:
23
+ """
24
+ List all available theme names.
25
+
26
+ Returns:
27
+ Dictionary with 'themes' key containing sorted list of theme names
28
+ """
29
+ try:
30
+ if not THEMES_DIR.exists():
31
+ return {"themes": []}
32
+
33
+ theme_files = list(THEMES_DIR.glob("*.toml"))
34
+ theme_names = sorted([f.stem for f in theme_files])
35
+
36
+ return {"themes": theme_names}
37
+ except Exception as e:
38
+ raise HTTPException(status_code=500, detail=f"Failed to list themes: {e!s}")
39
+
40
+
41
+ @router.get("/themes/{theme_name}")
42
+ async def get_theme(theme_name: str) -> dict[str, Any]:
43
+ """
44
+ Get theme data by name.
45
+
46
+ Args:
47
+ theme_name: Name of the theme (without .toml extension)
48
+
49
+ Returns:
50
+ Dictionary with 'name' and 'data' containing theme colors
51
+
52
+ Raises:
53
+ HTTPException: If theme not found or failed to load
54
+ """
55
+ try:
56
+ # Sanitize theme name to prevent path traversal
57
+ theme_name = theme_name.replace("/", "").replace("\\", "").replace("..", "")
58
+
59
+ theme_path = THEMES_DIR / f"{theme_name}.toml"
60
+
61
+ if not theme_path.exists():
62
+ raise HTTPException(status_code=404, detail=f"Theme '{theme_name}' not found")
63
+
64
+ # Load TOML theme
65
+ theme_data = toml.load(theme_path)
66
+
67
+ return {"name": theme_name, "data": theme_data}
68
+ except HTTPException:
69
+ raise
70
+ except Exception as e:
71
+ raise HTTPException(status_code=500, detail=f"Failed to load theme '{theme_name}': {e!s}")
flock/artifacts.py ADDED
@@ -0,0 +1,86 @@
1
+ """Artifact modelling utilities."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from datetime import datetime, timezone
6
+ from typing import Any
7
+ from uuid import UUID, uuid4
8
+
9
+ from pydantic import BaseModel, Field
10
+
11
+ from flock.registry import type_registry
12
+ from flock.visibility import Visibility, ensure_visibility
13
+
14
+
15
+ class Artifact(BaseModel):
16
+ """Typed artifact stored on the blackboard."""
17
+
18
+ id: UUID = Field(default_factory=uuid4)
19
+ type: str
20
+ payload: dict[str, Any]
21
+ produced_by: str
22
+ correlation_id: UUID | None = None
23
+ partition_key: str | None = None
24
+ tags: set[str] = Field(default_factory=set)
25
+ visibility: Visibility = Field(default_factory=lambda: ensure_visibility(None))
26
+ created_at: datetime = Field(default_factory=lambda: datetime.now(timezone.utc))
27
+ version: int = 1
28
+
29
+ def model_dump_payload(self) -> dict[str, Any]: # pragma: no cover - convenience
30
+ return dict(self.payload)
31
+
32
+
33
+ class ArtifactSpec(BaseModel):
34
+ """Wiring description used for validation on publish."""
35
+
36
+ type_name: str
37
+ model: type[BaseModel]
38
+
39
+ @classmethod
40
+ def from_model(cls, model: type[BaseModel]) -> ArtifactSpec:
41
+ type_name = type_registry.register(model)
42
+ return cls(type_name=type_name, model=model)
43
+
44
+ def build(
45
+ self,
46
+ *,
47
+ produced_by: str,
48
+ data: dict[str, Any],
49
+ visibility: Visibility | None = None,
50
+ correlation_id: UUID | None = None,
51
+ partition_key: str | None = None,
52
+ tags: set[str] | None = None,
53
+ version: int = 1,
54
+ artifact_id: UUID | None = None, # Phase 6: Optional pre-generated ID
55
+ ) -> Artifact:
56
+ payload_model = self.model(**data)
57
+ artifact_kwargs = {
58
+ "type": self.type_name,
59
+ "payload": payload_model.model_dump(),
60
+ "produced_by": produced_by,
61
+ "visibility": ensure_visibility(visibility),
62
+ "correlation_id": correlation_id,
63
+ "partition_key": partition_key,
64
+ "tags": tags or set(),
65
+ "version": version,
66
+ }
67
+
68
+ # Phase 6: Use pre-generated ID if provided (for streaming message preview)
69
+ if artifact_id is not None:
70
+ artifact_kwargs["id"] = artifact_id
71
+
72
+ return Artifact(**artifact_kwargs)
73
+
74
+
75
+ class ArtifactEnvelope(BaseModel):
76
+ """Envelope passed to components/engines during evaluation."""
77
+
78
+ artifact: Artifact
79
+ state: dict[str, Any] = Field(default_factory=dict)
80
+
81
+
82
+ __all__ = [
83
+ "Artifact",
84
+ "ArtifactEnvelope",
85
+ "ArtifactSpec",
86
+ ]
flock/cli.py ADDED
@@ -0,0 +1,147 @@
1
+ """Typer-based CLI for blackboard agents."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import asyncio
6
+ from datetime import datetime
7
+
8
+ import typer
9
+ from rich.console import Console
10
+ from rich.table import Table
11
+ from typer.models import OptionInfo
12
+
13
+ # Lazy import: only import examples when CLI commands are invoked
14
+ # This prevents polluting type_registry on every package import
15
+ from flock.service import BlackboardHTTPService
16
+ from flock.store import SQLiteBlackboardStore
17
+
18
+
19
+ app = typer.Typer(help="Blackboard Agents CLI")
20
+ console = Console()
21
+
22
+
23
+ @app.command()
24
+ def demo(
25
+ topic: str = typer.Option("AI agents collaborating", help="Idea topic"),
26
+ genre: str = typer.Option("comedy", help="Idea genre"),
27
+ ) -> None:
28
+ """Run the demo pipeline locally and stream results to the console."""
29
+
30
+ from flock.examples import Idea, create_demo_orchestrator
31
+
32
+ orchestrator, agents = create_demo_orchestrator()
33
+ idea = Idea(topic=topic, genre=genre)
34
+
35
+ async def _run_demo() -> None:
36
+ await orchestrator.arun(agents["movie"], idea)
37
+ await orchestrator.run_until_idle()
38
+ table = Table(title="Published Artifacts")
39
+ table.add_column("Type")
40
+ table.add_column("Payload", overflow="fold")
41
+ for artifact in await orchestrator.store.list():
42
+ table.add_row(artifact.type, repr(artifact.payload))
43
+ console.print(table)
44
+
45
+ asyncio.run(_run_demo())
46
+
47
+
48
+ @app.command()
49
+ def list_agents() -> None:
50
+ """List registered agents for the demo orchestrator."""
51
+
52
+ from flock.examples import create_demo_orchestrator
53
+
54
+ orchestrator, _agents = create_demo_orchestrator()
55
+ table = Table(title="Agents")
56
+ table.add_column("Name")
57
+ table.add_column("Description")
58
+ for agent in orchestrator.agents:
59
+ table.add_row(agent.name, agent.description or "")
60
+ console.print(table)
61
+
62
+
63
+ @app.command()
64
+ def serve(
65
+ host: str = "127.0.0.1",
66
+ port: int = 8344,
67
+ sqlite_db: str | None = typer.Option(None, help="Path to SQLite blackboard store"),
68
+ ) -> None:
69
+ """Run the HTTP control plane bound to the demo orchestrator."""
70
+
71
+ from flock.examples import create_demo_orchestrator
72
+
73
+ if isinstance(sqlite_db, OptionInfo): # Allow direct invocation in tests
74
+ sqlite_db = sqlite_db.default
75
+
76
+ store = None
77
+ if sqlite_db is not None:
78
+ sqlite_store = SQLiteBlackboardStore(sqlite_db)
79
+
80
+ async def _prepare() -> SQLiteBlackboardStore:
81
+ await sqlite_store.ensure_schema()
82
+ return sqlite_store
83
+
84
+ store = asyncio.run(_prepare())
85
+
86
+ orchestrator, _ = create_demo_orchestrator(store=store)
87
+ service = BlackboardHTTPService(orchestrator)
88
+ service.run(host=host, port=port)
89
+
90
+
91
+ @app.command("init-sqlite-store")
92
+ def init_sqlite_store(
93
+ db_path: str = typer.Argument(..., help="Path to SQLite blackboard database"),
94
+ ) -> None:
95
+ """Initialise the SQLite store schema."""
96
+
97
+ store = SQLiteBlackboardStore(db_path)
98
+
99
+ async def _init() -> None:
100
+ await store.ensure_schema()
101
+ await store.close()
102
+
103
+ asyncio.run(_init())
104
+ console.print(f"[green]Initialised SQLite blackboard at {db_path}[/green]")
105
+
106
+
107
+ @app.command("sqlite-maintenance")
108
+ def sqlite_maintenance(
109
+ db_path: str = typer.Argument(..., help="Path to SQLite blackboard database"),
110
+ delete_before: str | None = typer.Option(
111
+ None, help="ISO timestamp; delete artifacts before this time"
112
+ ),
113
+ vacuum: bool = typer.Option(False, help="Run VACUUM after maintenance"),
114
+ ) -> None:
115
+ """Perform maintenance tasks for the SQLite store."""
116
+
117
+ store = SQLiteBlackboardStore(db_path)
118
+
119
+ async def _maintain() -> tuple[int, bool]:
120
+ await store.ensure_schema()
121
+ deleted = 0
122
+ if delete_before is not None:
123
+ try:
124
+ before_dt = datetime.fromisoformat(delete_before)
125
+ except ValueError as exc: # pragma: no cover - Typer handles but defensive
126
+ raise typer.BadParameter(f"Invalid ISO timestamp: {delete_before}") from exc
127
+ deleted = await store.delete_before(before_dt)
128
+ if vacuum:
129
+ await store.vacuum()
130
+ await store.close()
131
+ return deleted, vacuum
132
+
133
+ deleted, vacuum_run = asyncio.run(_maintain())
134
+ console.print(
135
+ f"[yellow]Deleted {deleted} artifacts[/yellow]"
136
+ if delete_before is not None
137
+ else "[yellow]No deletions requested[/yellow]"
138
+ )
139
+ if vacuum_run:
140
+ console.print("[yellow]VACUUM completed[/yellow]")
141
+
142
+
143
+ def main() -> None:
144
+ app()
145
+
146
+
147
+ __all__ = ["app", "main"]
flock/components.py ADDED
@@ -0,0 +1,189 @@
1
+ """Agent component abstractions."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import TYPE_CHECKING, Any
6
+
7
+ from pydantic import BaseModel, Field, create_model
8
+ from pydantic._internal._model_construction import ModelMetaclass
9
+ from typing_extensions import Self, TypeVar
10
+
11
+ from flock.logging.auto_trace import AutoTracedMeta
12
+
13
+
14
+ if TYPE_CHECKING: # pragma: no cover - type checking only
15
+ from uuid import UUID
16
+
17
+ from flock.agent import Agent
18
+ from flock.artifacts import Artifact
19
+ from flock.runtime import Context, EvalInputs, EvalResult
20
+
21
+ T = TypeVar("T", bound="AgentComponentConfig")
22
+
23
+
24
+ class TracedModelMeta(ModelMetaclass, AutoTracedMeta):
25
+ """Combined metaclass for Pydantic models with auto-tracing.
26
+
27
+ This metaclass combines Pydantic's ModelMetaclass with AutoTracedMeta
28
+ to enable both Pydantic functionality and automatic method tracing.
29
+ """
30
+
31
+
32
+ class AgentComponentConfig(BaseModel):
33
+ enabled: bool = True
34
+ model: str | None = None
35
+
36
+ @classmethod
37
+ def with_fields(cls, **field_definitions) -> type[Self]:
38
+ """Create a new config class with additional fields.
39
+
40
+ This allows dynamic config creation for components with custom configuration needs.
41
+
42
+ Example:
43
+ CustomConfig = AgentComponentConfig.with_fields(
44
+ temperature=Field(default=0.7, description="LLM temperature"),
45
+ max_tokens=Field(default=1000, description="Max tokens to generate")
46
+ )
47
+ """
48
+ return create_model(f"Dynamic{cls.__name__}", __base__=cls, **field_definitions)
49
+
50
+
51
+ class AgentComponent(BaseModel, metaclass=TracedModelMeta):
52
+ """Base class for agent components with lifecycle hooks.
53
+
54
+ All public methods are automatically traced via OpenTelemetry.
55
+ """
56
+
57
+ name: str | None = None
58
+ config: AgentComponentConfig = Field(default_factory=AgentComponentConfig)
59
+
60
+ async def on_initialize(
61
+ self, agent: Agent, ctx: Context
62
+ ) -> None: # pragma: no cover - default no-op
63
+ return None
64
+
65
+ async def on_pre_consume(
66
+ self, agent: Agent, ctx: Context, inputs: list[Artifact]
67
+ ) -> list[Artifact]:
68
+ return inputs
69
+
70
+ async def on_pre_evaluate(self, agent: Agent, ctx: Context, inputs: EvalInputs) -> EvalInputs:
71
+ return inputs
72
+
73
+ async def on_post_evaluate(
74
+ self, agent: Agent, ctx: Context, inputs: EvalInputs, result: EvalResult
75
+ ) -> EvalResult:
76
+ return result
77
+
78
+ async def on_post_publish(
79
+ self, agent: Agent, ctx: Context, artifact: Artifact
80
+ ) -> None: # pragma: no cover - default
81
+ return None
82
+
83
+ async def on_error(
84
+ self, agent: Agent, ctx: Context, error: Exception
85
+ ) -> None: # pragma: no cover - default
86
+ return None
87
+
88
+ async def on_terminate(self, agent: Agent, ctx: Context) -> None: # pragma: no cover - default
89
+ return None
90
+
91
+
92
+ class EngineComponent(AgentComponent):
93
+ """Base class for engine components with built-in conversation context support."""
94
+
95
+ # Configuration for context fetching
96
+ enable_context: bool = Field(
97
+ default=True,
98
+ description="Whether to automatically fetch conversation context based on correlation_id",
99
+ )
100
+ context_max_artifacts: int | None = Field(
101
+ default=None,
102
+ description="Maximum number of artifacts to include in context (None = unlimited)",
103
+ )
104
+ context_exclude_types: set[str] = Field(
105
+ default_factory=set, description="Artifact types to exclude from context"
106
+ )
107
+
108
+ async def evaluate(self, agent: Agent, ctx: Context, inputs: EvalInputs) -> EvalResult:
109
+ """Override this method in your engine implementation."""
110
+ raise NotImplementedError
111
+
112
+ async def fetch_conversation_context(
113
+ self,
114
+ ctx: Context,
115
+ correlation_id: UUID | None = None,
116
+ max_artifacts: int | None = None,
117
+ ) -> list[dict[str, Any]]:
118
+ """Fetch all artifacts with the same correlation_id for conversation context."""
119
+ if not self.enable_context or not ctx:
120
+ return []
121
+
122
+ target_correlation_id = correlation_id or getattr(ctx, "correlation_id", None)
123
+ if not target_correlation_id:
124
+ return []
125
+
126
+ try:
127
+ all_artifacts = await ctx.board.list()
128
+
129
+ context_artifacts = [
130
+ a
131
+ for a in all_artifacts
132
+ if (
133
+ a.correlation_id == target_correlation_id
134
+ and a.type not in self.context_exclude_types
135
+ )
136
+ ]
137
+
138
+ context_artifacts.sort(key=lambda a: a.created_at)
139
+
140
+ max_limit = max_artifacts if max_artifacts is not None else self.context_max_artifacts
141
+ if max_limit is not None and max_limit > 0:
142
+ context_artifacts = context_artifacts[-max_limit:]
143
+
144
+ context = []
145
+ i = 0
146
+ for artifact in context_artifacts:
147
+ context.append(
148
+ {
149
+ "type": artifact.type,
150
+ "payload": artifact.payload,
151
+ "produced_by": artifact.produced_by,
152
+ "event_number": i,
153
+ # "created_at": artifact.created_at.isoformat(),
154
+ }
155
+ )
156
+ i += 1
157
+
158
+ return context
159
+
160
+ except Exception:
161
+ return []
162
+
163
+ async def get_latest_artifact_of_type(
164
+ self,
165
+ ctx: Context,
166
+ artifact_type: str,
167
+ correlation_id: UUID | None = None,
168
+ ) -> dict[str, Any] | None:
169
+ """Get the most recent artifact of a specific type in the conversation."""
170
+ context = await self.fetch_conversation_context(ctx, correlation_id)
171
+ matching = [a for a in context if a["type"].endswith(artifact_type)]
172
+ return matching[-1] if matching else None
173
+
174
+ def should_use_context(self, inputs: EvalInputs) -> bool:
175
+ """Determine if context should be included based on the current inputs."""
176
+ if not self.enable_context:
177
+ return False
178
+
179
+ if inputs.artifacts:
180
+ return inputs.artifacts[0].correlation_id is not None
181
+
182
+ return False
183
+
184
+
185
+ __all__ = [
186
+ "AgentComponent",
187
+ "AgentComponentConfig",
188
+ "EngineComponent",
189
+ ]
@@ -0,0 +1,30 @@
1
+ """Real-time dashboard event collection for flock-flow.
2
+
3
+ Phase 1: Backend event capture system.
4
+ Phase 3: WebSocket infrastructure for real-time communication.
5
+ """
6
+
7
+ from flock.dashboard.collector import DashboardEventCollector
8
+ from flock.dashboard.events import (
9
+ AgentActivatedEvent,
10
+ AgentCompletedEvent,
11
+ AgentErrorEvent,
12
+ MessagePublishedEvent,
13
+ StreamingOutputEvent,
14
+ )
15
+ from flock.dashboard.graph_builder import GraphAssembler
16
+ from flock.dashboard.service import DashboardHTTPService
17
+ from flock.dashboard.websocket import WebSocketManager
18
+
19
+
20
+ __all__ = [
21
+ "AgentActivatedEvent",
22
+ "AgentCompletedEvent",
23
+ "AgentErrorEvent",
24
+ "DashboardEventCollector",
25
+ "DashboardHTTPService",
26
+ "GraphAssembler",
27
+ "MessagePublishedEvent",
28
+ "StreamingOutputEvent",
29
+ "WebSocketManager",
30
+ ]