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
@@ -0,0 +1,139 @@
1
+ /**
2
+ * useModules Hook - Module Lifecycle Management
3
+ *
4
+ * Provides ModuleContext to modules and manages lifecycle hooks.
5
+ * Aggregates data from multiple stores into a unified context.
6
+ * Calls module onMount/onUnmount lifecycle hooks when instances change.
7
+ *
8
+ * SPECIFICATION: docs/specs/003-real-time-dashboard/FRONTEND_ARCHITECTURE.md Section 7.4
9
+ * - Build ModuleContext from store data (agents, messages, events, filters)
10
+ * - Call module onMount lifecycle hooks when instances added
11
+ * - Call module onUnmount lifecycle hooks when instances removed
12
+ * - Provide publish and invoke actions in context
13
+ */
14
+
15
+ import { useEffect, useMemo, useRef } from 'react';
16
+ import { useModuleStore } from '../store/moduleStore';
17
+ import { useGraphStore } from '../store/graphStore';
18
+ import { useFilterStore } from '../store/filterStore';
19
+ import { moduleRegistry, type ModuleContext } from '../components/modules/ModuleRegistry';
20
+
21
+ /**
22
+ * Custom hook for module lifecycle management
23
+ *
24
+ * Features:
25
+ * - Builds ModuleContext from graphStore, filterStore
26
+ * - Tracks module instances and calls lifecycle hooks
27
+ * - Calls onMount when new instances are added
28
+ * - Calls onUnmount when instances are removed
29
+ * - Provides publish/invoke actions (placeholder for now)
30
+ *
31
+ * @returns {Object} Hook return value
32
+ * @returns {ModuleContext} context - The module context object
33
+ */
34
+ export function useModules() {
35
+ // Subscribe to store state
36
+ const instances = useModuleStore((state) => state.instances);
37
+ const agents = useGraphStore((state) => state.agents);
38
+ const messages = useGraphStore((state) => state.messages);
39
+ const events = useGraphStore((state) => state.events);
40
+ const correlationId = useFilterStore((state) => state.correlationId);
41
+ const timeRange = useFilterStore((state) => state.timeRange);
42
+
43
+ // Track previous instances to detect changes
44
+ const prevInstancesRef = useRef<Map<string, any>>(new Map());
45
+
46
+ // Build ModuleContext
47
+ const context: ModuleContext = useMemo(
48
+ () => ({
49
+ agents,
50
+ messages,
51
+ events,
52
+ filters: {
53
+ correlationId,
54
+ timeRange,
55
+ },
56
+ publish: (artifact: any) => {
57
+ // Placeholder: In production, this would dispatch to WebSocket
58
+ console.log('[Module Context] Publish artifact:', artifact);
59
+ },
60
+ invoke: (agentName: string, inputs: any[]) => {
61
+ // Placeholder: In production, this would dispatch to WebSocket
62
+ console.log('[Module Context] Invoke agent:', agentName, 'with inputs:', inputs);
63
+ },
64
+ }),
65
+ [agents, messages, events, correlationId, timeRange]
66
+ );
67
+
68
+ /**
69
+ * Lifecycle effect: Call onMount/onUnmount hooks when instances change
70
+ */
71
+ useEffect(() => {
72
+ const currentInstances = instances;
73
+ const prevInstances = prevInstancesRef.current;
74
+
75
+ // Detect added instances (in current but not in previous)
76
+ const addedInstances = new Map<string, any>();
77
+ currentInstances.forEach((instance, id) => {
78
+ if (!prevInstances.has(id)) {
79
+ addedInstances.set(id, instance);
80
+ }
81
+ });
82
+
83
+ // Detect removed instances (in previous but not in current)
84
+ const removedInstances = new Map<string, any>();
85
+ prevInstances.forEach((instance, id) => {
86
+ if (!currentInstances.has(id)) {
87
+ removedInstances.set(id, instance);
88
+ }
89
+ });
90
+
91
+ // Call onMount for added instances
92
+ addedInstances.forEach((instance) => {
93
+ const module = moduleRegistry.get(instance.type);
94
+ if (module?.onMount) {
95
+ console.log(`[useModules] Calling onMount for module: ${module.name} (${instance.id})`);
96
+ try {
97
+ module.onMount(context);
98
+ } catch (error) {
99
+ console.error(`[useModules] Error in onMount for module ${module.name}:`, error);
100
+ }
101
+ }
102
+ });
103
+
104
+ // Call onUnmount for removed instances
105
+ removedInstances.forEach((instance) => {
106
+ const module = moduleRegistry.get(instance.type);
107
+ if (module?.onUnmount) {
108
+ console.log(`[useModules] Calling onUnmount for module: ${module.name} (${instance.id})`);
109
+ try {
110
+ module.onUnmount();
111
+ } catch (error) {
112
+ console.error(`[useModules] Error in onUnmount for module ${module.name}:`, error);
113
+ }
114
+ }
115
+ });
116
+
117
+ // Update previous instances ref for next comparison
118
+ prevInstancesRef.current = new Map(currentInstances);
119
+
120
+ // Cleanup: Call onUnmount for all instances when hook unmounts
121
+ return () => {
122
+ currentInstances.forEach((instance) => {
123
+ const module = moduleRegistry.get(instance.type);
124
+ if (module?.onUnmount) {
125
+ console.log(`[useModules] Cleanup: Calling onUnmount for module: ${module.name} (${instance.id})`);
126
+ try {
127
+ module.onUnmount();
128
+ } catch (error) {
129
+ console.error(`[useModules] Error in cleanup onUnmount for module ${module.name}:`, error);
130
+ }
131
+ }
132
+ });
133
+ };
134
+ }, [instances, context]);
135
+
136
+ return {
137
+ context,
138
+ };
139
+ }
@@ -0,0 +1,139 @@
1
+ /**
2
+ * usePersistence Hook - Node Position Persistence
3
+ *
4
+ * Provides position persistence for graph nodes using IndexedDB.
5
+ * Manages loading and saving of node positions with debouncing.
6
+ * Handles separate layouts for Agent View and Blackboard View.
7
+ *
8
+ * SPECIFICATION: docs/specs/003-real-time-dashboard/FRONTEND_ARCHITECTURE.md
9
+ * - Debounce: 300ms delay on drag stop
10
+ * - Performance: Position save <50ms (after debounce)
11
+ * - Separate layouts for Agent View vs Blackboard View
12
+ */
13
+
14
+ import { useEffect, useCallback, useRef } from 'react';
15
+ import { useGraphStore } from '../store/graphStore';
16
+ import { useUIStore, VisualizationMode } from '../store/uiStore';
17
+ import { indexedDBService } from '../services/indexeddb';
18
+
19
+ interface Position {
20
+ x: number;
21
+ y: number;
22
+ }
23
+
24
+ /**
25
+ * Custom debounce implementation
26
+ * Creates a debounced function that delays invoking func until after delay milliseconds
27
+ */
28
+ function debounce<T extends (...args: any[]) => void>(
29
+ func: T,
30
+ delay: number
31
+ ): (...args: Parameters<T>) => void {
32
+ let timeoutId: ReturnType<typeof setTimeout> | null = null;
33
+
34
+ return (...args: Parameters<T>) => {
35
+ if (timeoutId) {
36
+ clearTimeout(timeoutId);
37
+ }
38
+
39
+ timeoutId = setTimeout(() => {
40
+ func(...args);
41
+ timeoutId = null;
42
+ }, delay);
43
+ };
44
+ }
45
+
46
+ /**
47
+ * React hook for node position persistence
48
+ *
49
+ * Features:
50
+ * - Loads node positions from IndexedDB on mount
51
+ * - Applies loaded positions to graphStore
52
+ * - Returns debounced saveNodePosition function (300ms delay)
53
+ * - Handles mode switching (reloads positions for new mode)
54
+ *
55
+ * @returns {Object} Hook return value
56
+ * @returns {Function} saveNodePosition - Debounced function to save node position
57
+ */
58
+ export function usePersistence() {
59
+ const mode = useUIStore((state) => state.mode);
60
+ const updateNodePosition = useGraphStore((state) => state.updateNodePosition);
61
+
62
+ // Use ref to maintain debounced function identity across renders
63
+ const debouncedSaveRef = useRef<((nodeId: string, mode: VisualizationMode, position: Position) => void) | null>(null);
64
+
65
+ // Initialize debounced save function once
66
+ if (!debouncedSaveRef.current) {
67
+ debouncedSaveRef.current = debounce(
68
+ async (nodeId: string, mode: VisualizationMode, position: Position) => {
69
+ try {
70
+ console.log(`[usePersistence] Saving position for ${nodeId} in ${mode} view:`, position);
71
+ const layoutRecord = {
72
+ node_id: nodeId,
73
+ x: position.x,
74
+ y: position.y,
75
+ last_updated: new Date().toISOString(),
76
+ };
77
+
78
+ if (mode === 'agent') {
79
+ await indexedDBService.saveAgentViewLayout(layoutRecord);
80
+ console.log(`[usePersistence] ✓ Saved to agent view layout`);
81
+ } else {
82
+ await indexedDBService.saveBlackboardViewLayout(layoutRecord);
83
+ console.log(`[usePersistence] ✓ Saved to blackboard view layout`);
84
+ }
85
+ } catch (error) {
86
+ console.error(`[usePersistence] Failed to save node position for ${nodeId}:`, error);
87
+ }
88
+ },
89
+ 300 // 300ms debounce delay as per specification
90
+ );
91
+ }
92
+
93
+ /**
94
+ * Load node positions from IndexedDB for current mode
95
+ */
96
+ const loadNodePositions = useCallback(async (currentMode: VisualizationMode) => {
97
+ try {
98
+ let layouts: Array<{ node_id: string; x: number; y: number; last_updated: string }> = [];
99
+
100
+ if (currentMode === 'agent') {
101
+ layouts = await indexedDBService.getAllAgentViewLayouts();
102
+ } else {
103
+ layouts = await indexedDBService.getAllBlackboardViewLayouts();
104
+ }
105
+
106
+ // Apply loaded positions to graph store
107
+ layouts.forEach((layout) => {
108
+ updateNodePosition(layout.node_id, { x: layout.x, y: layout.y });
109
+ });
110
+
111
+ console.log(`[usePersistence] Loaded ${layouts.length} node positions for ${currentMode} view`);
112
+ } catch (error) {
113
+ console.error(`[usePersistence] Failed to load node positions for ${currentMode} view:`, error);
114
+ }
115
+ }, [updateNodePosition]);
116
+
117
+ /**
118
+ * Load positions on mount and when mode changes
119
+ */
120
+ useEffect(() => {
121
+ loadNodePositions(mode);
122
+ }, [mode, loadNodePositions]);
123
+
124
+ /**
125
+ * Public API: Save node position with debouncing
126
+ */
127
+ const saveNodePosition = useCallback(
128
+ (nodeId: string, position: Position) => {
129
+ if (debouncedSaveRef.current) {
130
+ debouncedSaveRef.current(nodeId, mode, position);
131
+ }
132
+ },
133
+ [mode]
134
+ );
135
+
136
+ return {
137
+ saveNodePosition,
138
+ };
139
+ }
@@ -0,0 +1,13 @@
1
+ import ReactDOM from 'react-dom/client';
2
+ import App from './App';
3
+ import './styles/index.css';
4
+
5
+ // Mock data removed - dashboard now starts empty and shows only real WebSocket data
6
+
7
+ const rootElement = document.getElementById('root');
8
+
9
+ if (!rootElement) {
10
+ throw new Error('Root element not found');
11
+ }
12
+
13
+ ReactDOM.createRoot(rootElement).render(<App />);
@@ -0,0 +1,213 @@
1
+ /**
2
+ * REST API client for orchestrator control operations.
3
+ *
4
+ * Provides methods to publish artifacts and invoke agents via HTTP endpoints.
5
+ * Handles error responses and provides typed return values.
6
+ *
7
+ * Base URL defaults to /api for same-origin requests.
8
+ */
9
+
10
+ const BASE_URL = import.meta.env.VITE_API_BASE_URL || '/api';
11
+
12
+ export interface ArtifactType {
13
+ name: string;
14
+ schema: {
15
+ type: string;
16
+ properties: Record<string, any>;
17
+ };
18
+ }
19
+
20
+ export interface Agent {
21
+ name: string;
22
+ description: string;
23
+ status: string;
24
+ subscriptions: string[];
25
+ output_types: string[];
26
+ }
27
+
28
+ export interface PublishResponse {
29
+ status: string;
30
+ correlation_id: string;
31
+ message: string;
32
+ }
33
+
34
+ export interface InvokeResponse {
35
+ status: string;
36
+ invocation_id: string;
37
+ correlation_id?: string | null;
38
+ agent: string;
39
+ message: string;
40
+ }
41
+
42
+ export interface ArtifactTypesResponse {
43
+ artifact_types: ArtifactType[];
44
+ }
45
+
46
+ export interface AgentsResponse {
47
+ agents: Agent[];
48
+ }
49
+
50
+ export interface ErrorResponse {
51
+ error: string;
52
+ message: string;
53
+ }
54
+
55
+ class ApiError extends Error {
56
+ constructor(public status: number, public errorResponse: ErrorResponse) {
57
+ super(errorResponse.message || errorResponse.error);
58
+ this.name = 'ApiError';
59
+ }
60
+ }
61
+
62
+ /**
63
+ * Fetch artifact types from orchestrator
64
+ */
65
+ export async function fetchArtifactTypes(): Promise<ArtifactType[]> {
66
+ try {
67
+ const response = await fetch(`${BASE_URL}/artifact-types`, {
68
+ method: 'GET',
69
+ headers: {
70
+ 'Content-Type': 'application/json',
71
+ },
72
+ });
73
+
74
+ if (!response.ok) {
75
+ const errorData = await response.json().catch(() => ({
76
+ error: 'Unknown error',
77
+ message: 'Failed to fetch artifact types',
78
+ }));
79
+ throw new ApiError(response.status, errorData);
80
+ }
81
+
82
+ const data: ArtifactTypesResponse = await response.json();
83
+ return data.artifact_types;
84
+ } catch (error) {
85
+ if (error instanceof ApiError) {
86
+ throw error;
87
+ }
88
+ throw new Error('Failed to connect to API server');
89
+ }
90
+ }
91
+
92
+ /**
93
+ * Fetch available agents from orchestrator
94
+ */
95
+ export async function fetchAgents(): Promise<Agent[]> {
96
+ try {
97
+ const response = await fetch(`${BASE_URL}/agents`, {
98
+ method: 'GET',
99
+ headers: {
100
+ 'Content-Type': 'application/json',
101
+ },
102
+ });
103
+
104
+ if (!response.ok) {
105
+ const errorData = await response.json().catch(() => ({
106
+ error: 'Unknown error',
107
+ message: 'Failed to fetch agents',
108
+ }));
109
+ throw new ApiError(response.status, errorData);
110
+ }
111
+
112
+ const data: AgentsResponse = await response.json();
113
+ return data.agents;
114
+ } catch (error) {
115
+ if (error instanceof ApiError) {
116
+ throw error;
117
+ }
118
+ throw new Error('Failed to connect to API server');
119
+ }
120
+ }
121
+
122
+ /**
123
+ * Fetch registered agents and transform to graph store format
124
+ * Returns agents with 'idle' status ready for initial display
125
+ */
126
+ export async function fetchRegisteredAgents(): Promise<import('../types/graph').Agent[]> {
127
+ const agents = await fetchAgents();
128
+ return agents.map(agent => ({
129
+ id: agent.name,
130
+ name: agent.name,
131
+ status: 'idle' as const,
132
+ subscriptions: agent.subscriptions || [],
133
+ outputTypes: agent.output_types || [],
134
+ lastActive: Date.now(),
135
+ sentCount: 0,
136
+ recvCount: 0,
137
+ receivedByType: {},
138
+ sentByType: {},
139
+ }));
140
+ }
141
+
142
+ /**
143
+ * Publish an artifact to the orchestrator
144
+ * @param artifactType - The type of artifact to publish
145
+ * @param content - The artifact content as a parsed JSON object
146
+ * @returns Response with correlation ID
147
+ */
148
+ export async function publishArtifact(
149
+ artifactType: string,
150
+ content: any
151
+ ): Promise<PublishResponse> {
152
+ try {
153
+ const response = await fetch(`${BASE_URL}/control/publish`, {
154
+ method: 'POST',
155
+ headers: {
156
+ 'Content-Type': 'application/json',
157
+ },
158
+ body: JSON.stringify({
159
+ artifact_type: artifactType,
160
+ content: content,
161
+ }),
162
+ });
163
+
164
+ if (!response.ok) {
165
+ const errorData = await response.json().catch(() => ({
166
+ error: 'Unknown error',
167
+ message: 'Failed to publish artifact',
168
+ }));
169
+ throw new ApiError(response.status, errorData);
170
+ }
171
+
172
+ return await response.json();
173
+ } catch (error) {
174
+ if (error instanceof ApiError) {
175
+ throw error;
176
+ }
177
+ throw new Error('Failed to connect to API server');
178
+ }
179
+ }
180
+
181
+ /**
182
+ * Invoke an agent via the orchestrator
183
+ * @param agentName - The name of the agent to invoke
184
+ * @returns Response with invocation ID
185
+ */
186
+ export async function invokeAgent(agentName: string): Promise<InvokeResponse> {
187
+ try {
188
+ const response = await fetch(`${BASE_URL}/control/invoke`, {
189
+ method: 'POST',
190
+ headers: {
191
+ 'Content-Type': 'application/json',
192
+ },
193
+ body: JSON.stringify({
194
+ agent: agentName,
195
+ }),
196
+ });
197
+
198
+ if (!response.ok) {
199
+ const errorData = await response.json().catch(() => ({
200
+ error: 'Unknown error',
201
+ message: 'Failed to invoke agent',
202
+ }));
203
+ throw new ApiError(response.status, errorData);
204
+ }
205
+
206
+ return await response.json();
207
+ } catch (error) {
208
+ if (error instanceof ApiError) {
209
+ throw error;
210
+ }
211
+ throw new Error('Failed to connect to API server');
212
+ }
213
+ }