flock-core 0.4.543__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.543.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.543.dist-info/METADATA +0 -676
  496. flock_core-0.4.543.dist-info/RECORD +0 -572
  497. flock_core-0.4.543.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.543.dist-info → flock_core-0.5.0.dist-info}/WHEEL +0 -0
@@ -1,192 +0,0 @@
1
- import uuid
2
- from typing import Any
3
-
4
- from pydantic import Field
5
- from zep_python.client import Zep
6
- from zep_python.types import Message as ZepMessage, SessionSearchResult
7
-
8
- from flock.core.context.context import FlockContext
9
- from flock.core.flock_agent import FlockAgent
10
- from flock.core.flock_module import FlockModule, FlockModuleConfig
11
- from flock.core.flock_registry import flock_component
12
- from flock.core.logging.logging import get_logger
13
-
14
- logger = get_logger("module.zep")
15
-
16
-
17
- class ZepModuleConfig(FlockModuleConfig):
18
- """Configuration for the Zep module."""
19
-
20
- zep_url: str = "http://localhost:8000"
21
- zep_api_key: str = "apikey"
22
- min_fact_rating: float = Field(
23
- default=0.7, description="Minimum rating for facts to be considered"
24
- )
25
- enable_read: bool = True
26
- enable_write: bool = False
27
- top_k: int = Field(default=10, description="Number of memories to retrieve")
28
- user_id: str = Field(default="flock", description="User ID the memories will be associated with")
29
- agent_id: str = Field(default="flock", description="Agent ID the memories will be associated with")
30
- memory_input_key: str | None = Field(default=None, description="Input key to use for memory, if none the description of the agent will be used")
31
-
32
-
33
-
34
- @flock_component(config_class=ZepModuleConfig)
35
- class ZepModule(FlockModule):
36
- """Module that adds Zep capabilities to a Flock agent."""
37
-
38
- name: str = "zep"
39
- config: ZepModuleConfig = ZepModuleConfig()
40
- session_id: str | None = None
41
- user_id: str | None = None
42
-
43
- def __init__(self, name, config: ZepModuleConfig) -> None:
44
- """Initialize Zep module."""
45
- super().__init__(name=name, config=config)
46
- logger.debug("Initializing Zep module")
47
- zep_client = Zep(
48
- base_url=self.config.zep_url, api_key=self.config.zep_api_key
49
- )
50
- self.user_id = self.name
51
- self._setup_user(zep_client)
52
- self.session_id = str(uuid.uuid4())
53
- self._setup_session(zep_client)
54
-
55
- def _setup_user(self, zep_client: Zep) -> None:
56
- """Set up user in Zep."""
57
- if not zep_client or not self.user_id:
58
- raise ValueError("Zep service or user_id not initialized")
59
-
60
- try:
61
- user = zep_client.user.get(user_id=self.user_id)
62
- if not user:
63
- zep_client.user.add(user_id=self.user_id)
64
- except Exception:
65
- zep_client.user.add(user_id=self.user_id)
66
-
67
- def _setup_session(self, zep_client: Zep) -> None:
68
- """Set up new session."""
69
- if not zep_client or not self.user_id or not self.session_id:
70
- raise ValueError(
71
- "Zep service, user_id, or session_id not initialized"
72
- )
73
-
74
- zep_client.memory.add_session(
75
- user_id=self.user_id,
76
- session_id=self.session_id,
77
- )
78
-
79
- def get_client(self) -> Zep:
80
- """Get Zep client."""
81
- return Zep(
82
- base_url=self.config.zep_url, api_key=self.config.zep_api_key
83
- )
84
-
85
- def get_memory(self, zep_client: Zep) -> str | None:
86
- """Get memory for the current session."""
87
- if not zep_client or not self.session_id:
88
- logger.error("Zep service or session_id not initialized")
89
- return None
90
-
91
- try:
92
- memory = zep_client.memory.get(
93
- self.session_id, min_rating=self.config.min_fact_rating
94
- )
95
- if memory:
96
- return f"{memory.relevant_facts}"
97
- except Exception as e:
98
- logger.error(f"Error fetching memory: {e}")
99
- return None
100
-
101
- return None
102
-
103
- def split_text(
104
- self, text: str | None, max_length: int = 1000
105
- ) -> list[ZepMessage]:
106
- """Split text into smaller chunks."""
107
- result: list[ZepMessage] = []
108
- if not text:
109
- return result
110
- if len(text) <= max_length:
111
- return [ZepMessage(role="user", content=text, role_type="user")]
112
- for i in range(0, len(text), max_length):
113
- result.append(
114
- ZepMessage(
115
- role="user",
116
- content=text[i : i + max_length],
117
- role_type="user",
118
- )
119
- )
120
- return result
121
-
122
- def add_to_memory(self, text: str, zep_client: Zep) -> None:
123
- """Add text to memory."""
124
- if not zep_client or not self.session_id:
125
- logger.error("Zep service or session_id not initialized")
126
- return
127
-
128
- messages = self.split_text(text)
129
- zep_client.memory.add(session_id=self.session_id, messages=messages)
130
-
131
- def search_memory(
132
- self, query: str, zep_client: Zep
133
- ) -> list[SessionSearchResult]:
134
- """Search memory for a query."""
135
- if not zep_client or not self.user_id:
136
- logger.error("Zep service or user_id not initialized")
137
- return []
138
-
139
- response = zep_client.memory.search_sessions(
140
- text=query,
141
- user_id=self.user_id,
142
- search_scope="facts",
143
- min_fact_rating=self.config.min_fact_rating,
144
- )
145
- if not response.results:
146
- return []
147
- return response.results
148
-
149
- async def on_post_evaluate(
150
- self,
151
- agent: FlockAgent,
152
- inputs: dict[str, Any],
153
- context: FlockContext | None = None,
154
- result: dict[str, Any] | None = None,
155
- ) -> dict[str, Any]:
156
- """Format and display the output."""
157
- if not self.config.enable_write:
158
- return result
159
- logger.debug("Saving data to memory")
160
- zep_client = Zep(
161
- base_url=self.config.zep_url, api_key=self.config.zep_api_key
162
- )
163
- self.add_to_memory(str(result), zep_client)
164
- return result
165
-
166
- async def on_pre_evaluate(
167
- self,
168
- agent: FlockAgent,
169
- inputs: dict[str, Any],
170
- context: FlockContext | None = None,
171
- ) -> dict[str, Any]:
172
- """Format and display the output."""
173
- if not self.config.enable_read:
174
- return inputs
175
-
176
- zep_client = Zep(
177
- base_url=self.config.zep_url, api_key=self.config.zep_api_key
178
- )
179
-
180
- logger.debug("Searching memory")
181
- facts = self.search_memory(str(inputs), zep_client)
182
-
183
- # Add memory to inputs
184
- facts_str = ""
185
- if facts:
186
- for fact in facts:
187
- facts_str += fact.fact.fact + "\n"
188
- logger.debug("Found facts in memory: {}", facts_str)
189
- agent.input = agent.input + ", memory"
190
- inputs["memory"] = facts_str
191
-
192
- return inputs
@@ -1,49 +0,0 @@
1
- import subprocess
2
- import time
3
-
4
-
5
- def _check_docker_running():
6
- """Check if Docker is running by calling 'docker info'."""
7
- try:
8
- result = subprocess.run(
9
- ["docker", "info"],
10
- stdout=subprocess.PIPE,
11
- stderr=subprocess.PIPE,
12
- text=True,
13
- )
14
- return result.returncode == 0
15
- except Exception:
16
- return False
17
-
18
-
19
- def _start_docker():
20
- """Attempt to start Docker.
21
- This example first tries 'systemctl start docker' and then 'service docker start'.
22
- Adjust as needed for your environment.
23
- """
24
- try:
25
- print("Attempting to start Docker...")
26
- result = subprocess.run(
27
- ["sudo", "systemctl", "start", "docker"],
28
- stdout=subprocess.PIPE,
29
- stderr=subprocess.PIPE,
30
- text=True,
31
- )
32
- if result.returncode != 0:
33
- result = subprocess.run(
34
- ["sudo", "service", "docker", "start"],
35
- stdout=subprocess.PIPE,
36
- stderr=subprocess.PIPE,
37
- text=True,
38
- )
39
- # Give Docker a moment to start.
40
- time.sleep(3)
41
- if _check_docker_running():
42
- print("Docker is now running.")
43
- return True
44
- else:
45
- print("Docker did not start successfully.")
46
- return False
47
- except Exception as e:
48
- print(f"Exception when trying to start Docker: {e}")
49
- return False
@@ -1,86 +0,0 @@
1
- import socket
2
- import subprocess
3
- from urllib.parse import urlparse
4
-
5
-
6
- class JaegerInstaller:
7
- jaeger_endpoint: str = None
8
- jaeger_transport: str = "grpc"
9
-
10
- def _check_jaeger_running(self):
11
- """Check if Jaeger is reachable by attempting a socket connection.
12
- For HTTP transport, we parse the URL; for gRPC, we expect "host:port".
13
- """
14
- try:
15
- if self.jaeger_transport == "grpc":
16
- host, port = self.jaeger_endpoint.split(":")
17
- port = int(port)
18
- elif self.jaeger_transport == "http":
19
- parsed = urlparse(self.jaeger_endpoint)
20
- host = parsed.hostname
21
- port = parsed.port if parsed.port else 80
22
- else:
23
- return False
24
-
25
- # Try connecting to the host and port.
26
- with socket.create_connection((host, port), timeout=3):
27
- return True
28
- except Exception:
29
- return False
30
-
31
- def _is_jaeger_container_running(self):
32
- """Check if a Jaeger container (using the official all-in-one image) is running.
33
- This uses 'docker ps' to filter for containers running the Jaeger image.
34
- """
35
- try:
36
- result = subprocess.run(
37
- [
38
- "docker",
39
- "ps",
40
- "--filter",
41
- "ancestor=jaegertracing/all-in-one:latest",
42
- "--format",
43
- "{{.ID}}",
44
- ],
45
- stdout=subprocess.PIPE,
46
- stderr=subprocess.PIPE,
47
- text=True,
48
- )
49
- return bool(result.stdout.strip())
50
- except Exception:
51
- return False
52
-
53
- def _provision_jaeger_container(self):
54
- """Provision a Jaeger container using Docker."""
55
- try:
56
- print("Provisioning Jaeger container using Docker...")
57
- result = subprocess.run(
58
- [
59
- "docker",
60
- "run",
61
- "-d",
62
- "--name",
63
- "jaeger",
64
- "-p",
65
- "16686:16686",
66
- "-p",
67
- "14250:14250",
68
- "-p",
69
- "14268:14268",
70
- "jaegertracing/all-in-one:latest",
71
- ],
72
- stdout=subprocess.PIPE,
73
- stderr=subprocess.PIPE,
74
- text=True,
75
- )
76
- if result.returncode == 0:
77
- print("Jaeger container started successfully.")
78
- return True
79
- else:
80
- print(
81
- f"Failed to start Jaeger container. Error: {result.stderr}"
82
- )
83
- return False
84
- except Exception as e:
85
- print(f"Exception when provisioning Jaeger container: {e}")
86
- return False
flock/routers/__init__.py DELETED
@@ -1 +0,0 @@
1
- """Routers for the Flock framework."""
@@ -1 +0,0 @@
1
- """Agent-based router implementation for the Flock framework."""
@@ -1,236 +0,0 @@
1
- """Agent-based router implementation for the Flock framework."""
2
-
3
- from typing import Any
4
-
5
- from flock.core.context.context import FlockContext
6
- from flock.core.flock_agent import FlockAgent
7
- from flock.core.flock_registry import flock_component
8
- from flock.core.flock_router import (
9
- FlockRouter,
10
- FlockRouterConfig,
11
- HandOffRequest,
12
- )
13
- from flock.core.logging.formatters.themes import OutputTheme
14
- from flock.core.logging.logging import get_logger
15
- from flock.evaluators.declarative.declarative_evaluator import (
16
- DeclarativeEvaluator,
17
- DeclarativeEvaluatorConfig,
18
- )
19
- from flock.modules.output.output_module import OutputModule, OutputModuleConfig
20
- from flock.routers.agent.handoff_agent import (
21
- AgentInfo,
22
- HandoffAgent,
23
- )
24
-
25
- logger = get_logger("agent_router")
26
-
27
-
28
- class AgentRouterConfig(FlockRouterConfig):
29
- """Configuration for the agent router.
30
-
31
- This class extends FlockRouterConfig with parameters specific to the agent router.
32
- """
33
-
34
- with_output: bool = False
35
- confidence_threshold: float = 0.5 # No additional parameters needed for now
36
-
37
-
38
- @flock_component(config_class=AgentRouterConfig)
39
- class AgentRouter(FlockRouter):
40
- """Router that uses a FlockAgent to determine the next agent in a workflow.
41
-
42
- This class is responsible for:
43
- 1. Creating and managing a HandoffAgent
44
- 2. Analyzing available agents in the registry
45
- 3. Using the HandoffAgent to determine the best next agent
46
- 4. Creating a HandOff object with the selected agent
47
- """
48
-
49
- def __init__(
50
- self,
51
- name: str = "agent_router",
52
- config: AgentRouterConfig | None = None,
53
- ):
54
- """Initialize the AgentRouter.
55
-
56
- Args:
57
- registry: The agent registry containing all available agents
58
- name: The name of the router
59
- config: The router configuration
60
- """
61
- super().__init__(
62
- name=name, config=config or AgentRouterConfig(name=name)
63
- )
64
-
65
- async def route(
66
- self,
67
- current_agent: FlockAgent,
68
- result: dict[str, Any],
69
- context: FlockContext,
70
- ) -> HandOffRequest:
71
- """Determine the next agent to hand off to based on the current agent's output.
72
-
73
- Args:
74
- current_agent: The agent that just completed execution
75
- result: The output from the current agent
76
- context: The global execution context
77
-
78
- Returns:
79
- A HandOff object containing the next agent and input data
80
- """
81
- # Get all available agents from context.agent_definitions
82
- agent_definitions = context.agent_definitions
83
- handoff_agent = HandoffAgent(model=current_agent.model)
84
- handoff_agent.evaluator = DeclarativeEvaluator(
85
- name="evaluator",
86
- config=DeclarativeEvaluatorConfig(
87
- model=current_agent.model,
88
- use_cache=True,
89
- max_tokens=1000,
90
- temperature=0.0,
91
- ),
92
- )
93
- if self.config.with_output:
94
- handoff_agent.add_module(
95
- OutputModule(
96
- name="output",
97
- config=OutputModuleConfig(
98
- theme=OutputTheme.abernathy,
99
- ),
100
- )
101
- )
102
- available_agents = self._get_available_agents(
103
- agent_definitions, current_agent.name
104
- )
105
-
106
- if not available_agents:
107
- logger.warning("No available agents for agent-based routing")
108
- return HandOffRequest(
109
- next_agent="",
110
- output_to_input_merge_strategy="add",
111
- override_next_agent=None,
112
- override_context=None,
113
- )
114
-
115
- # Prepare input for the handoff agent
116
- handoff_input = {
117
- "current_agent_name": current_agent.name,
118
- "current_agent_description": current_agent.description,
119
- "current_agent_input": current_agent.input,
120
- "current_agent_output": current_agent.output,
121
- "current_result": result,
122
- "available_agents": available_agents,
123
- }
124
-
125
- try:
126
- # Run the handoff agent to determine the next agent
127
- handoff_result = await handoff_agent.run_async(handoff_input)
128
-
129
- # Extract the decision
130
- next_agent_name = handoff_result.get("agent_name")
131
- confidence = handoff_result.get("confidence")
132
- reasoning = handoff_result.get("reasoning")
133
- logger.info(
134
- f"Agent router selected agent '{next_agent_name}' with confidence {confidence} and reasoning: {reasoning}"
135
- )
136
-
137
- if confidence < self.config.confidence_threshold:
138
- logger.info(
139
- f"No suitable next agent found (best score: {confidence})"
140
- )
141
- return HandOffRequest(
142
- next_agent="",
143
- output_to_input_merge_strategy="add",
144
- override_next_agent=None,
145
- override_context=None,
146
- )
147
-
148
- next_agent = agent_definitions.get(next_agent_name)
149
- if not next_agent:
150
- logger.error(
151
- f"Selected agent '{next_agent_name}' not found in agent definitions"
152
- )
153
- return HandOffRequest(
154
- next_agent="",
155
- output_to_input_merge_strategy="add",
156
- override_next_agent=None,
157
- override_context=None,
158
- )
159
-
160
- logger.info(
161
- f"Agent router selected agent '{next_agent_name}' with confidence {confidence}"
162
- )
163
- return HandOffRequest(
164
- next_agent=next_agent_name,
165
- output_to_input_merge_strategy="add",
166
- override_next_agent=None,
167
- override_context=None,
168
- )
169
-
170
- except Exception as e:
171
- logger.error(f"Error in agent-based routing: {e}")
172
- return HandOffRequest(
173
- next_agent="",
174
- output_to_input_merge_strategy="add",
175
- override_next_agent=None,
176
- override_context=None,
177
- )
178
-
179
- def _get_available_agents(
180
- self, agent_definitions: dict[str, Any], current_agent_name: str
181
- ) -> list[AgentInfo]:
182
- """Get all available agents except the current one and the handoff agent.
183
-
184
- Args:
185
- agent_definitions: Dictionary of available agents
186
- current_agent_name: Name of the current agent to exclude
187
-
188
- Returns:
189
- List of available agents as AgentInfo objects
190
- """
191
- agents = []
192
- for agent_name in agent_definitions:
193
- if agent_name != current_agent_name:
194
- agent = agent_definitions[agent_name]
195
- agent_info = AgentInfo(
196
- name=agent_name,
197
- description=agent.agent_data["description"]
198
- if agent.agent_data["description"]
199
- else "",
200
- input_schema=agent.agent_data["input"],
201
- output_schema=agent.agent_data["output"],
202
- )
203
- agents.append(agent_info)
204
- return agents
205
-
206
- def _get_schema_from_agent(
207
- self, agent: Any, schema_type: str
208
- ) -> dict[str, Any]:
209
- """Extract input or output schema from an agent.
210
-
211
- Args:
212
- agent: The agent to extract schema from
213
- schema_type: Either "input" or "output"
214
-
215
- Returns:
216
- Dictionary representation of the schema
217
- """
218
- schema = {}
219
- schema_str = agent.agent_data.get(schema_type, "")
220
-
221
- # Parse the schema string to extract field names, types, and descriptions
222
- if schema_str:
223
- fields = schema_str.split(",")
224
- for field in fields:
225
- field = field.strip()
226
- if ":" in field:
227
- name, rest = field.split(":", 1)
228
- name = name.strip()
229
- schema[name] = rest.strip()
230
- else:
231
- schema[field] = "Any"
232
-
233
- return schema
234
-
235
- # The _create_next_input method is no longer needed since we're using hand_off_mode="add"
236
- # instead of manually preparing inputs for the next agent
@@ -1,58 +0,0 @@
1
- """Handoff agent for the agent-based router."""
2
-
3
- from pydantic import BaseModel
4
-
5
- from flock.core.flock_agent import FlockAgent
6
-
7
-
8
- class AgentInfo(BaseModel):
9
- """Information about an agent for handoff decisions."""
10
-
11
- name: str
12
- description: str = ""
13
- input_schema: str = ""
14
- output_schema: str = ""
15
-
16
-
17
- class HandoffDecision(BaseModel):
18
- """Decision about which agent to hand off to."""
19
-
20
- agent_name: str
21
- confidence: float
22
- reasoning: str
23
-
24
-
25
- class HandoffAgent(FlockAgent):
26
- """Agent that decides which agent to hand off to next.
27
-
28
- This agent analyzes the current agent's output and available agents
29
- to determine the best next agent in the workflow.
30
- """
31
-
32
- def __init__(
33
- self,
34
- name: str = "handoff_agent",
35
- model: str | None = None,
36
- description: str = "Decides which agent to hand off to next",
37
- ):
38
- """Initialize the HandoffAgent.
39
-
40
- Args:
41
- name: The name of the agent
42
- model: The model to use (e.g., 'openai/gpt-4o')
43
- description: A human-readable description of the agent
44
- """
45
- super().__init__(
46
- name=name,
47
- model=model,
48
- description=description,
49
- input=(
50
- "current_agent_name: str | Name of the current agent, "
51
- "current_agent_description: str | Description of the current agent, "
52
- "current_agent_input: str | Input schema of the current agent, "
53
- "current_agent_output: str | Output schema of the current agent, "
54
- "current_result: dict | Output from the current agent, "
55
- "available_agents: list[AgentInfo] | List of available agents"
56
- ),
57
- output="agent_name: str | Name of the agent to hand off to, confidence: float | Confidence in the decision, reasoning: str | Reasoning for the decision",
58
- )