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
flock/api/themes.py ADDED
@@ -0,0 +1,71 @@
1
+ """
2
+ Theme API Endpoints
3
+
4
+ Serves 300+ terminal color themes from TOML files.
5
+ Themes are loaded from src/flock/themes/
6
+ """
7
+
8
+ from pathlib import Path
9
+ from typing import Any
10
+
11
+ import toml
12
+ from fastapi import APIRouter, HTTPException
13
+
14
+
15
+ router = APIRouter()
16
+
17
+ # Path to themes directory
18
+ THEMES_DIR = Path(__file__).parent.parent / "themes"
19
+
20
+
21
+ @router.get("/themes")
22
+ async def list_themes() -> dict[str, list[str]]:
23
+ """
24
+ List all available theme names.
25
+
26
+ Returns:
27
+ Dictionary with 'themes' key containing sorted list of theme names
28
+ """
29
+ try:
30
+ if not THEMES_DIR.exists():
31
+ return {"themes": []}
32
+
33
+ theme_files = list(THEMES_DIR.glob("*.toml"))
34
+ theme_names = sorted([f.stem for f in theme_files])
35
+
36
+ return {"themes": theme_names}
37
+ except Exception as e:
38
+ raise HTTPException(status_code=500, detail=f"Failed to list themes: {e!s}")
39
+
40
+
41
+ @router.get("/themes/{theme_name}")
42
+ async def get_theme(theme_name: str) -> dict[str, Any]:
43
+ """
44
+ Get theme data by name.
45
+
46
+ Args:
47
+ theme_name: Name of the theme (without .toml extension)
48
+
49
+ Returns:
50
+ Dictionary with 'name' and 'data' containing theme colors
51
+
52
+ Raises:
53
+ HTTPException: If theme not found or failed to load
54
+ """
55
+ try:
56
+ # Sanitize theme name to prevent path traversal
57
+ theme_name = theme_name.replace("/", "").replace("\\", "").replace("..", "")
58
+
59
+ theme_path = THEMES_DIR / f"{theme_name}.toml"
60
+
61
+ if not theme_path.exists():
62
+ raise HTTPException(status_code=404, detail=f"Theme '{theme_name}' not found")
63
+
64
+ # Load TOML theme
65
+ theme_data = toml.load(theme_path)
66
+
67
+ return {"name": theme_name, "data": theme_data}
68
+ except HTTPException:
69
+ raise
70
+ except Exception as e:
71
+ raise HTTPException(status_code=500, detail=f"Failed to load theme '{theme_name}': {e!s}")
flock/artifacts.py ADDED
@@ -0,0 +1,79 @@
1
+ """Artifact modelling utilities."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from datetime import datetime, timezone
6
+ from typing import Any
7
+ from uuid import UUID, uuid4
8
+
9
+ from pydantic import BaseModel, Field
10
+
11
+ from flock.registry import type_registry
12
+ from flock.visibility import Visibility, ensure_visibility
13
+
14
+
15
+ class Artifact(BaseModel):
16
+ """Typed artifact stored on the blackboard."""
17
+
18
+ id: UUID = Field(default_factory=uuid4)
19
+ type: str
20
+ payload: dict[str, Any]
21
+ produced_by: str
22
+ correlation_id: UUID | None = None
23
+ partition_key: str | None = None
24
+ tags: set[str] = Field(default_factory=set)
25
+ visibility: Visibility = Field(default_factory=lambda: ensure_visibility(None))
26
+ created_at: datetime = Field(default_factory=lambda: datetime.now(timezone.utc))
27
+ version: int = 1
28
+
29
+ def model_dump_payload(self) -> dict[str, Any]: # pragma: no cover - convenience
30
+ return dict(self.payload)
31
+
32
+
33
+ class ArtifactSpec(BaseModel):
34
+ """Wiring description used for validation on publish."""
35
+
36
+ type_name: str
37
+ model: type[BaseModel]
38
+
39
+ @classmethod
40
+ def from_model(cls, model: type[BaseModel]) -> ArtifactSpec:
41
+ type_name = type_registry.register(model)
42
+ return cls(type_name=type_name, model=model)
43
+
44
+ def build(
45
+ self,
46
+ *,
47
+ produced_by: str,
48
+ data: dict[str, Any],
49
+ visibility: Visibility | None = None,
50
+ correlation_id: UUID | None = None,
51
+ partition_key: str | None = None,
52
+ tags: set[str] | None = None,
53
+ version: int = 1,
54
+ ) -> Artifact:
55
+ payload_model = self.model(**data)
56
+ return Artifact(
57
+ type=self.type_name,
58
+ payload=payload_model.model_dump(),
59
+ produced_by=produced_by,
60
+ visibility=ensure_visibility(visibility),
61
+ correlation_id=correlation_id,
62
+ partition_key=partition_key,
63
+ tags=tags or set(),
64
+ version=version,
65
+ )
66
+
67
+
68
+ class ArtifactEnvelope(BaseModel):
69
+ """Envelope passed to components/engines during evaluation."""
70
+
71
+ artifact: Artifact
72
+ state: dict[str, Any] = Field(default_factory=dict)
73
+
74
+
75
+ __all__ = [
76
+ "Artifact",
77
+ "ArtifactEnvelope",
78
+ "ArtifactSpec",
79
+ ]
flock/cli.py ADDED
@@ -0,0 +1,75 @@
1
+ """Typer-based CLI for blackboard agents."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import asyncio
6
+
7
+ import typer
8
+ from rich.console import Console
9
+ from rich.table import Table
10
+
11
+ # Lazy import: only import examples when CLI commands are invoked
12
+ # This prevents polluting type_registry on every package import
13
+ from flock.service import BlackboardHTTPService
14
+
15
+
16
+ app = typer.Typer(help="Blackboard Agents CLI")
17
+ console = Console()
18
+
19
+
20
+ @app.command()
21
+ def demo(
22
+ topic: str = typer.Option("AI agents collaborating", help="Idea topic"),
23
+ genre: str = typer.Option("comedy", help="Idea genre"),
24
+ ) -> None:
25
+ """Run the demo pipeline locally and stream results to the console."""
26
+
27
+ from flock.examples import Idea, create_demo_orchestrator
28
+
29
+ orchestrator, agents = create_demo_orchestrator()
30
+ idea = Idea(topic=topic, genre=genre)
31
+
32
+ async def _run_demo() -> None:
33
+ await orchestrator.arun(agents["movie"], idea)
34
+ await orchestrator.run_until_idle()
35
+ table = Table(title="Published Artifacts")
36
+ table.add_column("Type")
37
+ table.add_column("Payload", overflow="fold")
38
+ for artifact in await orchestrator.store.list():
39
+ table.add_row(artifact.type, repr(artifact.payload))
40
+ console.print(table)
41
+
42
+ asyncio.run(_run_demo())
43
+
44
+
45
+ @app.command()
46
+ def list_agents() -> None:
47
+ """List registered agents for the demo orchestrator."""
48
+
49
+ from flock.examples import create_demo_orchestrator
50
+
51
+ orchestrator, _agents = create_demo_orchestrator()
52
+ table = Table(title="Agents")
53
+ table.add_column("Name")
54
+ table.add_column("Description")
55
+ for agent in orchestrator.agents:
56
+ table.add_row(agent.name, agent.description or "")
57
+ console.print(table)
58
+
59
+
60
+ @app.command()
61
+ def serve(host: str = "127.0.0.1", port: int = 8000) -> None:
62
+ """Run the HTTP control plane bound to the demo orchestrator."""
63
+
64
+ from flock.examples import create_demo_orchestrator
65
+
66
+ orchestrator, _ = create_demo_orchestrator()
67
+ service = BlackboardHTTPService(orchestrator)
68
+ service.run(host=host, port=port)
69
+
70
+
71
+ def main() -> None:
72
+ app()
73
+
74
+
75
+ __all__ = ["app", "main"]
flock/components.py ADDED
@@ -0,0 +1,173 @@
1
+ """Agent component abstractions."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import TYPE_CHECKING, Any
6
+
7
+ from pydantic import BaseModel, Field, create_model
8
+ from typing_extensions import Self, TypeVar
9
+
10
+
11
+ if TYPE_CHECKING: # pragma: no cover - type checking only
12
+ from uuid import UUID
13
+
14
+ from flock.agent import Agent
15
+ from flock.artifacts import Artifact
16
+ from flock.runtime import Context, EvalInputs, EvalResult
17
+
18
+ T = TypeVar("T", bound="AgentComponentConfig")
19
+
20
+
21
+ class AgentComponentConfig(BaseModel):
22
+ enabled: bool = True
23
+ model: str | None = None
24
+
25
+ @classmethod
26
+ def with_fields(cls, **field_definitions) -> type[Self]:
27
+ """Create a new config class with additional fields.
28
+
29
+ This allows dynamic config creation for components with custom configuration needs.
30
+
31
+ Example:
32
+ CustomConfig = AgentComponentConfig.with_fields(
33
+ temperature=Field(default=0.7, description="LLM temperature"),
34
+ max_tokens=Field(default=1000, description="Max tokens to generate")
35
+ )
36
+ """
37
+ return create_model(f"Dynamic{cls.__name__}", __base__=cls, **field_definitions)
38
+
39
+
40
+ class AgentComponent(BaseModel):
41
+ name: str | None = None
42
+ config: AgentComponentConfig = Field(default_factory=AgentComponentConfig)
43
+
44
+ async def on_initialize(
45
+ self, agent: Agent, ctx: Context
46
+ ) -> None: # pragma: no cover - default no-op
47
+ return None
48
+
49
+ async def on_pre_consume(
50
+ self, agent: Agent, ctx: Context, inputs: list[Artifact]
51
+ ) -> list[Artifact]:
52
+ return inputs
53
+
54
+ async def on_pre_evaluate(self, agent: Agent, ctx: Context, inputs: EvalInputs) -> EvalInputs:
55
+ return inputs
56
+
57
+ async def on_post_evaluate(
58
+ self, agent: Agent, ctx: Context, inputs: EvalInputs, result: EvalResult
59
+ ) -> EvalResult:
60
+ return result
61
+
62
+ async def on_post_publish(
63
+ self, agent: Agent, ctx: Context, artifact: Artifact
64
+ ) -> None: # pragma: no cover - default
65
+ return None
66
+
67
+ async def on_error(
68
+ self, agent: Agent, ctx: Context, error: Exception
69
+ ) -> None: # pragma: no cover - default
70
+ return None
71
+
72
+ async def on_terminate(self, agent: Agent, ctx: Context) -> None: # pragma: no cover - default
73
+ return None
74
+
75
+
76
+ class EngineComponent(AgentComponent):
77
+ """Base class for engine components with built-in conversation context support."""
78
+
79
+ # Configuration for context fetching
80
+ enable_context: bool = Field(
81
+ default=True,
82
+ description="Whether to automatically fetch conversation context based on correlation_id",
83
+ )
84
+ context_max_artifacts: int | None = Field(
85
+ default=None,
86
+ description="Maximum number of artifacts to include in context (None = unlimited)",
87
+ )
88
+ context_exclude_types: set[str] = Field(
89
+ default_factory=set, description="Artifact types to exclude from context"
90
+ )
91
+
92
+ async def evaluate(self, agent: Agent, ctx: Context, inputs: EvalInputs) -> EvalResult:
93
+ """Override this method in your engine implementation."""
94
+ raise NotImplementedError
95
+
96
+ async def fetch_conversation_context(
97
+ self,
98
+ ctx: Context,
99
+ correlation_id: UUID | None = None,
100
+ max_artifacts: int | None = None,
101
+ ) -> list[dict[str, Any]]:
102
+ """Fetch all artifacts with the same correlation_id for conversation context."""
103
+ if not self.enable_context or not ctx:
104
+ return []
105
+
106
+ target_correlation_id = correlation_id or getattr(ctx, "correlation_id", None)
107
+ if not target_correlation_id:
108
+ return []
109
+
110
+ try:
111
+ all_artifacts = await ctx.board.list()
112
+
113
+ context_artifacts = [
114
+ a
115
+ for a in all_artifacts
116
+ if (
117
+ a.correlation_id == target_correlation_id
118
+ and a.type not in self.context_exclude_types
119
+ )
120
+ ]
121
+
122
+ context_artifacts.sort(key=lambda a: a.created_at)
123
+
124
+ max_limit = max_artifacts if max_artifacts is not None else self.context_max_artifacts
125
+ if max_limit is not None and max_limit > 0:
126
+ context_artifacts = context_artifacts[-max_limit:]
127
+
128
+ context = []
129
+ i = 0
130
+ for artifact in context_artifacts:
131
+ context.append(
132
+ {
133
+ "type": artifact.type,
134
+ "payload": artifact.payload,
135
+ "produced_by": artifact.produced_by,
136
+ "event_number": i,
137
+ # "created_at": artifact.created_at.isoformat(),
138
+ }
139
+ )
140
+ i += 1
141
+
142
+ return context
143
+
144
+ except Exception:
145
+ return []
146
+
147
+ async def get_latest_artifact_of_type(
148
+ self,
149
+ ctx: Context,
150
+ artifact_type: str,
151
+ correlation_id: UUID | None = None,
152
+ ) -> dict[str, Any] | None:
153
+ """Get the most recent artifact of a specific type in the conversation."""
154
+ context = await self.fetch_conversation_context(ctx, correlation_id)
155
+ matching = [a for a in context if a["type"].endswith(artifact_type)]
156
+ return matching[-1] if matching else None
157
+
158
+ def should_use_context(self, inputs: EvalInputs) -> bool:
159
+ """Determine if context should be included based on the current inputs."""
160
+ if not self.enable_context:
161
+ return False
162
+
163
+ if inputs.artifacts:
164
+ return inputs.artifacts[0].correlation_id is not None
165
+
166
+ return False
167
+
168
+
169
+ __all__ = [
170
+ "AgentComponent",
171
+ "AgentComponentConfig",
172
+ "EngineComponent",
173
+ ]
@@ -0,0 +1,28 @@
1
+ """Real-time dashboard event collection for flock-flow.
2
+
3
+ Phase 1: Backend event capture system.
4
+ Phase 3: WebSocket infrastructure for real-time communication.
5
+ """
6
+
7
+ from flock.dashboard.collector import DashboardEventCollector
8
+ from flock.dashboard.events import (
9
+ AgentActivatedEvent,
10
+ AgentCompletedEvent,
11
+ AgentErrorEvent,
12
+ MessagePublishedEvent,
13
+ StreamingOutputEvent,
14
+ )
15
+ from flock.dashboard.service import DashboardHTTPService
16
+ from flock.dashboard.websocket import WebSocketManager
17
+
18
+
19
+ __all__ = [
20
+ "AgentActivatedEvent",
21
+ "AgentCompletedEvent",
22
+ "AgentErrorEvent",
23
+ "DashboardEventCollector",
24
+ "DashboardHTTPService",
25
+ "MessagePublishedEvent",
26
+ "StreamingOutputEvent",
27
+ "WebSocketManager",
28
+ ]