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,550 +0,0 @@
1
- # src/flock/components/utility/memory_utility_component.py
2
- """Enterprise-grade memory utility component for Flock using unified component architecture.
3
-
4
- This component persists:
5
- • vector embeddings in a Chroma collection (or any collection that
6
- implements the same API)
7
- • a concept graph in Neo4j/Memgraph (Cypher-compatible)
8
-
9
- It follows the same life-cycle callbacks as the standard MemoryModule but
10
- is designed for large-scale, concurrent deployments.
11
- """
12
-
13
- from __future__ import annotations
14
-
15
- import asyncio
16
- import json
17
- import time
18
- import uuid
19
- from pathlib import Path
20
- from typing import TYPE_CHECKING, Any, Literal
21
-
22
- from neo4j import AsyncGraphDatabase
23
- from opentelemetry import trace
24
- from pydantic import Field
25
- from sentence_transformers import SentenceTransformer
26
-
27
- from flock.adapter.azure_adapter import AzureSearchAdapter
28
- from flock.adapter.chroma_adapter import ChromaAdapter
29
- from flock.adapter.faiss_adapter import FAISSAdapter
30
- from flock.adapter.pinecone_adapter import PineconeAdapter
31
- from flock.adapter.vector_base import VectorAdapter
32
- from flock.core.component.agent_component_base import AgentComponentConfig
33
- from flock.core.component.utility_component import UtilityComponent
34
- from flock.core.context.context import FlockContext
35
- from flock.core.logging.logging import get_logger
36
- from flock.core.registry import flock_component
37
-
38
- # Conditional import for MetricsUtilityComponent to avoid circular imports
39
- if TYPE_CHECKING:
40
- from flock.components.utility.metrics_utility_component import (
41
- MetricsUtilityComponent,
42
- )
43
- from flock.core.flock_agent import FlockAgent
44
-
45
- logger = get_logger("components.utility.memory")
46
- tracer = trace.get_tracer(__name__)
47
-
48
-
49
- class MemoryUtilityConfig(AgentComponentConfig):
50
- """Configuration for MemoryUtilityComponent."""
51
-
52
- # ---------------------
53
- # Vector store settings
54
- # ---------------------
55
-
56
- vector_backend: Literal["chroma", "pinecone", "azure", "faiss"] = Field(
57
- default="chroma",
58
- description="Which vector backend to use (chroma | pinecone | azure)",
59
- )
60
-
61
- # --- Chroma ---
62
- chroma_path: str | None = Field(
63
- default="./vector_store",
64
- description="Disk path for Chroma persistent storage (if running embedded).",
65
- )
66
- chroma_collection: str = Field(
67
- default="flock_memories", description="Chroma collection name"
68
- )
69
- chroma_host: str | None = Field(
70
- default=None,
71
- description="If provided, connect to a remote Chroma HTTP server at this host",
72
- )
73
- chroma_port: int = Field(
74
- default=8000, description="Remote Chroma HTTP port"
75
- )
76
-
77
- # --- Pinecone ---
78
- pinecone_api_key: str | None = Field(
79
- default=None, description="Pinecone API key"
80
- )
81
- pinecone_env: str | None = Field(
82
- default=None, description="Pinecone environment"
83
- )
84
- pinecone_index: str | None = Field(
85
- default=None, description="Pinecone index name"
86
- )
87
-
88
- # --- Azure Cognitive Search ---
89
- azure_search_endpoint: str | None = Field(
90
- default=None,
91
- description="Azure search endpoint (https://<service>.search.windows.net)",
92
- )
93
- azure_search_key: str | None = Field(
94
- default=None, description="Azure search admin/key"
95
- )
96
- azure_search_index_name: str | None = Field(
97
- default=None, description="Azure search index name"
98
- )
99
-
100
- # Graph DB (Neo4j / Memgraph) settings
101
- cypher_uri: str = Field(
102
- default="bolt://localhost:7687", description="Bolt URI for the graph DB"
103
- )
104
- cypher_username: str = Field(default="neo4j", description="Username for DB")
105
- cypher_password: str = Field(
106
- default="password", description="Password for DB"
107
- )
108
-
109
- similarity_threshold: float = Field(
110
- default=0.5, description="Cosine-similarity threshold for retrieval"
111
- )
112
- max_results: int = Field(
113
- default=10, description="Maximum retrieved memories"
114
- )
115
- number_of_concepts_to_extract: int = Field(
116
- default=3, description="Number of concepts extracted per chunk"
117
- )
118
- save_interval: int = Field(
119
- default=10,
120
- description="Persist to disk after this many new chunks (0 disables auto-save)",
121
- )
122
-
123
- export_graph_image: bool = Field(
124
- default=False,
125
- description="If true, exports a PNG image of the concept graph each time it is updated.",
126
- )
127
- graph_image_dir: str = Field(
128
- default="./concept_graphs",
129
- description="Directory where graph images will be stored when export_graph_image is true.",
130
- )
131
-
132
-
133
- class MemoryStore:
134
- """Persistence layer that wraps vector store + Cypher graph."""
135
-
136
- def __init__(
137
- self,
138
- cfg: MemoryUtilityConfig,
139
- metrics_component: MetricsUtilityComponent | None = None,
140
- ):
141
- self.cfg = cfg
142
- # Metrics component (DI-resolved or fallback)
143
- self._metrics = metrics_component
144
- # Lazy initialise expensive resources
145
- self._embedding_model: SentenceTransformer | None = None
146
- self._adapter: VectorAdapter | None = None
147
- self._driver = None # Neo4j driver
148
- self._pending_writes: list[tuple[str, dict[str, Any]]] = []
149
- self._write_lock = asyncio.Lock()
150
- self._concept_cache: set[str] | None = None # names of known concepts
151
-
152
- def _ensure_embedding_model(self) -> SentenceTransformer:
153
- if self._embedding_model is None:
154
- logger.debug("Loading embedding model 'all-MiniLM-L6-v2'")
155
- with tracer.start_as_current_span(
156
- "memory.load_embedding_model"
157
- ) as span:
158
- try:
159
- self._embedding_model = SentenceTransformer(
160
- "all-MiniLM-L6-v2"
161
- )
162
- span.set_attribute("model", "all-MiniLM-L6-v2")
163
- except Exception as e:
164
- span.record_exception(e)
165
- raise
166
- return self._embedding_model
167
-
168
- def _ensure_adapter(self) -> VectorAdapter:
169
- if self._adapter is not None:
170
- return self._adapter
171
-
172
- backend = self.cfg.vector_backend
173
-
174
- if backend == "chroma":
175
- self._adapter = ChromaAdapter(
176
- collection=self.cfg.chroma_collection,
177
- host=self.cfg.chroma_host,
178
- port=self.cfg.chroma_port,
179
- path=self.cfg.chroma_path,
180
- )
181
- elif backend == "pinecone":
182
- self._adapter = PineconeAdapter(
183
- api_key=self.cfg.pinecone_api_key,
184
- environment=self.cfg.pinecone_env,
185
- index=self.cfg.pinecone_index,
186
- )
187
- elif backend == "azure":
188
- self._adapter = AzureSearchAdapter(
189
- endpoint=self.cfg.azure_search_endpoint,
190
- key=self.cfg.azure_search_key,
191
- index_name=self.cfg.azure_search_index_name,
192
- )
193
- elif backend == "faiss":
194
- self._adapter = FAISSAdapter(index_path="./faiss.index")
195
- else:
196
- raise ValueError(f"Unsupported vector backend: {backend}")
197
-
198
- return self._adapter
199
-
200
- def _ensure_graph_driver(self):
201
- if self._driver is None:
202
- self._driver = AsyncGraphDatabase.driver(
203
- self.cfg.cypher_uri,
204
- auth=(self.cfg.cypher_username, self.cfg.cypher_password),
205
- encrypted=False,
206
- )
207
- return self._driver
208
-
209
- async def add_entry(
210
- self,
211
- content: str,
212
- concepts: set[str],
213
- metadata: dict[str, Any] | None = None,
214
- ) -> str:
215
- """Store a chunk in both vector store and graph DB and return its id."""
216
- with tracer.start_as_current_span("memory.add_entry") as span:
217
- entry_id = str(uuid.uuid4())
218
- span.set_attribute("entry_id", entry_id)
219
-
220
- # Embed
221
- embedding = self._ensure_embedding_model().encode(content).tolist()
222
- span.set_attribute("embedding_length", len(embedding))
223
-
224
- # Vector store write
225
- adapter = self._ensure_adapter()
226
- span.set_attribute("vector_backend", self.cfg.vector_backend)
227
-
228
- start_t = time.perf_counter()
229
- try:
230
- adapter.add(
231
- id=entry_id,
232
- content=content,
233
- embedding=embedding,
234
- metadata=metadata,
235
- )
236
- except Exception as e:
237
- span.record_exception(e)
238
- raise
239
- finally:
240
- elapsed = (time.perf_counter() - start_t) * 1000 # ms
241
- if self._metrics:
242
- self._metrics.record(
243
- "memory_add_latency_ms",
244
- elapsed,
245
- {"backend": self.cfg.vector_backend},
246
- )
247
-
248
- # Schedule graph writes (batched)
249
- async with self._write_lock:
250
- self._pending_writes.append((entry_id, {"concepts": concepts}))
251
- if (
252
- self.cfg.save_interval
253
- and len(self._pending_writes) >= self.cfg.save_interval
254
- ):
255
- await self._flush_pending_graph_writes()
256
- return entry_id
257
-
258
- async def search(
259
- self, query_text: str, threshold: float, k: int
260
- ) -> list[dict[str, Any]]:
261
- """Vector similarity search followed by graph enrichment."""
262
- with tracer.start_as_current_span("memory.search") as span:
263
- span.set_attribute("vector_backend", self.cfg.vector_backend)
264
- embedding = (
265
- self._ensure_embedding_model().encode(query_text).tolist()
266
- )
267
- span.set_attribute("embedding_length", len(embedding))
268
- adapter = self._ensure_adapter()
269
- backend = self.cfg.vector_backend
270
- results: list[dict[str, Any]] = []
271
-
272
- search_start = time.perf_counter()
273
- vector_hits = adapter.query(embedding=embedding, k=k)
274
- search_elapsed = (time.perf_counter() - search_start) * 1000
275
- if self._metrics:
276
- self._metrics.record(
277
- "memory_search_hits", len(vector_hits), {"backend": backend}
278
- )
279
- for hit in vector_hits:
280
- if hit.score < threshold:
281
- continue
282
- results.append(
283
- {
284
- "id": hit.id,
285
- "content": hit.content,
286
- "metadata": hit.metadata,
287
- "score": hit.score,
288
- }
289
- )
290
-
291
- span.set_attribute("results_count", len(results))
292
- if self._metrics:
293
- self._metrics.record(
294
- "memory_search_latency_ms",
295
- search_elapsed,
296
- {"backend": backend},
297
- )
298
- return results
299
-
300
- async def _flush_pending_graph_writes(self):
301
- """Commit queued node/edge creations to the Cypher store."""
302
- if not self._pending_writes:
303
- return
304
- driver = self._ensure_graph_driver()
305
- async with driver.session() as session:
306
- tx_commands: list[str] = []
307
- params: dict[str, Any] = {}
308
- # Build Cypher in one transaction
309
- for idx, (entry_id, extra) in enumerate(self._pending_writes):
310
- concept_param = f"concepts_{idx}"
311
- tx_commands.append(
312
- f"MERGE (e:Memory {{id: '{entry_id}'}}) "
313
- f"SET e.created = datetime() "
314
- )
315
- if extra.get("concepts"):
316
- tx_commands.append(
317
- f"WITH e UNWIND ${concept_param} AS c "
318
- "MERGE (co:Concept {name: c}) "
319
- "MERGE (e)-[:MENTIONS]->(co)"
320
- )
321
- params[concept_param] = list(extra["concepts"])
322
- cypher = "\n".join(tx_commands)
323
- await session.run(cypher, params)
324
- # Export graph image if requested
325
- if self.cfg.export_graph_image:
326
- await self._export_graph_image(session)
327
- self._pending_writes.clear()
328
-
329
- async def _export_graph_image(self, session):
330
- """Generate and save a PNG of the concept graph."""
331
- try:
332
- import matplotlib
333
-
334
- matplotlib.use("Agg")
335
- import matplotlib.pyplot as plt
336
- import networkx as nx
337
-
338
- records = await session.run(
339
- "MATCH (c1:Concept)<-[:MENTIONS]-(:Memory)-[:MENTIONS]->(c2:Concept) "
340
- "RETURN DISTINCT c1.name AS source, c2.name AS target"
341
- )
342
- edges = [
343
- (r["source"], r["target"])
344
- for r in await records.values("source", "target")
345
- ]
346
- if not edges:
347
- return
348
-
349
- G = nx.Graph()
350
- G.add_edges_from(edges)
351
-
352
- pos = nx.spring_layout(G, k=0.4)
353
- plt.figure(figsize=(12, 9), dpi=100)
354
- nx.draw_networkx_nodes(
355
- G, pos, node_color="#8fa8d6", node_size=500, edgecolors="white"
356
- )
357
- nx.draw_networkx_edges(G, pos, alpha=0.5, width=1.5)
358
- nx.draw_networkx_labels(G, pos, font_size=8)
359
- plt.axis("off")
360
-
361
- img_dir = Path(self.cfg.graph_image_dir)
362
- img_dir.mkdir(parents=True, exist_ok=True)
363
- filename = img_dir / f"concept_graph_{uuid.uuid4().hex[:8]}.png"
364
- plt.savefig(filename, bbox_inches="tight", facecolor="white")
365
- plt.close()
366
- logger.info("Concept graph image exported to %s", filename)
367
- except Exception as e:
368
- logger.warning("Failed to export concept graph image: %s", e)
369
-
370
- async def _deduplicate_concepts(self, new_concepts: set[str]) -> set[str]:
371
- """Return a set of concept names that merges with existing ones to avoid duplicates.
372
-
373
- Strategy: case-insensitive equality first, then fuzzy match via difflib with cutoff 0.85.
374
- """
375
- await self._ensure_concept_cache()
376
- assert self._concept_cache is not None
377
-
378
- from difflib import get_close_matches
379
-
380
- unified: set[str] = set()
381
- for concept in new_concepts:
382
- # Exact (case-insensitive) match
383
- lower = concept.lower()
384
- exact = next(
385
- (c for c in self._concept_cache if c.lower() == lower), None
386
- )
387
- if exact:
388
- unified.add(exact)
389
- continue
390
-
391
- # Fuzzy match (>=0.85 similarity)
392
- close = get_close_matches(
393
- concept, list(self._concept_cache), n=1, cutoff=0.85
394
- )
395
- if close:
396
- unified.add(close[0])
397
- continue
398
-
399
- # No match – treat as new
400
- unified.add(concept)
401
- self._concept_cache.add(concept)
402
- return unified
403
-
404
- async def _ensure_concept_cache(self):
405
- if self._concept_cache is not None:
406
- return
407
- driver = self._ensure_graph_driver()
408
- async with driver.session() as session:
409
- records = await session.run(
410
- "MATCH (c:Concept) RETURN c.name AS name"
411
- )
412
- self._concept_cache = {
413
- r["name"] for r in await records.values("name")
414
- }
415
-
416
- async def close(self):
417
- if self._pending_writes:
418
- await self._flush_pending_graph_writes()
419
- if self._driver:
420
- await self._driver.close()
421
- if self._adapter and hasattr(self._adapter, "close"):
422
- self._adapter.close()
423
-
424
-
425
- @flock_component(config_class=MemoryUtilityConfig)
426
- class MemoryUtilityComponent(UtilityComponent):
427
- """Enterprise-ready memory utility component using real datastores."""
428
-
429
- config: MemoryUtilityConfig = Field(
430
- default_factory=MemoryUtilityConfig,
431
- description="Memory configuration",
432
- )
433
-
434
- def __init__(
435
- self,
436
- name: str = "memory",
437
- config: MemoryUtilityConfig | None = None,
438
- **data,
439
- ):
440
- if config is None:
441
- config = MemoryUtilityConfig()
442
- super().__init__(name=name, config=config, **data)
443
-
444
- self._store: MemoryStore | None = None
445
- self._metrics_component: MetricsUtilityComponent | None = None
446
-
447
- def _get_metrics_component(self) -> MetricsUtilityComponent | None:
448
- """Try to get the metrics component from the singleton if available."""
449
- try:
450
- from flock.components.utility.metrics_utility_component import (
451
- MetricsUtilityComponent,
452
- )
453
-
454
- return MetricsUtilityComponent._INSTANCE
455
- except ImportError:
456
- return None
457
-
458
- async def on_initialize(
459
- self,
460
- agent: FlockAgent,
461
- inputs: dict[str, Any],
462
- context: FlockContext | None = None,
463
- ) -> None:
464
- """Initialize the memory store."""
465
- self._metrics_component = self._get_metrics_component()
466
- self._store = MemoryStore(self.config, self._metrics_component)
467
- logger.info(
468
- "MemoryUtilityComponent initialised for agent: %s", agent.name
469
- )
470
-
471
- async def on_pre_evaluate(
472
- self,
473
- agent: FlockAgent,
474
- inputs: dict[str, Any],
475
- context: FlockContext | None = None,
476
- ) -> dict[str, Any]:
477
- """Retrieve relevant memories and inject into inputs."""
478
- if not self._store:
479
- return inputs
480
- try:
481
- query_str = json.dumps(inputs)
482
- matches = await self._store.search(
483
- query_str,
484
- threshold=self.config.similarity_threshold,
485
- k=self.config.max_results,
486
- )
487
- if matches:
488
- inputs = {**inputs, "context": matches}
489
- # Advertise new input key to DSPy signature if needed
490
- if (
491
- isinstance(agent.input, str)
492
- and "context:" not in agent.input
493
- ):
494
- agent.input += ", context: list | retrieved memories"
495
- except Exception as e:
496
- logger.warning(
497
- "Memory retrieval failed for agent %s: %s", agent.name, e
498
- )
499
- return inputs
500
-
501
- async def on_post_evaluate(
502
- self,
503
- agent: FlockAgent,
504
- inputs: dict[str, Any],
505
- context: FlockContext | None = None,
506
- result: dict[str, Any] | None = None,
507
- ) -> dict[str, Any] | None:
508
- """Store new memories from inputs and results."""
509
- if not self._store:
510
- return result
511
- try:
512
- full_text = json.dumps(inputs) + (
513
- json.dumps(result) if result else ""
514
- )
515
- concepts = await self._extract_concepts(agent, full_text)
516
- if self._store:
517
- concepts = await self._store._deduplicate_concepts(concepts)
518
- await self._store.add_entry(full_text, concepts)
519
- except Exception as e:
520
- logger.warning(
521
- "Memory store failed for agent %s: %s", agent.name, e
522
- )
523
- return result
524
-
525
- async def on_terminate(
526
- self,
527
- agent: FlockAgent,
528
- inputs: dict[str, Any],
529
- context: FlockContext | None = None,
530
- result: dict[str, Any] | None = None,
531
- ) -> None:
532
- """Clean up memory store resources."""
533
- if self._store:
534
- await self._store.close()
535
-
536
- async def _extract_concepts(
537
- self, agent: FlockAgent, text: str
538
- ) -> set[str]:
539
- """Use the LLM to extract concept tokens."""
540
- concept_signature = agent.create_dspy_signature_class(
541
- f"{agent.name}_concept_extractor_memory",
542
- "Extract key concepts from text",
543
- "text: str | Input text -> concepts: list[str] | key concepts lower case",
544
- )
545
- import dspy
546
- lm = dspy.LM(model=agent.model, cache=True, temperature=0.0, max_tokens=8192)
547
- predictor = agent._select_task(concept_signature, "Predict")
548
- with dspy.settings.context(lm=lm):
549
- res = predictor(text=text)
550
- return set(getattr(res, "concepts", []))