flock-core 0.5.0b28__py3-none-any.whl → 0.5.0b51__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 (469) hide show
  1. flock/__init__.py +12 -217
  2. flock/agent.py +678 -0
  3. flock/api/themes.py +71 -0
  4. flock/artifacts.py +79 -0
  5. flock/cli.py +75 -0
  6. flock/components.py +173 -0
  7. flock/dashboard/__init__.py +28 -0
  8. flock/dashboard/collector.py +283 -0
  9. flock/dashboard/events.py +182 -0
  10. flock/dashboard/launcher.py +230 -0
  11. flock/dashboard/service.py +537 -0
  12. flock/dashboard/websocket.py +235 -0
  13. flock/engines/__init__.py +6 -0
  14. flock/engines/dspy_engine.py +856 -0
  15. flock/examples.py +128 -0
  16. flock/frontend/README.md +678 -0
  17. flock/frontend/docs/DESIGN_SYSTEM.md +1980 -0
  18. flock/frontend/index.html +12 -0
  19. flock/frontend/package-lock.json +4347 -0
  20. flock/frontend/package.json +48 -0
  21. flock/frontend/src/App.tsx +79 -0
  22. flock/frontend/src/__tests__/e2e/critical-scenarios.test.tsx +587 -0
  23. flock/frontend/src/__tests__/integration/filtering-e2e.test.tsx +387 -0
  24. flock/frontend/src/__tests__/integration/graph-rendering.test.tsx +640 -0
  25. flock/frontend/src/__tests__/integration/indexeddb-persistence.test.tsx +699 -0
  26. flock/frontend/src/components/common/BuildInfo.tsx +39 -0
  27. flock/frontend/src/components/common/EmptyState.module.css +115 -0
  28. flock/frontend/src/components/common/EmptyState.tsx +128 -0
  29. flock/frontend/src/components/common/ErrorBoundary.module.css +169 -0
  30. flock/frontend/src/components/common/ErrorBoundary.tsx +118 -0
  31. flock/frontend/src/components/common/KeyboardShortcutsDialog.css +251 -0
  32. flock/frontend/src/components/common/KeyboardShortcutsDialog.tsx +151 -0
  33. flock/frontend/src/components/common/LoadingSpinner.module.css +97 -0
  34. flock/frontend/src/components/common/LoadingSpinner.tsx +29 -0
  35. flock/frontend/src/components/controls/PublishControl.css +547 -0
  36. flock/frontend/src/components/controls/PublishControl.test.tsx +543 -0
  37. flock/frontend/src/components/controls/PublishControl.tsx +432 -0
  38. flock/frontend/src/components/details/DetailWindowContainer.tsx +62 -0
  39. flock/frontend/src/components/details/LiveOutputTab.test.tsx +792 -0
  40. flock/frontend/src/components/details/LiveOutputTab.tsx +220 -0
  41. flock/frontend/src/components/details/MessageHistoryTab.tsx +299 -0
  42. flock/frontend/src/components/details/NodeDetailWindow.test.tsx +501 -0
  43. flock/frontend/src/components/details/NodeDetailWindow.tsx +218 -0
  44. flock/frontend/src/components/details/RunStatusTab.tsx +307 -0
  45. flock/frontend/src/components/details/tabs.test.tsx +1015 -0
  46. flock/frontend/src/components/filters/CorrelationIDFilter.module.css +102 -0
  47. flock/frontend/src/components/filters/CorrelationIDFilter.test.tsx +197 -0
  48. flock/frontend/src/components/filters/CorrelationIDFilter.tsx +121 -0
  49. flock/frontend/src/components/filters/FilterBar.module.css +29 -0
  50. flock/frontend/src/components/filters/FilterBar.test.tsx +133 -0
  51. flock/frontend/src/components/filters/FilterBar.tsx +33 -0
  52. flock/frontend/src/components/filters/FilterPills.module.css +79 -0
  53. flock/frontend/src/components/filters/FilterPills.test.tsx +173 -0
  54. flock/frontend/src/components/filters/FilterPills.tsx +67 -0
  55. flock/frontend/src/components/filters/TimeRangeFilter.module.css +91 -0
  56. flock/frontend/src/components/filters/TimeRangeFilter.test.tsx +154 -0
  57. flock/frontend/src/components/filters/TimeRangeFilter.tsx +105 -0
  58. flock/frontend/src/components/graph/AgentNode.test.tsx +75 -0
  59. flock/frontend/src/components/graph/AgentNode.tsx +322 -0
  60. flock/frontend/src/components/graph/GraphCanvas.tsx +406 -0
  61. flock/frontend/src/components/graph/MessageFlowEdge.tsx +128 -0
  62. flock/frontend/src/components/graph/MessageNode.test.tsx +62 -0
  63. flock/frontend/src/components/graph/MessageNode.tsx +116 -0
  64. flock/frontend/src/components/graph/MiniMap.tsx +47 -0
  65. flock/frontend/src/components/graph/TransformEdge.tsx +123 -0
  66. flock/frontend/src/components/layout/DashboardLayout.css +407 -0
  67. flock/frontend/src/components/layout/DashboardLayout.tsx +300 -0
  68. flock/frontend/src/components/layout/Header.module.css +88 -0
  69. flock/frontend/src/components/layout/Header.tsx +52 -0
  70. flock/frontend/src/components/modules/EventLogModule.test.tsx +401 -0
  71. flock/frontend/src/components/modules/EventLogModule.tsx +396 -0
  72. flock/frontend/src/components/modules/EventLogModuleWrapper.tsx +17 -0
  73. flock/frontend/src/components/modules/ModuleRegistry.test.ts +333 -0
  74. flock/frontend/src/components/modules/ModuleRegistry.ts +85 -0
  75. flock/frontend/src/components/modules/ModuleWindow.tsx +155 -0
  76. flock/frontend/src/components/modules/registerModules.ts +20 -0
  77. flock/frontend/src/components/settings/AdvancedSettings.tsx +175 -0
  78. flock/frontend/src/components/settings/AppearanceSettings.tsx +185 -0
  79. flock/frontend/src/components/settings/GraphSettings.tsx +110 -0
  80. flock/frontend/src/components/settings/SettingsPanel.css +327 -0
  81. flock/frontend/src/components/settings/SettingsPanel.tsx +131 -0
  82. flock/frontend/src/components/settings/ThemeSelector.tsx +298 -0
  83. flock/frontend/src/hooks/useKeyboardShortcuts.ts +148 -0
  84. flock/frontend/src/hooks/useModulePersistence.test.ts +442 -0
  85. flock/frontend/src/hooks/useModulePersistence.ts +154 -0
  86. flock/frontend/src/hooks/useModules.ts +139 -0
  87. flock/frontend/src/hooks/usePersistence.ts +139 -0
  88. flock/frontend/src/main.tsx +13 -0
  89. flock/frontend/src/services/api.ts +213 -0
  90. flock/frontend/src/services/indexeddb.test.ts +793 -0
  91. flock/frontend/src/services/indexeddb.ts +794 -0
  92. flock/frontend/src/services/layout.test.ts +437 -0
  93. flock/frontend/src/services/layout.ts +146 -0
  94. flock/frontend/src/services/themeApplicator.ts +140 -0
  95. flock/frontend/src/services/themeService.ts +77 -0
  96. flock/frontend/src/services/websocket.test.ts +595 -0
  97. flock/frontend/src/services/websocket.ts +685 -0
  98. flock/frontend/src/store/filterStore.test.ts +242 -0
  99. flock/frontend/src/store/filterStore.ts +103 -0
  100. flock/frontend/src/store/graphStore.test.ts +186 -0
  101. flock/frontend/src/store/graphStore.ts +414 -0
  102. flock/frontend/src/store/moduleStore.test.ts +253 -0
  103. flock/frontend/src/store/moduleStore.ts +57 -0
  104. flock/frontend/src/store/settingsStore.ts +188 -0
  105. flock/frontend/src/store/streamStore.ts +68 -0
  106. flock/frontend/src/store/uiStore.test.ts +54 -0
  107. flock/frontend/src/store/uiStore.ts +110 -0
  108. flock/frontend/src/store/wsStore.ts +34 -0
  109. flock/frontend/src/styles/index.css +15 -0
  110. flock/frontend/src/styles/scrollbar.css +47 -0
  111. flock/frontend/src/styles/variables.css +488 -0
  112. flock/frontend/src/test/setup.ts +1 -0
  113. flock/frontend/src/types/filters.ts +14 -0
  114. flock/frontend/src/types/graph.ts +55 -0
  115. flock/frontend/src/types/modules.ts +7 -0
  116. flock/frontend/src/types/theme.ts +55 -0
  117. flock/frontend/src/utils/mockData.ts +85 -0
  118. flock/frontend/src/utils/performance.ts +16 -0
  119. flock/frontend/src/utils/transforms.test.ts +860 -0
  120. flock/frontend/src/utils/transforms.ts +323 -0
  121. flock/frontend/src/vite-env.d.ts +17 -0
  122. flock/frontend/tsconfig.json +27 -0
  123. flock/frontend/tsconfig.node.json +11 -0
  124. flock/frontend/vite.config.ts +25 -0
  125. flock/frontend/vitest.config.ts +11 -0
  126. flock/{core/util → helper}/cli_helper.py +4 -3
  127. flock/{core/logging → logging}/__init__.py +2 -3
  128. flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
  129. flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
  130. flock/{core/logging → logging}/formatters/themed_formatter.py +69 -115
  131. flock/{core/logging → logging}/logging.py +77 -61
  132. flock/{core/logging → logging}/telemetry.py +20 -26
  133. flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
  134. flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +6 -9
  135. flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
  136. flock/{core/logging → logging}/trace_and_logged.py +20 -24
  137. flock/mcp/__init__.py +91 -0
  138. flock/{core/mcp/mcp_client.py → mcp/client.py} +103 -154
  139. flock/{core/mcp/mcp_config.py → mcp/config.py} +62 -117
  140. flock/mcp/manager.py +255 -0
  141. flock/mcp/servers/sse/__init__.py +1 -1
  142. flock/mcp/servers/sse/flock_sse_server.py +11 -53
  143. flock/mcp/servers/stdio/__init__.py +1 -1
  144. flock/mcp/servers/stdio/flock_stdio_server.py +8 -48
  145. flock/mcp/servers/streamable_http/flock_streamable_http_server.py +17 -62
  146. flock/mcp/servers/websockets/flock_websocket_server.py +7 -40
  147. flock/{core/mcp/flock_mcp_tool.py → mcp/tool.py} +16 -26
  148. flock/mcp/types/__init__.py +42 -0
  149. flock/{core/mcp → mcp}/types/callbacks.py +9 -15
  150. flock/{core/mcp → mcp}/types/factories.py +7 -6
  151. flock/{core/mcp → mcp}/types/handlers.py +13 -18
  152. flock/{core/mcp → mcp}/types/types.py +70 -74
  153. flock/{core/mcp → mcp}/util/helpers.py +1 -1
  154. flock/orchestrator.py +645 -0
  155. flock/registry.py +148 -0
  156. flock/runtime.py +262 -0
  157. flock/service.py +140 -0
  158. flock/store.py +69 -0
  159. flock/subscription.py +111 -0
  160. flock/themes/andromeda.toml +1 -1
  161. flock/themes/apple-system-colors.toml +1 -1
  162. flock/themes/arcoiris.toml +1 -1
  163. flock/themes/atomonelight.toml +1 -1
  164. flock/themes/ayu copy.toml +1 -1
  165. flock/themes/ayu-light.toml +1 -1
  166. flock/themes/belafonte-day.toml +1 -1
  167. flock/themes/belafonte-night.toml +1 -1
  168. flock/themes/blulocodark.toml +1 -1
  169. flock/themes/breeze.toml +1 -1
  170. flock/themes/broadcast.toml +1 -1
  171. flock/themes/brogrammer.toml +1 -1
  172. flock/themes/builtin-dark.toml +1 -1
  173. flock/themes/builtin-pastel-dark.toml +1 -1
  174. flock/themes/catppuccin-latte.toml +1 -1
  175. flock/themes/catppuccin-macchiato.toml +1 -1
  176. flock/themes/catppuccin-mocha.toml +1 -1
  177. flock/themes/cga.toml +1 -1
  178. flock/themes/chalk.toml +1 -1
  179. flock/themes/ciapre.toml +1 -1
  180. flock/themes/coffee-theme.toml +1 -1
  181. flock/themes/cyberpunkscarletprotocol.toml +1 -1
  182. flock/themes/dark+.toml +1 -1
  183. flock/themes/darkermatrix.toml +1 -1
  184. flock/themes/darkside.toml +1 -1
  185. flock/themes/desert.toml +1 -1
  186. flock/themes/django.toml +1 -1
  187. flock/themes/djangosmooth.toml +1 -1
  188. flock/themes/doomone.toml +1 -1
  189. flock/themes/dotgov.toml +1 -1
  190. flock/themes/dracula+.toml +1 -1
  191. flock/themes/duckbones.toml +1 -1
  192. flock/themes/encom.toml +1 -1
  193. flock/themes/espresso.toml +1 -1
  194. flock/themes/everblush.toml +1 -1
  195. flock/themes/fairyfloss.toml +1 -1
  196. flock/themes/fideloper.toml +1 -1
  197. flock/themes/fishtank.toml +1 -1
  198. flock/themes/flexoki-light.toml +1 -1
  199. flock/themes/floraverse.toml +1 -1
  200. flock/themes/framer.toml +1 -1
  201. flock/themes/galizur.toml +1 -1
  202. flock/themes/github.toml +1 -1
  203. flock/themes/grass.toml +1 -1
  204. flock/themes/grey-green.toml +1 -1
  205. flock/themes/gruvboxlight.toml +1 -1
  206. flock/themes/guezwhoz.toml +1 -1
  207. flock/themes/harper.toml +1 -1
  208. flock/themes/hax0r-blue.toml +1 -1
  209. flock/themes/hopscotch.256.toml +1 -1
  210. flock/themes/ic-green-ppl.toml +1 -1
  211. flock/themes/iceberg-dark.toml +1 -1
  212. flock/themes/japanesque.toml +1 -1
  213. flock/themes/jubi.toml +1 -1
  214. flock/themes/kibble.toml +1 -1
  215. flock/themes/kolorit.toml +1 -1
  216. flock/themes/kurokula.toml +1 -1
  217. flock/themes/materialdesigncolors.toml +1 -1
  218. flock/themes/matrix.toml +1 -1
  219. flock/themes/mellifluous.toml +1 -1
  220. flock/themes/midnight-in-mojave.toml +1 -1
  221. flock/themes/monokai-remastered.toml +1 -1
  222. flock/themes/monokai-soda.toml +1 -1
  223. flock/themes/neon.toml +1 -1
  224. flock/themes/neopolitan.toml +1 -1
  225. flock/themes/nord-light.toml +1 -1
  226. flock/themes/ocean.toml +1 -1
  227. flock/themes/onehalfdark.toml +1 -1
  228. flock/themes/onehalflight.toml +1 -1
  229. flock/themes/palenighthc.toml +1 -1
  230. flock/themes/paulmillr.toml +1 -1
  231. flock/themes/pencildark.toml +1 -1
  232. flock/themes/pnevma.toml +1 -1
  233. flock/themes/purple-rain.toml +1 -1
  234. flock/themes/purplepeter.toml +1 -1
  235. flock/themes/raycast-dark.toml +1 -1
  236. flock/themes/red-sands.toml +1 -1
  237. flock/themes/relaxed.toml +1 -1
  238. flock/themes/retro.toml +1 -1
  239. flock/themes/rose-pine.toml +1 -1
  240. flock/themes/royal.toml +1 -1
  241. flock/themes/ryuuko.toml +1 -1
  242. flock/themes/sakura.toml +1 -1
  243. flock/themes/scarlet-protocol.toml +1 -1
  244. flock/themes/seoulbones-dark.toml +1 -1
  245. flock/themes/shades-of-purple.toml +1 -1
  246. flock/themes/smyck.toml +1 -1
  247. flock/themes/softserver.toml +1 -1
  248. flock/themes/solarized-darcula.toml +1 -1
  249. flock/themes/square.toml +1 -1
  250. flock/themes/sugarplum.toml +1 -1
  251. flock/themes/thayer-bright.toml +1 -1
  252. flock/themes/tokyonight.toml +1 -1
  253. flock/themes/tomorrow.toml +1 -1
  254. flock/themes/ubuntu.toml +1 -1
  255. flock/themes/ultradark.toml +1 -1
  256. flock/themes/ultraviolent.toml +1 -1
  257. flock/themes/unikitty.toml +1 -1
  258. flock/themes/urple.toml +1 -1
  259. flock/themes/vesper.toml +1 -1
  260. flock/themes/vimbones.toml +1 -1
  261. flock/themes/wildcherry.toml +1 -1
  262. flock/themes/wilmersdorf.toml +1 -1
  263. flock/themes/wryan.toml +1 -1
  264. flock/themes/xcodedarkhc.toml +1 -1
  265. flock/themes/xcodelight.toml +1 -1
  266. flock/themes/zenbones-light.toml +1 -1
  267. flock/themes/zenwritten-dark.toml +1 -1
  268. flock/utilities.py +301 -0
  269. flock/{components/utility → utility}/output_utility_component.py +68 -53
  270. flock/visibility.py +107 -0
  271. flock_core-0.5.0b51.dist-info/METADATA +747 -0
  272. flock_core-0.5.0b51.dist-info/RECORD +508 -0
  273. flock_core-0.5.0b51.dist-info/entry_points.txt +2 -0
  274. {flock_core-0.5.0b28.dist-info → flock_core-0.5.0b51.dist-info}/licenses/LICENSE +1 -1
  275. flock/adapter/__init__.py +0 -14
  276. flock/adapter/azure_adapter.py +0 -68
  277. flock/adapter/chroma_adapter.py +0 -73
  278. flock/adapter/faiss_adapter.py +0 -97
  279. flock/adapter/pinecone_adapter.py +0 -51
  280. flock/adapter/vector_base.py +0 -47
  281. flock/cli/assets/release_notes.md +0 -140
  282. flock/cli/config.py +0 -8
  283. flock/cli/constants.py +0 -36
  284. flock/cli/create_agent.py +0 -1
  285. flock/cli/create_flock.py +0 -280
  286. flock/cli/execute_flock.py +0 -620
  287. flock/cli/load_agent.py +0 -1
  288. flock/cli/load_examples.py +0 -1
  289. flock/cli/load_flock.py +0 -192
  290. flock/cli/load_release_notes.py +0 -20
  291. flock/cli/loaded_flock_cli.py +0 -254
  292. flock/cli/manage_agents.py +0 -459
  293. flock/cli/registry_management.py +0 -889
  294. flock/cli/runner.py +0 -41
  295. flock/cli/settings.py +0 -857
  296. flock/cli/utils.py +0 -135
  297. flock/cli/view_results.py +0 -29
  298. flock/cli/yaml_editor.py +0 -396
  299. flock/components/__init__.py +0 -30
  300. flock/components/evaluation/__init__.py +0 -9
  301. flock/components/evaluation/declarative_evaluation_component.py +0 -606
  302. flock/components/routing/__init__.py +0 -15
  303. flock/components/routing/conditional_routing_component.py +0 -494
  304. flock/components/routing/default_routing_component.py +0 -103
  305. flock/components/routing/llm_routing_component.py +0 -206
  306. flock/components/utility/__init__.py +0 -22
  307. flock/components/utility/example_utility_component.py +0 -250
  308. flock/components/utility/feedback_utility_component.py +0 -206
  309. flock/components/utility/memory_utility_component.py +0 -550
  310. flock/components/utility/metrics_utility_component.py +0 -700
  311. flock/config.py +0 -61
  312. flock/core/__init__.py +0 -110
  313. flock/core/agent/__init__.py +0 -16
  314. flock/core/agent/default_agent.py +0 -216
  315. flock/core/agent/flock_agent_components.py +0 -104
  316. flock/core/agent/flock_agent_execution.py +0 -101
  317. flock/core/agent/flock_agent_integration.py +0 -260
  318. flock/core/agent/flock_agent_lifecycle.py +0 -186
  319. flock/core/agent/flock_agent_serialization.py +0 -381
  320. flock/core/api/__init__.py +0 -10
  321. flock/core/api/custom_endpoint.py +0 -45
  322. flock/core/api/endpoints.py +0 -254
  323. flock/core/api/main.py +0 -162
  324. flock/core/api/models.py +0 -97
  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/component/__init__.py +0 -15
  329. flock/core/component/agent_component_base.py +0 -309
  330. flock/core/component/evaluation_component.py +0 -62
  331. flock/core/component/routing_component.py +0 -74
  332. flock/core/component/utility_component.py +0 -69
  333. flock/core/config/flock_agent_config.py +0 -58
  334. flock/core/config/scheduled_agent_config.py +0 -40
  335. flock/core/context/context.py +0 -213
  336. flock/core/context/context_manager.py +0 -37
  337. flock/core/context/context_vars.py +0 -10
  338. flock/core/evaluation/utils.py +0 -396
  339. flock/core/execution/batch_executor.py +0 -369
  340. flock/core/execution/evaluation_executor.py +0 -438
  341. flock/core/execution/local_executor.py +0 -31
  342. flock/core/execution/opik_executor.py +0 -103
  343. flock/core/execution/temporal_executor.py +0 -164
  344. flock/core/flock.py +0 -634
  345. flock/core/flock_agent.py +0 -336
  346. flock/core/flock_factory.py +0 -613
  347. flock/core/flock_scheduler.py +0 -166
  348. flock/core/flock_server_manager.py +0 -136
  349. flock/core/interpreter/python_interpreter.py +0 -689
  350. flock/core/mcp/__init__.py +0 -1
  351. flock/core/mcp/flock_mcp_server.py +0 -680
  352. flock/core/mcp/mcp_client_manager.py +0 -201
  353. flock/core/mcp/types/__init__.py +0 -1
  354. flock/core/mixin/dspy_integration.py +0 -403
  355. flock/core/mixin/prompt_parser.py +0 -125
  356. flock/core/orchestration/__init__.py +0 -15
  357. flock/core/orchestration/flock_batch_processor.py +0 -94
  358. flock/core/orchestration/flock_evaluator.py +0 -113
  359. flock/core/orchestration/flock_execution.py +0 -295
  360. flock/core/orchestration/flock_initialization.py +0 -149
  361. flock/core/orchestration/flock_server_manager.py +0 -67
  362. flock/core/orchestration/flock_web_server.py +0 -117
  363. flock/core/registry/__init__.py +0 -45
  364. flock/core/registry/agent_registry.py +0 -69
  365. flock/core/registry/callable_registry.py +0 -139
  366. flock/core/registry/component_discovery.py +0 -142
  367. flock/core/registry/component_registry.py +0 -64
  368. flock/core/registry/config_mapping.py +0 -64
  369. flock/core/registry/decorators.py +0 -137
  370. flock/core/registry/registry_hub.py +0 -205
  371. flock/core/registry/server_registry.py +0 -57
  372. flock/core/registry/type_registry.py +0 -86
  373. flock/core/serialization/__init__.py +0 -13
  374. flock/core/serialization/callable_registry.py +0 -52
  375. flock/core/serialization/flock_serializer.py +0 -832
  376. flock/core/serialization/json_encoder.py +0 -41
  377. flock/core/serialization/secure_serializer.py +0 -175
  378. flock/core/serialization/serializable.py +0 -342
  379. flock/core/serialization/serialization_utils.py +0 -412
  380. flock/core/util/file_path_utils.py +0 -223
  381. flock/core/util/hydrator.py +0 -309
  382. flock/core/util/input_resolver.py +0 -164
  383. flock/core/util/loader.py +0 -59
  384. flock/core/util/splitter.py +0 -219
  385. flock/di.py +0 -27
  386. flock/platform/docker_tools.py +0 -49
  387. flock/platform/jaeger_install.py +0 -86
  388. flock/webapp/__init__.py +0 -1
  389. flock/webapp/app/__init__.py +0 -0
  390. flock/webapp/app/api/__init__.py +0 -0
  391. flock/webapp/app/api/agent_management.py +0 -241
  392. flock/webapp/app/api/execution.py +0 -709
  393. flock/webapp/app/api/flock_management.py +0 -129
  394. flock/webapp/app/api/registry_viewer.py +0 -30
  395. flock/webapp/app/chat.py +0 -665
  396. flock/webapp/app/config.py +0 -104
  397. flock/webapp/app/dependencies.py +0 -117
  398. flock/webapp/app/main.py +0 -1070
  399. flock/webapp/app/middleware.py +0 -113
  400. flock/webapp/app/models_ui.py +0 -7
  401. flock/webapp/app/services/__init__.py +0 -0
  402. flock/webapp/app/services/feedback_file_service.py +0 -363
  403. flock/webapp/app/services/flock_service.py +0 -337
  404. flock/webapp/app/services/sharing_models.py +0 -81
  405. flock/webapp/app/services/sharing_store.py +0 -762
  406. flock/webapp/app/templates/theme_mapper.html +0 -326
  407. flock/webapp/app/theme_mapper.py +0 -812
  408. flock/webapp/app/utils.py +0 -85
  409. flock/webapp/run.py +0 -215
  410. flock/webapp/static/css/chat.css +0 -301
  411. flock/webapp/static/css/components.css +0 -167
  412. flock/webapp/static/css/header.css +0 -39
  413. flock/webapp/static/css/layout.css +0 -46
  414. flock/webapp/static/css/sidebar.css +0 -127
  415. flock/webapp/static/css/two-pane.css +0 -48
  416. flock/webapp/templates/base.html +0 -200
  417. flock/webapp/templates/chat.html +0 -152
  418. flock/webapp/templates/chat_settings.html +0 -19
  419. flock/webapp/templates/flock_editor.html +0 -16
  420. flock/webapp/templates/index.html +0 -12
  421. flock/webapp/templates/partials/_agent_detail_form.html +0 -93
  422. flock/webapp/templates/partials/_agent_list.html +0 -18
  423. flock/webapp/templates/partials/_agent_manager_view.html +0 -51
  424. flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
  425. flock/webapp/templates/partials/_chat_container.html +0 -15
  426. flock/webapp/templates/partials/_chat_messages.html +0 -57
  427. flock/webapp/templates/partials/_chat_settings_form.html +0 -85
  428. flock/webapp/templates/partials/_create_flock_form.html +0 -50
  429. flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
  430. flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
  431. flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
  432. flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
  433. flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
  434. flock/webapp/templates/partials/_env_vars_table.html +0 -23
  435. flock/webapp/templates/partials/_execution_form.html +0 -118
  436. flock/webapp/templates/partials/_execution_view_container.html +0 -28
  437. flock/webapp/templates/partials/_flock_file_list.html +0 -23
  438. flock/webapp/templates/partials/_flock_properties_form.html +0 -52
  439. flock/webapp/templates/partials/_flock_upload_form.html +0 -16
  440. flock/webapp/templates/partials/_header_flock_status.html +0 -5
  441. flock/webapp/templates/partials/_load_manager_view.html +0 -49
  442. flock/webapp/templates/partials/_registry_table.html +0 -25
  443. flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
  444. flock/webapp/templates/partials/_results_display.html +0 -78
  445. flock/webapp/templates/partials/_settings_env_content.html +0 -9
  446. flock/webapp/templates/partials/_settings_theme_content.html +0 -14
  447. flock/webapp/templates/partials/_settings_view.html +0 -36
  448. flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
  449. flock/webapp/templates/partials/_share_link_snippet.html +0 -35
  450. flock/webapp/templates/partials/_sidebar.html +0 -74
  451. flock/webapp/templates/partials/_streaming_results_container.html +0 -195
  452. flock/webapp/templates/partials/_structured_data_view.html +0 -40
  453. flock/webapp/templates/partials/_theme_preview.html +0 -36
  454. flock/webapp/templates/registry_viewer.html +0 -84
  455. flock/webapp/templates/shared_run_page.html +0 -140
  456. flock/workflow/__init__.py +0 -0
  457. flock/workflow/activities.py +0 -196
  458. flock/workflow/agent_activities.py +0 -24
  459. flock/workflow/agent_execution_activity.py +0 -202
  460. flock/workflow/flock_workflow.py +0 -214
  461. flock/workflow/temporal_config.py +0 -96
  462. flock/workflow/temporal_setup.py +0 -68
  463. flock_core-0.5.0b28.dist-info/METADATA +0 -274
  464. flock_core-0.5.0b28.dist-info/RECORD +0 -561
  465. flock_core-0.5.0b28.dist-info/entry_points.txt +0 -2
  466. /flock/{core/logging → logging}/formatters/themes.py +0 -0
  467. /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
  468. /flock/{core/mcp → mcp}/util/__init__.py +0 -0
  469. {flock_core-0.5.0b28.dist-info → flock_core-0.5.0b51.dist-info}/WHEEL +0 -0
@@ -1,125 +0,0 @@
1
- """A mixin class for parsing agent prompts and building clean signatures for DSPy."""
2
-
3
- # DEPRECATED! This mixin is no longer used in the current version of Flock. It was used to parse agent prompts and build clean signatures for DSPy.
4
- # TODO: DELETE THIS FILE!
5
-
6
- from flock.core.util.input_resolver import split_top_level
7
-
8
-
9
- class PromptParserMixin:
10
- """A mixin class for parsing agent prompts and building clean signatures for DSPy."""
11
-
12
- def _parse_key_descriptions(self, keys_str: str) -> list[tuple[str, str]]:
13
- """Parse a comma-separated string into a list of (key, description) tuples.
14
-
15
- This function processes a configuration string that defines one or more keys, where each key may
16
- include a type hint and an optional human-readable description. The expected format for each key is:
17
-
18
- key: type_hint | description
19
-
20
- If the pipe symbol ("|") is absent, the description is set to an empty string.
21
-
22
- The splitting is performed using split_top_level() so that commas inside type hints are preserved.
23
-
24
- For example, given:
25
- "query: str | The search query, context: dict | The full conversation context"
26
- it returns:
27
- [("query", "The search query"), ("context", "The full conversation context")]
28
-
29
- Args:
30
- keys_str (str): A comma-separated string of key definitions.
31
-
32
- Returns:
33
- List[Tuple[str, str]]: A list of (key, description) tuples.
34
- """
35
- key_descs = []
36
- for part in split_top_level(keys_str):
37
- if not part:
38
- continue
39
- if "|" in part:
40
- key_type_part, desc = part.split("|", 1)
41
- desc = desc.strip()
42
- else:
43
- key_type_part = part
44
- desc = ""
45
- key = key_type_part.split(":", 1)[0].strip()
46
- key_descs.append((key, desc))
47
- return key_descs
48
-
49
- def _build_clean_signature(self, keys_str: str) -> str:
50
- """Build a clean signature string from the configuration string by removing the description parts.
51
-
52
- Given a string like:
53
- "query: str | The search query, context: dict | The full conversation context"
54
- this method returns:
55
- "query: str, context: dict"
56
-
57
- This function uses split_top_level() to avoid splitting on commas that are inside type hints.
58
-
59
- Args:
60
- keys_str (str): The configuration string containing keys, type hints, and optional descriptions.
61
-
62
- Returns:
63
- str: A clean signature string with only keys and type hints.
64
- """
65
- parts = []
66
- for part in split_top_level(keys_str):
67
- if not part:
68
- continue
69
- if "|" in part:
70
- clean_part = part.split("|", 1)[0].strip()
71
- else:
72
- clean_part = part.strip()
73
- parts.append(clean_part)
74
- return ", ".join(parts)
75
-
76
- def _build_descriptions(self) -> tuple[dict[str, str], dict[str, str]]:
77
- """Build dictionaries of input and output descriptions from the agent's configuration.
78
-
79
- Returns:
80
- A tuple containing:
81
- - input_desc: A dictionary mapping each input key (without type hints) to its description.
82
- - output_desc: A dictionary mapping each output key (without type hints) to its description.
83
- """
84
- input_desc: dict[str, str] = {}
85
- if self.input:
86
- for key, desc in self._parse_key_descriptions(self.input):
87
- input_desc[key] = desc
88
-
89
- output_desc: dict[str, str] = {}
90
- if self.output:
91
- for key, desc in self._parse_key_descriptions(self.output):
92
- output_desc[key] = desc
93
-
94
- return input_desc, output_desc
95
-
96
- def _build_prompt(
97
- self, input_desc: dict[str, str], output_desc: dict[str, str]
98
- ) -> str:
99
- """Build a clean signature prompt from the agent's configuration.
100
-
101
- This method uses the original input and output strings (removing the description parts)
102
- to create a signature string that is passed to DSPy. For example, if:
103
- - self.input is "query: str | The search query, context: dict | The full conversation context"
104
- - self.output is "result: str | The result"
105
- then the prompt will be:
106
- "query: str, context: dict -> result: str"
107
-
108
- **Note:** The descriptive metadata is preserved in the dictionaries obtained from _build_descriptions,
109
- which are passed separately to DSPy.
110
-
111
- Args:
112
- input_desc: Dictionary of input key descriptions (for metadata only).
113
- output_desc: Dictionary of output key descriptions (for metadata only).
114
-
115
- Returns:
116
- A clean signature string for DSPy.
117
- """
118
- clean_input = (
119
- self._build_clean_signature(self.input) if self.input else ""
120
- )
121
- clean_output = (
122
- self._build_clean_signature(self.output) if self.output else ""
123
- )
124
- # Combine the clean input and output signatures using "->"
125
- return f"{clean_input} -> {clean_output}"
@@ -1,15 +0,0 @@
1
- # src/flock/core/orchestration/__init__.py
2
- """Orchestration package public API.
3
-
4
- Avoid importing submodules at package import time to prevent heavy side effects
5
- and keep tests fast and deterministic. Import modules directly where needed.
6
- """
7
-
8
- __all__ = [
9
- "FlockExecution",
10
- "FlockServerManager",
11
- "FlockBatchProcessor",
12
- "FlockEvaluator",
13
- "FlockWebServer",
14
- "FlockInitialization",
15
- ]
@@ -1,94 +0,0 @@
1
- # src/flock/core/orchestration/flock_batch_processor.py
2
- """Batch processing functionality for Flock orchestrator."""
3
-
4
- from typing import TYPE_CHECKING, Any
5
-
6
- from box import Box
7
- from pandas import DataFrame
8
-
9
- from flock.core.logging.logging import get_logger
10
-
11
- if TYPE_CHECKING:
12
- from flock.core.flock import Flock
13
- from flock.core.flock_agent import FlockAgent
14
-
15
- logger = get_logger("flock.batch_processor")
16
-
17
-
18
- class FlockBatchProcessor:
19
- """Handles batch processing functionality for Flock orchestrator."""
20
-
21
- def __init__(self, flock: "Flock"):
22
- self.flock = flock
23
-
24
- async def run_batch_async(
25
- self,
26
- start_agent: "FlockAgent | str",
27
- batch_inputs: list[dict[str, Any]] | DataFrame | str,
28
- input_mapping: dict[str, str] | None = None,
29
- static_inputs: dict[str, Any] | None = None,
30
- parallel: bool = True,
31
- max_workers: int = 5,
32
- use_temporal: bool | None = None,
33
- box_results: bool = True,
34
- return_errors: bool = False,
35
- silent_mode: bool = False,
36
- write_to_csv: str | None = None,
37
- hide_columns: list[str] | None = None,
38
- delimiter: str = ",",
39
- ) -> list[Box | dict | None | Exception]:
40
- """Runs the specified agent/workflow for each item in a batch asynchronously (delegated)."""
41
- # Import processor locally
42
- from flock.core.execution.batch_executor import BatchProcessor
43
-
44
- processor = BatchProcessor(self.flock) # Pass flock instance
45
- return await processor.run_batch_async(
46
- start_agent=start_agent,
47
- batch_inputs=batch_inputs,
48
- input_mapping=input_mapping,
49
- static_inputs=static_inputs,
50
- parallel=parallel,
51
- max_workers=max_workers,
52
- use_temporal=use_temporal,
53
- box_results=box_results,
54
- return_errors=return_errors,
55
- silent_mode=silent_mode,
56
- write_to_csv=write_to_csv,
57
- hide_columns=hide_columns,
58
- delimiter=delimiter,
59
- )
60
-
61
- def run_batch(
62
- self,
63
- start_agent: "FlockAgent | str",
64
- batch_inputs: list[dict[str, Any]] | DataFrame | str,
65
- input_mapping: dict[str, str] | None = None,
66
- static_inputs: dict[str, Any] | None = None,
67
- parallel: bool = True,
68
- max_workers: int = 5,
69
- use_temporal: bool | None = None,
70
- box_results: bool = True,
71
- return_errors: bool = False,
72
- silent_mode: bool = False,
73
- write_to_csv: str | None = None,
74
- hide_columns: list[str] | None = None,
75
- delimiter: str = ",",
76
- ) -> list[Box | dict | None | Exception]:
77
- """Synchronous wrapper for batch processing."""
78
- return self.flock._execution._run_sync(
79
- self.run_batch_async(
80
- start_agent=start_agent,
81
- batch_inputs=batch_inputs,
82
- input_mapping=input_mapping,
83
- static_inputs=static_inputs,
84
- parallel=parallel,
85
- max_workers=max_workers,
86
- use_temporal=use_temporal,
87
- box_results=box_results,
88
- return_errors=return_errors,
89
- silent_mode=silent_mode,
90
- write_to_csv=write_to_csv,
91
- hide_columns=hide_columns,
92
- delimiter=delimiter,
93
- )
94
- )
@@ -1,113 +0,0 @@
1
- # src/flock/core/orchestration/flock_evaluator.py
2
- """Evaluation functionality for Flock orchestrator."""
3
-
4
- from collections.abc import Callable
5
- from pathlib import Path
6
- from typing import TYPE_CHECKING, Any, Literal
7
-
8
- from datasets import Dataset
9
- from pandas import DataFrame
10
-
11
- from flock.core.flock_agent import FlockAgent
12
- from flock.core.logging.logging import get_logger
13
-
14
- if TYPE_CHECKING:
15
- from flock.core.flock import Flock
16
-
17
-
18
- logger = get_logger("flock.evaluator")
19
-
20
-
21
- class FlockEvaluator:
22
- """Handles evaluation functionality for Flock orchestrator."""
23
-
24
- def __init__(self, flock: "Flock"):
25
- self.flock = flock
26
-
27
- async def evaluate_async(
28
- self,
29
- dataset: str | Path | list[dict[str, Any]] | DataFrame | Dataset,
30
- start_agent: FlockAgent | str,
31
- input_mapping: dict[str, str],
32
- answer_mapping: dict[str, str],
33
- metrics: list[
34
- str
35
- | Callable[[Any, Any], bool | float | dict[str, Any]]
36
- | FlockAgent
37
- ],
38
- metric_configs: dict[str, dict[str, Any]] | None = None,
39
- static_inputs: dict[str, Any] | None = None,
40
- parallel: bool = True,
41
- max_workers: int = 5,
42
- use_temporal: bool | None = None,
43
- error_handling: Literal["raise", "skip", "log"] = "log",
44
- output_file: str | Path | None = None,
45
- return_dataframe: bool = True,
46
- silent_mode: bool = False,
47
- metadata_columns: list[str] | None = None,
48
- ) -> "DataFrame | list[dict[str, Any]]":
49
- """Evaluates the Flock's performance against a dataset (delegated)."""
50
- # Import processor locally
51
- from flock.core.execution.evaluation_executor import EvaluationExecutor
52
-
53
- processor = EvaluationExecutor(self.flock) # Pass flock instance
54
- return await processor.evaluate_async(
55
- dataset=dataset,
56
- start_agent=start_agent,
57
- input_mapping=input_mapping,
58
- answer_mapping=answer_mapping,
59
- metrics=metrics,
60
- metric_configs=metric_configs,
61
- static_inputs=static_inputs,
62
- parallel=parallel,
63
- max_workers=max_workers,
64
- use_temporal=use_temporal,
65
- error_handling=error_handling,
66
- output_file=output_file,
67
- return_dataframe=return_dataframe,
68
- silent_mode=silent_mode,
69
- metadata_columns=metadata_columns,
70
- )
71
-
72
- def evaluate(
73
- self,
74
- dataset: str | Path | list[dict[str, Any]] | DataFrame | Dataset,
75
- start_agent: FlockAgent | str,
76
- input_mapping: dict[str, str],
77
- answer_mapping: dict[str, str],
78
- metrics: list[
79
- str
80
- | Callable[[Any, Any], bool | float | dict[str, Any]]
81
- | FlockAgent
82
- ],
83
- metric_configs: dict[str, dict[str, Any]] | None = None,
84
- static_inputs: dict[str, Any] | None = None,
85
- parallel: bool = True,
86
- max_workers: int = 5,
87
- use_temporal: bool | None = None,
88
- error_handling: Literal["raise", "skip", "log"] = "log",
89
- output_file: str | Path | None = None,
90
- return_dataframe: bool = True,
91
- silent_mode: bool = False,
92
- metadata_columns: list[str] | None = None,
93
- ) -> "DataFrame | list[dict[str, Any]]":
94
- """Synchronous wrapper for evaluation."""
95
- return self.flock._execution._run_sync(
96
- self.evaluate_async(
97
- dataset=dataset,
98
- start_agent=start_agent,
99
- input_mapping=input_mapping,
100
- answer_mapping=answer_mapping,
101
- metrics=metrics,
102
- metric_configs=metric_configs,
103
- static_inputs=static_inputs,
104
- parallel=parallel,
105
- max_workers=max_workers,
106
- use_temporal=use_temporal,
107
- error_handling=error_handling,
108
- output_file=output_file,
109
- return_dataframe=return_dataframe,
110
- silent_mode=silent_mode,
111
- metadata_columns=metadata_columns,
112
- )
113
- )
@@ -1,295 +0,0 @@
1
- # src/flock/core/orchestration/flock_execution.py
2
- """Execution management functionality for Flock orchestrator."""
3
-
4
- import asyncio
5
- import contextvars
6
- import uuid
7
- from concurrent.futures import ThreadPoolExecutor
8
- from typing import TYPE_CHECKING, Any, TypeVar
9
-
10
- from box import Box
11
- from opentelemetry import trace
12
- from opentelemetry.baggage import set_baggage
13
-
14
- from flock.config import DEFAULT_MODEL
15
- from flock.core.context.context import FlockContext
16
- from flock.core.context.context_manager import initialize_context
17
- from flock.core.execution.local_executor import run_local_workflow
18
- from flock.core.execution.temporal_executor import run_temporal_workflow
19
- from flock.core.logging.logging import get_logger
20
-
21
- if TYPE_CHECKING:
22
- from flock.core.flock import Flock
23
- from flock.core.flock_agent import FlockAgent
24
-
25
- logger = get_logger("flock.execution")
26
- tracer = trace.get_tracer(__name__)
27
- _R = TypeVar("_R")
28
-
29
-
30
- class FlockExecution:
31
- """Handles execution management for Flock including run, run_async, and execution coordination."""
32
-
33
- def __init__(self, flock: "Flock"):
34
- self.flock = flock
35
-
36
- def _run_sync(self, coro) -> _R:
37
- """Execute *coro* synchronously.
38
-
39
- * If no loop is running → ``asyncio.run``.
40
- * Otherwise run ``asyncio.run`` inside a fresh thread **with**
41
- context-vars propagation.
42
- """
43
- try:
44
- asyncio.get_running_loop()
45
- except RuntimeError: # no loop → simple
46
- return asyncio.run(coro)
47
-
48
- # A loop is already running – Jupyter / ASGI / etc.
49
- ctx = contextvars.copy_context() # propagate baggage
50
- with ThreadPoolExecutor(max_workers=1) as pool:
51
- future = pool.submit(ctx.run, asyncio.run, coro)
52
- try:
53
- return future.result()
54
- finally:
55
- if not future.done():
56
- future.cancel()
57
-
58
- def run(
59
- self,
60
- agent: "FlockAgent | str | None" = None,
61
- input: dict | None = None,
62
- context: FlockContext | None = None,
63
- run_id: str = "",
64
- box_result: bool = True,
65
- agents: list["FlockAgent"] | None = None,
66
- servers: list[Any] | None = None,
67
- memo: dict[str, Any] | None = None,
68
- ) -> Box | dict:
69
- """Synchronous execution wrapper."""
70
- return self._run_sync(
71
- self.run_async(
72
- agent=agent,
73
- input=input,
74
- context=context,
75
- run_id=run_id,
76
- box_result=box_result,
77
- agents=agents,
78
- servers=servers,
79
- memo=memo,
80
- )
81
- )
82
-
83
- async def run_async(
84
- self,
85
- agent: "FlockAgent | str | None" = None,
86
- input: dict | None = None,
87
- context: FlockContext | None = None,
88
- run_id: str = "",
89
- box_result: bool = True,
90
- agents: list["FlockAgent"] | None = None,
91
- servers: list[Any] | None = None,
92
- memo: dict[str, Any] | None = None,
93
- ) -> Box | dict:
94
- """Entry point for running an agent system asynchronously."""
95
- # Import here to allow forward reference resolution
96
- from flock.core.flock_agent import FlockAgent as ConcreteFlockAgent
97
- from flock.core.mcp.flock_mcp_server import (
98
- FlockMCPServer as ConcreteFlockServer,
99
- )
100
-
101
- with tracer.start_as_current_span("flock.run_async") as span:
102
- # Add passed servers so that agents have access to them.
103
- if servers:
104
- for server_obj in servers:
105
- if isinstance(server_obj, ConcreteFlockServer):
106
- self.flock.add_server(server=server_obj)
107
- else:
108
- logger.warning(
109
- f"Item in 'servers' list is not a FlockMCPServer: {type(server_obj)}"
110
- )
111
-
112
- # Add passed agents
113
- if agents:
114
- for agent_obj in agents:
115
- if isinstance(agent_obj, ConcreteFlockAgent):
116
- self.flock.add_agent(agent_obj)
117
- else:
118
- logger.warning(
119
- f"Item in 'agents' list is not a FlockAgent: {type(agent_obj)}"
120
- )
121
-
122
- # Determine starting agent name
123
- start_agent_name = self._resolve_start_agent(agent)
124
-
125
- # Setup execution context and input
126
- run_input = input if input is not None else self.flock._start_input
127
- # Accept Pydantic BaseModel instances as input by converting to dict
128
- try:
129
- from pydantic import BaseModel as _BM
130
- if not isinstance(run_input, dict) and isinstance(run_input, _BM):
131
- run_input = run_input.model_dump(exclude_none=True) # type: ignore[attr-defined]
132
- except Exception:
133
- pass
134
- effective_run_id = run_id or f"flockrun_{uuid.uuid4().hex[:8]}"
135
-
136
- # Set span attributes
137
- span.set_attribute("start_agent", start_agent_name)
138
- span.set_attribute("input", str(run_input))
139
- span.set_attribute("run_id", effective_run_id)
140
- span.set_attribute("enable_temporal", self.flock.enable_temporal)
141
-
142
- logger.info(
143
- f"Initiating Flock run '{self.flock.name}'. Model: '{self.flock.model}'. Start Agent: '{start_agent_name}'. Temporal: {self.flock.enable_temporal}."
144
- )
145
-
146
- try:
147
- # Setup execution context
148
- run_context = self._setup_execution_context(
149
- context, start_agent_name, run_input, effective_run_id
150
- )
151
-
152
- # Execute workflow with server management
153
- async with self.flock._mgr:
154
- logger.info("Entering managed server context. Servers starting up.")
155
- logger.info(
156
- "Starting agent execution",
157
- agent=start_agent_name,
158
- enable_temporal=self.flock.enable_temporal,
159
- )
160
-
161
- # Execute workflow using appropriate engine
162
- result = await self._execute_workflow(run_context, memo)
163
-
164
- # Set result attributes on span
165
- span.set_attribute("result.type", str(type(result)))
166
- result_str = str(result)
167
- span.set_attribute(
168
- "result.preview",
169
- result_str[:1000] + ("..." if len(result_str) > 1000 else ""),
170
- )
171
-
172
- # Format and return result
173
- return self._format_result(result, box_result)
174
-
175
- except Exception as e:
176
- logger.error(f"Flock run '{self.flock.name}' failed: {e}", exc_info=True)
177
- span.record_exception(e)
178
- span.set_status(trace.Status(trace.StatusCode.ERROR, str(e)))
179
-
180
- # Return a consistent error structure
181
- error_output = {
182
- "error": str(e),
183
- "details": f"Flock run '{self.flock.name}' failed.",
184
- "run_id": effective_run_id,
185
- "start_agent": start_agent_name,
186
- }
187
- return Box(error_output) if box_result else error_output
188
-
189
- def _resolve_start_agent(self, agent: "FlockAgent | str | None") -> str:
190
- """Resolve the start agent name from various input types."""
191
- from flock.core.flock_agent import FlockAgent as ConcreteFlockAgent
192
- from flock.core.registry import get_registry
193
-
194
- registry = get_registry()
195
-
196
- # Determine starting agent name
197
- start_agent_name: str | None = None
198
- if isinstance(agent, ConcreteFlockAgent):
199
- start_agent_name = agent.name
200
- if start_agent_name not in self.flock._agents: # Add if not already present
201
- self.flock.add_agent(agent)
202
- elif isinstance(agent, str):
203
- start_agent_name = agent
204
- else: # start_agent is None
205
- start_agent_name = self.flock._start_agent_name
206
-
207
- # Default to first agent if only one exists and none specified
208
- if not start_agent_name and len(self.flock._agents) == 1:
209
- start_agent_name = next(iter(self.flock._agents.keys()))
210
- elif not start_agent_name:
211
- raise ValueError(
212
- "No start_agent specified and multiple/no agents exist in the Flock instance."
213
- )
214
-
215
- # Check if start_agent is in agents
216
- if start_agent_name not in self.flock._agents:
217
- # Try loading from registry if not found locally yet
218
- reg_agent = registry.get_agent(start_agent_name)
219
- if reg_agent:
220
- self.flock.add_agent(reg_agent)
221
- logger.info(f"Loaded start agent '{start_agent_name}' from registry.")
222
- else:
223
- raise ValueError(
224
- f"Start agent '{start_agent_name}' not found locally or in registry."
225
- )
226
-
227
- return start_agent_name
228
-
229
- def _setup_execution_context(
230
- self,
231
- context: FlockContext | None,
232
- start_agent_name: str,
233
- run_input: dict,
234
- run_id: str,
235
- ) -> FlockContext:
236
- """Setup the execution context for the workflow."""
237
- resolved_start_agent = self.flock._agents.get(start_agent_name)
238
- if not resolved_start_agent: # Should have been handled by now
239
- raise ValueError(f"Start agent '{start_agent_name}' not found after checks.")
240
-
241
- run_context = context if context else FlockContext()
242
- set_baggage("run_id", run_id) # Set for OpenTelemetry
243
-
244
- initialize_context(
245
- run_context,
246
- start_agent_name,
247
- run_input,
248
- run_id,
249
- not self.flock.enable_temporal, # local_debug is inverse of enable_temporal
250
- self.flock.model or resolved_start_agent.model or DEFAULT_MODEL,
251
- )
252
-
253
- # Add agent definitions to context for routing/serialization within workflow
254
- for agent_name_iter, agent_instance_iter in self.flock.agents.items():
255
- agent_dict_repr = agent_instance_iter.to_dict() # Agents handle their own serialization
256
- run_context.add_agent_definition(
257
- agent_type=type(agent_instance_iter),
258
- agent_name=agent_name_iter,
259
- agent_data=agent_dict_repr,
260
- )
261
-
262
- # Add temporal config to context if enabled
263
- if self.flock.enable_temporal and self.flock.temporal_config:
264
- run_context.set_variable(
265
- "flock.temporal_workflow_config",
266
- self.flock.temporal_config.model_dump(mode="json"),
267
- )
268
-
269
- return run_context
270
-
271
- async def _execute_workflow(
272
- self, run_context: FlockContext, memo: dict[str, Any] | None = None
273
- ) -> dict[str, Any]:
274
- """Execute the workflow using the appropriate execution engine."""
275
- if not self.flock.enable_temporal:
276
- return await run_local_workflow(run_context, box_result=False)
277
- else:
278
- return await run_temporal_workflow(
279
- self.flock, # Pass the Flock instance
280
- run_context,
281
- box_result=False,
282
- memo=memo,
283
- )
284
-
285
- def _format_result(self, result: dict[str, Any], box_result: bool) -> Box | dict:
286
- """Format the execution result."""
287
- if box_result:
288
- try:
289
- logger.debug("Boxing final result.")
290
- return Box(result)
291
- except ImportError:
292
- logger.warning("Box library not installed, returning raw dict.")
293
- return result
294
- else:
295
- return result