flock-core 0.5.0b28__py3-none-any.whl → 0.5.56b0__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 (359) 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/{core/util → helper}/cli_helper.py +4 -3
  17. flock/{core/logging → logging}/__init__.py +2 -3
  18. flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
  19. flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
  20. flock/{core/logging → logging}/formatters/themed_formatter.py +69 -115
  21. flock/{core/logging → logging}/logging.py +77 -61
  22. flock/{core/logging → logging}/telemetry.py +20 -26
  23. flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
  24. flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +6 -9
  25. flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
  26. flock/{core/logging → logging}/trace_and_logged.py +20 -24
  27. flock/mcp/__init__.py +91 -0
  28. flock/{core/mcp/mcp_client.py → mcp/client.py} +103 -154
  29. flock/{core/mcp/mcp_config.py → mcp/config.py} +62 -117
  30. flock/mcp/manager.py +255 -0
  31. flock/mcp/servers/sse/__init__.py +1 -1
  32. flock/mcp/servers/sse/flock_sse_server.py +11 -53
  33. flock/mcp/servers/stdio/__init__.py +1 -1
  34. flock/mcp/servers/stdio/flock_stdio_server.py +8 -48
  35. flock/mcp/servers/streamable_http/flock_streamable_http_server.py +17 -62
  36. flock/mcp/servers/websockets/flock_websocket_server.py +7 -40
  37. flock/{core/mcp/flock_mcp_tool.py → mcp/tool.py} +16 -26
  38. flock/mcp/types/__init__.py +42 -0
  39. flock/{core/mcp → mcp}/types/callbacks.py +9 -15
  40. flock/{core/mcp → mcp}/types/factories.py +7 -6
  41. flock/{core/mcp → mcp}/types/handlers.py +13 -18
  42. flock/{core/mcp → mcp}/types/types.py +70 -74
  43. flock/{core/mcp → mcp}/util/helpers.py +1 -1
  44. flock/orchestrator.py +645 -0
  45. flock/registry.py +148 -0
  46. flock/runtime.py +262 -0
  47. flock/service.py +140 -0
  48. flock/store.py +69 -0
  49. flock/subscription.py +111 -0
  50. flock/themes/andromeda.toml +1 -1
  51. flock/themes/apple-system-colors.toml +1 -1
  52. flock/themes/arcoiris.toml +1 -1
  53. flock/themes/atomonelight.toml +1 -1
  54. flock/themes/ayu copy.toml +1 -1
  55. flock/themes/ayu-light.toml +1 -1
  56. flock/themes/belafonte-day.toml +1 -1
  57. flock/themes/belafonte-night.toml +1 -1
  58. flock/themes/blulocodark.toml +1 -1
  59. flock/themes/breeze.toml +1 -1
  60. flock/themes/broadcast.toml +1 -1
  61. flock/themes/brogrammer.toml +1 -1
  62. flock/themes/builtin-dark.toml +1 -1
  63. flock/themes/builtin-pastel-dark.toml +1 -1
  64. flock/themes/catppuccin-latte.toml +1 -1
  65. flock/themes/catppuccin-macchiato.toml +1 -1
  66. flock/themes/catppuccin-mocha.toml +1 -1
  67. flock/themes/cga.toml +1 -1
  68. flock/themes/chalk.toml +1 -1
  69. flock/themes/ciapre.toml +1 -1
  70. flock/themes/coffee-theme.toml +1 -1
  71. flock/themes/cyberpunkscarletprotocol.toml +1 -1
  72. flock/themes/dark+.toml +1 -1
  73. flock/themes/darkermatrix.toml +1 -1
  74. flock/themes/darkside.toml +1 -1
  75. flock/themes/desert.toml +1 -1
  76. flock/themes/django.toml +1 -1
  77. flock/themes/djangosmooth.toml +1 -1
  78. flock/themes/doomone.toml +1 -1
  79. flock/themes/dotgov.toml +1 -1
  80. flock/themes/dracula+.toml +1 -1
  81. flock/themes/duckbones.toml +1 -1
  82. flock/themes/encom.toml +1 -1
  83. flock/themes/espresso.toml +1 -1
  84. flock/themes/everblush.toml +1 -1
  85. flock/themes/fairyfloss.toml +1 -1
  86. flock/themes/fideloper.toml +1 -1
  87. flock/themes/fishtank.toml +1 -1
  88. flock/themes/flexoki-light.toml +1 -1
  89. flock/themes/floraverse.toml +1 -1
  90. flock/themes/framer.toml +1 -1
  91. flock/themes/galizur.toml +1 -1
  92. flock/themes/github.toml +1 -1
  93. flock/themes/grass.toml +1 -1
  94. flock/themes/grey-green.toml +1 -1
  95. flock/themes/gruvboxlight.toml +1 -1
  96. flock/themes/guezwhoz.toml +1 -1
  97. flock/themes/harper.toml +1 -1
  98. flock/themes/hax0r-blue.toml +1 -1
  99. flock/themes/hopscotch.256.toml +1 -1
  100. flock/themes/ic-green-ppl.toml +1 -1
  101. flock/themes/iceberg-dark.toml +1 -1
  102. flock/themes/japanesque.toml +1 -1
  103. flock/themes/jubi.toml +1 -1
  104. flock/themes/kibble.toml +1 -1
  105. flock/themes/kolorit.toml +1 -1
  106. flock/themes/kurokula.toml +1 -1
  107. flock/themes/materialdesigncolors.toml +1 -1
  108. flock/themes/matrix.toml +1 -1
  109. flock/themes/mellifluous.toml +1 -1
  110. flock/themes/midnight-in-mojave.toml +1 -1
  111. flock/themes/monokai-remastered.toml +1 -1
  112. flock/themes/monokai-soda.toml +1 -1
  113. flock/themes/neon.toml +1 -1
  114. flock/themes/neopolitan.toml +1 -1
  115. flock/themes/nord-light.toml +1 -1
  116. flock/themes/ocean.toml +1 -1
  117. flock/themes/onehalfdark.toml +1 -1
  118. flock/themes/onehalflight.toml +1 -1
  119. flock/themes/palenighthc.toml +1 -1
  120. flock/themes/paulmillr.toml +1 -1
  121. flock/themes/pencildark.toml +1 -1
  122. flock/themes/pnevma.toml +1 -1
  123. flock/themes/purple-rain.toml +1 -1
  124. flock/themes/purplepeter.toml +1 -1
  125. flock/themes/raycast-dark.toml +1 -1
  126. flock/themes/red-sands.toml +1 -1
  127. flock/themes/relaxed.toml +1 -1
  128. flock/themes/retro.toml +1 -1
  129. flock/themes/rose-pine.toml +1 -1
  130. flock/themes/royal.toml +1 -1
  131. flock/themes/ryuuko.toml +1 -1
  132. flock/themes/sakura.toml +1 -1
  133. flock/themes/scarlet-protocol.toml +1 -1
  134. flock/themes/seoulbones-dark.toml +1 -1
  135. flock/themes/shades-of-purple.toml +1 -1
  136. flock/themes/smyck.toml +1 -1
  137. flock/themes/softserver.toml +1 -1
  138. flock/themes/solarized-darcula.toml +1 -1
  139. flock/themes/square.toml +1 -1
  140. flock/themes/sugarplum.toml +1 -1
  141. flock/themes/thayer-bright.toml +1 -1
  142. flock/themes/tokyonight.toml +1 -1
  143. flock/themes/tomorrow.toml +1 -1
  144. flock/themes/ubuntu.toml +1 -1
  145. flock/themes/ultradark.toml +1 -1
  146. flock/themes/ultraviolent.toml +1 -1
  147. flock/themes/unikitty.toml +1 -1
  148. flock/themes/urple.toml +1 -1
  149. flock/themes/vesper.toml +1 -1
  150. flock/themes/vimbones.toml +1 -1
  151. flock/themes/wildcherry.toml +1 -1
  152. flock/themes/wilmersdorf.toml +1 -1
  153. flock/themes/wryan.toml +1 -1
  154. flock/themes/xcodedarkhc.toml +1 -1
  155. flock/themes/xcodelight.toml +1 -1
  156. flock/themes/zenbones-light.toml +1 -1
  157. flock/themes/zenwritten-dark.toml +1 -1
  158. flock/utilities.py +301 -0
  159. flock/{components/utility → utility}/output_utility_component.py +68 -53
  160. flock/visibility.py +107 -0
  161. flock_core-0.5.56b0.dist-info/METADATA +747 -0
  162. flock_core-0.5.56b0.dist-info/RECORD +398 -0
  163. flock_core-0.5.56b0.dist-info/entry_points.txt +2 -0
  164. {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/licenses/LICENSE +1 -1
  165. flock/adapter/__init__.py +0 -14
  166. flock/adapter/azure_adapter.py +0 -68
  167. flock/adapter/chroma_adapter.py +0 -73
  168. flock/adapter/faiss_adapter.py +0 -97
  169. flock/adapter/pinecone_adapter.py +0 -51
  170. flock/adapter/vector_base.py +0 -47
  171. flock/cli/assets/release_notes.md +0 -140
  172. flock/cli/config.py +0 -8
  173. flock/cli/constants.py +0 -36
  174. flock/cli/create_agent.py +0 -1
  175. flock/cli/create_flock.py +0 -280
  176. flock/cli/execute_flock.py +0 -620
  177. flock/cli/load_agent.py +0 -1
  178. flock/cli/load_examples.py +0 -1
  179. flock/cli/load_flock.py +0 -192
  180. flock/cli/load_release_notes.py +0 -20
  181. flock/cli/loaded_flock_cli.py +0 -254
  182. flock/cli/manage_agents.py +0 -459
  183. flock/cli/registry_management.py +0 -889
  184. flock/cli/runner.py +0 -41
  185. flock/cli/settings.py +0 -857
  186. flock/cli/utils.py +0 -135
  187. flock/cli/view_results.py +0 -29
  188. flock/cli/yaml_editor.py +0 -396
  189. flock/components/__init__.py +0 -30
  190. flock/components/evaluation/__init__.py +0 -9
  191. flock/components/evaluation/declarative_evaluation_component.py +0 -606
  192. flock/components/routing/__init__.py +0 -15
  193. flock/components/routing/conditional_routing_component.py +0 -494
  194. flock/components/routing/default_routing_component.py +0 -103
  195. flock/components/routing/llm_routing_component.py +0 -206
  196. flock/components/utility/__init__.py +0 -22
  197. flock/components/utility/example_utility_component.py +0 -250
  198. flock/components/utility/feedback_utility_component.py +0 -206
  199. flock/components/utility/memory_utility_component.py +0 -550
  200. flock/components/utility/metrics_utility_component.py +0 -700
  201. flock/config.py +0 -61
  202. flock/core/__init__.py +0 -110
  203. flock/core/agent/__init__.py +0 -16
  204. flock/core/agent/default_agent.py +0 -216
  205. flock/core/agent/flock_agent_components.py +0 -104
  206. flock/core/agent/flock_agent_execution.py +0 -101
  207. flock/core/agent/flock_agent_integration.py +0 -260
  208. flock/core/agent/flock_agent_lifecycle.py +0 -186
  209. flock/core/agent/flock_agent_serialization.py +0 -381
  210. flock/core/api/__init__.py +0 -10
  211. flock/core/api/custom_endpoint.py +0 -45
  212. flock/core/api/endpoints.py +0 -254
  213. flock/core/api/main.py +0 -162
  214. flock/core/api/models.py +0 -97
  215. flock/core/api/run_store.py +0 -224
  216. flock/core/api/runner.py +0 -44
  217. flock/core/api/service.py +0 -214
  218. flock/core/component/__init__.py +0 -15
  219. flock/core/component/agent_component_base.py +0 -309
  220. flock/core/component/evaluation_component.py +0 -62
  221. flock/core/component/routing_component.py +0 -74
  222. flock/core/component/utility_component.py +0 -69
  223. flock/core/config/flock_agent_config.py +0 -58
  224. flock/core/config/scheduled_agent_config.py +0 -40
  225. flock/core/context/context.py +0 -213
  226. flock/core/context/context_manager.py +0 -37
  227. flock/core/context/context_vars.py +0 -10
  228. flock/core/evaluation/utils.py +0 -396
  229. flock/core/execution/batch_executor.py +0 -369
  230. flock/core/execution/evaluation_executor.py +0 -438
  231. flock/core/execution/local_executor.py +0 -31
  232. flock/core/execution/opik_executor.py +0 -103
  233. flock/core/execution/temporal_executor.py +0 -164
  234. flock/core/flock.py +0 -634
  235. flock/core/flock_agent.py +0 -336
  236. flock/core/flock_factory.py +0 -613
  237. flock/core/flock_scheduler.py +0 -166
  238. flock/core/flock_server_manager.py +0 -136
  239. flock/core/interpreter/python_interpreter.py +0 -689
  240. flock/core/mcp/__init__.py +0 -1
  241. flock/core/mcp/flock_mcp_server.py +0 -680
  242. flock/core/mcp/mcp_client_manager.py +0 -201
  243. flock/core/mcp/types/__init__.py +0 -1
  244. flock/core/mixin/dspy_integration.py +0 -403
  245. flock/core/mixin/prompt_parser.py +0 -125
  246. flock/core/orchestration/__init__.py +0 -15
  247. flock/core/orchestration/flock_batch_processor.py +0 -94
  248. flock/core/orchestration/flock_evaluator.py +0 -113
  249. flock/core/orchestration/flock_execution.py +0 -295
  250. flock/core/orchestration/flock_initialization.py +0 -149
  251. flock/core/orchestration/flock_server_manager.py +0 -67
  252. flock/core/orchestration/flock_web_server.py +0 -117
  253. flock/core/registry/__init__.py +0 -45
  254. flock/core/registry/agent_registry.py +0 -69
  255. flock/core/registry/callable_registry.py +0 -139
  256. flock/core/registry/component_discovery.py +0 -142
  257. flock/core/registry/component_registry.py +0 -64
  258. flock/core/registry/config_mapping.py +0 -64
  259. flock/core/registry/decorators.py +0 -137
  260. flock/core/registry/registry_hub.py +0 -205
  261. flock/core/registry/server_registry.py +0 -57
  262. flock/core/registry/type_registry.py +0 -86
  263. flock/core/serialization/__init__.py +0 -13
  264. flock/core/serialization/callable_registry.py +0 -52
  265. flock/core/serialization/flock_serializer.py +0 -832
  266. flock/core/serialization/json_encoder.py +0 -41
  267. flock/core/serialization/secure_serializer.py +0 -175
  268. flock/core/serialization/serializable.py +0 -342
  269. flock/core/serialization/serialization_utils.py +0 -412
  270. flock/core/util/file_path_utils.py +0 -223
  271. flock/core/util/hydrator.py +0 -309
  272. flock/core/util/input_resolver.py +0 -164
  273. flock/core/util/loader.py +0 -59
  274. flock/core/util/splitter.py +0 -219
  275. flock/di.py +0 -27
  276. flock/platform/docker_tools.py +0 -49
  277. flock/platform/jaeger_install.py +0 -86
  278. flock/webapp/__init__.py +0 -1
  279. flock/webapp/app/__init__.py +0 -0
  280. flock/webapp/app/api/__init__.py +0 -0
  281. flock/webapp/app/api/agent_management.py +0 -241
  282. flock/webapp/app/api/execution.py +0 -709
  283. flock/webapp/app/api/flock_management.py +0 -129
  284. flock/webapp/app/api/registry_viewer.py +0 -30
  285. flock/webapp/app/chat.py +0 -665
  286. flock/webapp/app/config.py +0 -104
  287. flock/webapp/app/dependencies.py +0 -117
  288. flock/webapp/app/main.py +0 -1070
  289. flock/webapp/app/middleware.py +0 -113
  290. flock/webapp/app/models_ui.py +0 -7
  291. flock/webapp/app/services/__init__.py +0 -0
  292. flock/webapp/app/services/feedback_file_service.py +0 -363
  293. flock/webapp/app/services/flock_service.py +0 -337
  294. flock/webapp/app/services/sharing_models.py +0 -81
  295. flock/webapp/app/services/sharing_store.py +0 -762
  296. flock/webapp/app/templates/theme_mapper.html +0 -326
  297. flock/webapp/app/theme_mapper.py +0 -812
  298. flock/webapp/app/utils.py +0 -85
  299. flock/webapp/run.py +0 -215
  300. flock/webapp/static/css/chat.css +0 -301
  301. flock/webapp/static/css/components.css +0 -167
  302. flock/webapp/static/css/header.css +0 -39
  303. flock/webapp/static/css/layout.css +0 -46
  304. flock/webapp/static/css/sidebar.css +0 -127
  305. flock/webapp/static/css/two-pane.css +0 -48
  306. flock/webapp/templates/base.html +0 -200
  307. flock/webapp/templates/chat.html +0 -152
  308. flock/webapp/templates/chat_settings.html +0 -19
  309. flock/webapp/templates/flock_editor.html +0 -16
  310. flock/webapp/templates/index.html +0 -12
  311. flock/webapp/templates/partials/_agent_detail_form.html +0 -93
  312. flock/webapp/templates/partials/_agent_list.html +0 -18
  313. flock/webapp/templates/partials/_agent_manager_view.html +0 -51
  314. flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
  315. flock/webapp/templates/partials/_chat_container.html +0 -15
  316. flock/webapp/templates/partials/_chat_messages.html +0 -57
  317. flock/webapp/templates/partials/_chat_settings_form.html +0 -85
  318. flock/webapp/templates/partials/_create_flock_form.html +0 -50
  319. flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
  320. flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
  321. flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
  322. flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
  323. flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
  324. flock/webapp/templates/partials/_env_vars_table.html +0 -23
  325. flock/webapp/templates/partials/_execution_form.html +0 -118
  326. flock/webapp/templates/partials/_execution_view_container.html +0 -28
  327. flock/webapp/templates/partials/_flock_file_list.html +0 -23
  328. flock/webapp/templates/partials/_flock_properties_form.html +0 -52
  329. flock/webapp/templates/partials/_flock_upload_form.html +0 -16
  330. flock/webapp/templates/partials/_header_flock_status.html +0 -5
  331. flock/webapp/templates/partials/_load_manager_view.html +0 -49
  332. flock/webapp/templates/partials/_registry_table.html +0 -25
  333. flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
  334. flock/webapp/templates/partials/_results_display.html +0 -78
  335. flock/webapp/templates/partials/_settings_env_content.html +0 -9
  336. flock/webapp/templates/partials/_settings_theme_content.html +0 -14
  337. flock/webapp/templates/partials/_settings_view.html +0 -36
  338. flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
  339. flock/webapp/templates/partials/_share_link_snippet.html +0 -35
  340. flock/webapp/templates/partials/_sidebar.html +0 -74
  341. flock/webapp/templates/partials/_streaming_results_container.html +0 -195
  342. flock/webapp/templates/partials/_structured_data_view.html +0 -40
  343. flock/webapp/templates/partials/_theme_preview.html +0 -36
  344. flock/webapp/templates/registry_viewer.html +0 -84
  345. flock/webapp/templates/shared_run_page.html +0 -140
  346. flock/workflow/__init__.py +0 -0
  347. flock/workflow/activities.py +0 -196
  348. flock/workflow/agent_activities.py +0 -24
  349. flock/workflow/agent_execution_activity.py +0 -202
  350. flock/workflow/flock_workflow.py +0 -214
  351. flock/workflow/temporal_config.py +0 -96
  352. flock/workflow/temporal_setup.py +0 -68
  353. flock_core-0.5.0b28.dist-info/METADATA +0 -274
  354. flock_core-0.5.0b28.dist-info/RECORD +0 -561
  355. flock_core-0.5.0b28.dist-info/entry_points.txt +0 -2
  356. /flock/{core/logging → logging}/formatters/themes.py +0 -0
  357. /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
  358. /flock/{core/mcp → mcp}/util/__init__.py +0 -0
  359. {flock_core-0.5.0b28.dist-info → flock_core-0.5.56b0.dist-info}/WHEEL +0 -0
flock/webapp/app/utils.py DELETED
@@ -1,85 +0,0 @@
1
- import inspect
2
- import json
3
- from typing import Any
4
-
5
- def is_pydantic_model(obj: Any) -> bool:
6
- """
7
- Check if an object is a Pydantic model instance.
8
- More robust detection for both v1 and v2 Pydantic models.
9
- """
10
- # Check for Pydantic v2 model
11
- if hasattr(obj, "__class__") and hasattr(obj.__class__, "model_dump"):
12
- return True
13
-
14
- # Check for Pydantic v1 model
15
- if hasattr(obj, "__class__") and hasattr(obj.__class__, "schema") and hasattr(obj, "dict"):
16
- return True
17
-
18
- # Check if it has a __pydantic_core__ attribute (v2 models)
19
- if hasattr(obj, "__pydantic_core__"):
20
- return True
21
-
22
- # Final check: class name check and module check
23
- if hasattr(obj, "__class__"):
24
- cls = obj.__class__
25
- cls_name = cls.__name__
26
- module_name = getattr(cls, "__module__", "")
27
- if "pydantic" in module_name.lower() or "basemodel" in cls_name.lower():
28
- return True
29
-
30
- return False
31
-
32
- def is_json_serializable(obj: Any) -> bool:
33
- """Check if an object can be serialized to JSON."""
34
- try:
35
- json.dumps(obj)
36
- return True
37
- except (TypeError, ValueError):
38
- return False
39
-
40
- def pydantic_to_dict(obj: Any) -> Any:
41
- """
42
- Recursively convert Pydantic models to dictionaries.
43
- Works with nested models, lists, and dictionaries containing models.
44
- Falls back to string representation if object can't be serialized.
45
- """
46
- if obj is None:
47
- return None
48
-
49
- if is_pydantic_model(obj):
50
- # Handle Pydantic v2 models
51
- if hasattr(obj, "model_dump"):
52
- return obj.model_dump()
53
- # Handle Pydantic v1 models
54
- elif hasattr(obj, "dict"):
55
- return obj.dict()
56
- # Last resort - try __dict__ if it exists
57
- elif hasattr(obj, "__dict__"):
58
- return {k: pydantic_to_dict(v) for k, v in obj.__dict__.items()
59
- if not k.startswith("_")}
60
-
61
- elif isinstance(obj, dict):
62
- # Handle dictionaries that might contain Pydantic models
63
- return {k: pydantic_to_dict(v) for k, v in obj.items()}
64
-
65
- elif isinstance(obj, list):
66
- # Handle lists that might contain Pydantic models
67
- return [pydantic_to_dict(item) for item in obj]
68
-
69
- elif isinstance(obj, tuple) and hasattr(obj, '_fields'):
70
- # Handle namedtuples
71
- return dict(zip(obj._fields, (pydantic_to_dict(item) for item in obj)))
72
-
73
- elif isinstance(obj, (list, tuple)):
74
- # Handle regular lists and tuples
75
- return [pydantic_to_dict(item) for item in obj]
76
-
77
- # Final check - if object is not JSON serializable, convert to string
78
- if not is_json_serializable(obj):
79
- try:
80
- return str(obj)
81
- except Exception:
82
- return f"<Unserializable object of type {type(obj).__name__}>"
83
-
84
- # Return other types unchanged - these should be JSON serializable by default
85
- return obj
flock/webapp/run.py DELETED
@@ -1,215 +0,0 @@
1
- # src/flock/webapp/run.py
2
- import sys
3
- from collections.abc import Callable, Sequence
4
- from pathlib import Path
5
- from typing import TYPE_CHECKING, Any
6
-
7
- import uvicorn
8
-
9
- # Import core Flock components
10
- if TYPE_CHECKING:
11
- from flock.core.api.custom_endpoint import FlockEndpoint
12
- from flock.core.flock import Flock
13
-
14
- # --- Ensure src is in path for imports ---
15
- current_file_path = Path(__file__).resolve()
16
- flock_webapp_dir = current_file_path.parent
17
- flock_dir = flock_webapp_dir.parent
18
- src_dir = flock_dir.parent # Assuming `flock` is a package within `src`
19
-
20
- if str(src_dir) not in sys.path:
21
- sys.path.insert(0, str(src_dir))
22
-
23
- # --- Main Server Startup Function ---
24
- def start_unified_server(
25
- flock_instance: "Flock",
26
- host: str,
27
- port: int,
28
- server_title: str,
29
- enable_ui_routes: bool,
30
- enable_chat_routes: bool = False,
31
- ui_theme: str | None = None,
32
- custom_endpoints: Sequence["FlockEndpoint"] | dict[tuple[str, list[str] | None], Callable[..., Any]] | None = None,
33
- ):
34
- """Starts the unified FastAPI server for Flock.
35
- - Initializes the web application (imported from webapp.app.main).
36
- - Sets the provided Flock instance and a RunStore for dependency injection
37
- and makes them available via app.state.
38
- - Configures the UI theme.
39
- - Stores custom API endpoints for registration during app lifespan startup.
40
- - Optionally registers chat routes.
41
- - Runs Uvicorn.
42
- """
43
- print(f"Attempting to start unified server for Flock '{flock_instance.name}' on http://{host}:{port}")
44
- print(f"UI Routes Enabled: {enable_ui_routes}, Theme: {ui_theme or 'Default'}")
45
-
46
- try:
47
- # Import necessary webapp components HERE, after path setup.
48
- from flock.core.api.run_store import RunStore
49
- from flock.core.logging.logging import get_logger # For logging
50
- from flock.webapp.app.config import ( # For logging resolved theme
51
- get_current_theme_name,
52
- set_current_theme_name,
53
- )
54
- from flock.webapp.app.dependencies import (
55
- add_pending_custom_endpoints,
56
- set_global_flock_services,
57
- )
58
- from flock.webapp.app.main import (
59
- app as fastapi_app, # The single FastAPI app instance
60
- )
61
-
62
- logger = get_logger("webapp.run") # Use a logger
63
-
64
- # 1. Set UI Theme globally for the webapp
65
- set_current_theme_name(ui_theme)
66
- logger.info(f"Unified server configured to use theme: {get_current_theme_name()}")
67
-
68
- # 2. Create RunStore & Set Global Services for Dependency Injection
69
- run_store_instance = RunStore()
70
- set_global_flock_services(flock_instance, run_store_instance)
71
- logger.info("Global Flock instance and RunStore set for dependency injection.")
72
-
73
- # 3. Make Flock instance and filename available on app.state
74
- fastapi_app.state.flock_instance = flock_instance
75
- source_file_attr = "_source_file_path" # Attribute where Flock might store its load path
76
- fastapi_app.state.flock_filename = getattr(flock_instance, source_file_attr, None) or \
77
- f"{flock_instance.name.replace(' ', '_').lower()}.flock.yaml"
78
- fastapi_app.state.run_store = run_store_instance
79
- fastapi_app.state.chat_enabled = enable_chat_routes
80
-
81
- logger.info(f"Flock '{flock_instance.name}' (from '{fastapi_app.state.flock_filename}') made available via app.state.")
82
-
83
- # 4. Store Custom Endpoints for registration by the lifespan manager in app.main
84
- processed_custom_endpoints = []
85
- if custom_endpoints:
86
- from flock.core.api.custom_endpoint import (
87
- FlockEndpoint, # Ensure it's imported
88
- )
89
- if isinstance(custom_endpoints, dict):
90
- for (path_val, methods_val), cb_val in custom_endpoints.items():
91
- processed_custom_endpoints.append(
92
- FlockEndpoint(path=path_val, methods=list(methods_val) if methods_val else ["GET"], callback=cb_val)
93
- )
94
- else: # Assumed Sequence[FlockEndpoint]
95
- processed_custom_endpoints.extend(list(custom_endpoints))
96
-
97
- if processed_custom_endpoints:
98
- add_pending_custom_endpoints(processed_custom_endpoints)
99
- logger.info(f"{len(processed_custom_endpoints)} custom endpoints stored for registration by app lifespan.")
100
-
101
- # 5. Update FastAPI app title (FastAPI app instance is now imported from main)
102
- fastapi_app.title = server_title
103
-
104
- # 5a. Optionally strip UI routes if UI is disabled
105
- if not enable_ui_routes:
106
- from fastapi.routing import APIRoute
107
-
108
- allowed_tags = {"Flock API Core", "Flock API Custom Endpoints", "Chat"}
109
-
110
- def _route_is_allowed(route: APIRoute) -> bool: # type: ignore
111
- # Keep documentation and non-API utility routes (no tags)
112
- if not hasattr(route, "tags") or not route.tags:
113
- return True
114
- # Keep if any tag is in the allowed list
115
- return any(tag in allowed_tags for tag in route.tags) # type: ignore
116
-
117
- original_count = len(fastapi_app.router.routes)
118
- fastapi_app.router.routes = [r for r in fastapi_app.router.routes if _route_is_allowed(r)]
119
-
120
- # Clear cached OpenAPI schema so FastAPI regenerates it with the reduced route set
121
- if hasattr(fastapi_app, "openapi_schema"):
122
- fastapi_app.openapi_schema = None # type: ignore
123
-
124
- logger.info(
125
- f"UI disabled: removed {original_count - len(fastapi_app.router.routes)} UI routes. Remaining routes: {len(fastapi_app.router.routes)}"
126
- )
127
-
128
- # 5b. Include Chat routes if requested
129
- if enable_chat_routes:
130
- try:
131
- from flock.webapp.app.chat import (
132
- router as chat_router, # type: ignore
133
- )
134
- fastapi_app.include_router(chat_router, tags=["Chat"])
135
- logger.info("Chat routes enabled and registered.")
136
- except Exception as e:
137
- logger.error(f"Failed to include chat routes: {e}")
138
-
139
- # 6. Run Uvicorn
140
- logger.info(f"Running Uvicorn with application: flock.webapp.app.main:app")
141
- uvicorn.run(
142
- "flock.webapp.app.main:app",
143
- host=host,
144
- port=port,
145
- reload=False, # Critical for programmatically set state like flock_instance
146
- # root_path=os.getenv("FLOCK_ROOT_PATH", "")
147
- )
148
-
149
- except ImportError as e:
150
- # More specific error logging
151
- print(f"CRITICAL: Error importing components for unified server: {e}", file=sys.stderr)
152
- print(f"Module not found: {e.name}", file=sys.stderr)
153
- print("This usually means a problem with sys.path or missing dependencies.", file=sys.stderr)
154
- print(f"Current sys.path: {sys.path}", file=sys.stderr)
155
- sys.exit(1)
156
- except Exception as e:
157
- print(f"CRITICAL: Error starting unified server: {e}", file=sys.stderr)
158
- # Consider logging the full traceback for easier debugging
159
- import traceback
160
- traceback.print_exc(file=sys.stderr)
161
- sys.exit(1)
162
-
163
-
164
- # --- Standalone Webapp Runner (for `flock --web` or direct execution `python -m flock.webapp.run`) ---
165
- def main():
166
- """Runs the Flock web application in standalone mode.
167
- In this mode, no specific Flock is pre-loaded by the startup script;
168
- the user will load or create one via the UI.
169
- The FastAPI app (`webapp.app.main:app`) will initialize with DI services
170
- set to None for Flock, and a new RunStore.
171
- """
172
- print("Starting Flock web application in standalone mode...")
173
-
174
- from flock.core.api.run_store import RunStore
175
- from flock.webapp.app.config import (
176
- get_current_theme_name, # To log the theme being used
177
- )
178
- from flock.webapp.app.dependencies import set_global_flock_services
179
-
180
- # No pre-loaded Flock instance; create a RunStore so API calls can still function
181
- standalone_run_store = RunStore()
182
- set_global_flock_services(None, standalone_run_store)
183
-
184
- print(
185
- f"Standalone mode: Initialized global services. Flock: None, RunStore: {type(standalone_run_store)}"
186
- )
187
- print(f"Standalone webapp using theme: {get_current_theme_name()}")
188
-
189
- host = "127.0.0.1"
190
- port = 8344
191
- try:
192
- import os
193
-
194
- host = os.environ.get("FLOCK_WEB_HOST", host)
195
- port = int(os.environ.get("FLOCK_WEB_PORT", port))
196
- webapp_reload = os.environ.get("FLOCK_WEB_RELOAD", "true").lower() == "true"
197
- except Exception:
198
- webapp_reload = True
199
-
200
- app_import_string = "flock.webapp.app.main:app"
201
- print(
202
- f"Running Uvicorn: app='{app_import_string}', host='{host}', port={port}, reload={webapp_reload}"
203
- )
204
-
205
- uvicorn.run(
206
- app_import_string,
207
- host=host,
208
- port=port,
209
- reload=webapp_reload,
210
- # root_path=os.getenv("FLOCK_ROOT_PATH", "")
211
- )
212
-
213
-
214
- if __name__ == "__main__":
215
- main()
@@ -1,301 +0,0 @@
1
- /* --- Enhanced Chat Styles --- */
2
- body.chat-page {
3
- display: block;
4
- padding: 0;
5
- margin: 0;
6
- height: 100vh;
7
- width: 100vw;
8
- overflow: hidden;
9
- background-color: var(--pico-background-color);
10
- }
11
-
12
- #chat-container {
13
- /* Allow the chat container to grow to full width on small screens,
14
- but cap it at 80% of the viewport on larger displays and
15
- center it horizontally. */
16
- width: 100%;
17
- max-width: 80%;
18
- margin: 0 auto;
19
- display: flex;
20
- flex-direction: column;
21
- height: 100vh;
22
- background-color: var(--pico-background-color);
23
- overflow: hidden;
24
- }
25
-
26
- #chat-log {
27
- flex: 1;
28
- overflow-y: auto;
29
- padding: 1rem 1.5rem;
30
- display: flex;
31
- flex-direction: column;
32
- min-height: 0;
33
- gap: 1rem;
34
- background-color: rgba(0, 0, 0, 0.05);
35
- background-image:
36
- radial-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
37
- radial-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px);
38
- background-size: 20px 20px;
39
- background-position: 0 0, 10px 10px;
40
- }
41
-
42
-
43
-
44
- .bubble {
45
- position: relative;
46
- padding: 0.75rem 1rem;
47
- border-radius: 1.2rem;
48
- max-width: 80%;
49
- margin: 0.25rem 0;
50
- box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
51
- animation: fadeIn 0.3s ease-out;
52
- word-break: break-word;
53
- line-height: 1.4;
54
- }
55
-
56
- @keyframes fadeIn {
57
- from { opacity: 0; transform: translateY(10px); }
58
- to { opacity: 1; transform: translateY(0); }
59
- }
60
-
61
- .bubble.user {
62
- background: var(--pico-primary);
63
- color: var(--pico-button-base-color);
64
- margin-left: auto;
65
- border-bottom-right-radius: 0.3rem;
66
- text-align: right;
67
- }
68
-
69
- .bubble.user::after {
70
- content: '';
71
- position: absolute;
72
- bottom: 0;
73
- right: -0.5rem;
74
- width: 1rem;
75
- height: 1rem;
76
- background: var(--pico-primary-hover, var(--pico-primary));
77
- clip-path: polygon(0 0, 0% 100%, 100% 100%);
78
- }
79
-
80
- .bubble.bot {
81
- background: var(--pico-code-background-color);
82
- color: var(--pico-code-color);
83
- margin-right: auto;
84
- border-bottom-left-radius: 0.3rem;
85
- }
86
-
87
- .bubble.bot::after {
88
- content: '';
89
- position: absolute;
90
- bottom: 0;
91
- left: -0.5rem;
92
- width: 1rem;
93
- height: 1rem;
94
- background: var(--pico-code-background-color);
95
- clip-path: polygon(100% 0, 0% 100%, 100% 100%);
96
- }
97
-
98
- #chat-container form {
99
- display: flex;
100
- gap: 0.5rem;
101
- margin: 0;
102
- padding: 1rem;
103
- background-color: var(--pico-card-background-color);
104
- border-top: 1px solid var(--pico-muted-border-color);
105
- }
106
-
107
- #chat-container form input[type="text"] {
108
- flex: 1;
109
- border-radius: 2rem;
110
- padding-left: 1.25rem;
111
- background-color: var(--pico-background-color);
112
- border: 1px solid var(--pico-muted-border-color);
113
- transition: all 0.2s ease;
114
- height: 3rem;
115
- font-size: 1rem;
116
- }
117
-
118
- #chat-container form input[type="text"]:focus {
119
- border-color: var(--pico-primary);
120
- box-shadow: 0 0 0 2px rgba(var(--pico-primary-rgb, 0, 123, 255), 0.25);
121
- }
122
-
123
- #chat-container form button[type="submit"] {
124
- flex: 0 0 auto;
125
- min-width: auto;
126
- width: 150px; /* Wider send button */
127
- padding: 0 1rem;
128
- border-radius: 2rem;
129
- background: var(--pico-primary);
130
- color: var(--pico-button-base-color);
131
- font-weight: 600;
132
- transition: all 0.2s ease;
133
- margin-left: 0.5rem;
134
- height: 3rem;
135
- }
136
-
137
- #chat-container form button[type="submit"]:hover {
138
- background: var(--pico-primary-hover, var(--pico-primary));
139
- transform: translateY(-2px);
140
- box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
141
- }
142
-
143
- .chat-header {
144
- padding: 1rem 1.5rem;
145
- background-color: var(--pico-card-background-color);
146
- border-bottom: 1px solid var(--pico-muted-border-color);
147
- display: flex;
148
- align-items: center;
149
- justify-content: space-between;
150
- flex-shrink: 0;
151
- }
152
-
153
- .chat-header h2 {
154
- margin: 0;
155
- font-size: 1.5rem;
156
- color: var(--pico-color);
157
- }
158
-
159
- .chat-header h3 {
160
- margin: 0;
161
- font-size: 0.9rem;
162
- color: var(--pico-muted-color);
163
- font-weight: normal;
164
- }
165
-
166
- .chat-timestamp {
167
- display: block;
168
- font-size: 0.7rem;
169
- color: var(--pico-button-base-color);
170
- margin-top: 0.25rem;
171
- opacity: 0.8;
172
- }
173
-
174
- .chat-footer {
175
- padding: 0.5rem 1rem;
176
- text-align: center;
177
- font-size: 0.8rem;
178
- color: var(--pico-muted-color);
179
- background-color: var(--pico-card-background-color);
180
- border-top: 1px solid var(--pico-muted-border-color);
181
- flex-shrink: 0;
182
- }
183
- /* --- End Enhanced Chat Styles --- */
184
-
185
- /* -------------------------------------------------------------------------
186
- Chat container tweaks when embedded in the main UI (non-standalone mode)
187
- ------------------------------------------------------------------------- */
188
- body:not(.chat-page) #chat-container,
189
- body:not(.chat-page) .chat-container {
190
- height: 100%;
191
- min-height: 100%;
192
- /* allow full width inside the main content area */
193
- width: 100%;
194
- max-width: 100%;
195
- margin: 0 auto;
196
- }
197
-
198
- /* Settings form inside chat container should stack vertically */
199
- .chat-settings-form {
200
- display: flex;
201
- flex-direction: column;
202
- min-height: 60vh;
203
- min-width: 100%;
204
- }
205
-
206
- .chat-settings-form label,
207
- .chat-settings-form input,
208
- .chat-settings-form select {
209
- display: block;
210
- width: 100%;
211
- margin-bottom: 0.75rem;
212
- }
213
-
214
- .chat-settings-form .grid {
215
- display: flex;
216
- gap: 0.5rem;
217
- }
218
-
219
- /* Button sizing for Save Settings */
220
- .chat-settings-form .grid button:first-child {
221
- flex: 1 1 auto; /* expand in standalone */
222
- width: 50%;
223
- }
224
-
225
- /* In integrated UI (non chat-page) keep natural size */
226
- body:not(.chat-page) .chat-settings-form .grid button:first-child {
227
- flex: 0 0 auto;
228
- width: auto;
229
- }
230
-
231
- /* -------------------------------------------------------------------------
232
- Container flex area to ensure chat-log grows/shrinks as needed
233
- ------------------------------------------------------------------------- */
234
- #chat-content-area {
235
- display: flex;
236
- flex-direction: column;
237
- flex: 1 1 auto;
238
- overflow: hidden;
239
- }
240
-
241
- /* Prevent double scrollbars when chat is embedded */
242
- main.main-content:has(#chat-container) {
243
- overflow: hidden;
244
- }
245
-
246
- /* Ensure all direct text and common markdown elements within bot bubbles use the bot's text color */
247
- .bubble.bot,
248
- .bubble.bot p,
249
- .bubble.bot li,
250
- .bubble.bot h1,
251
- .bubble.bot h2,
252
- .bubble.bot h3,
253
- .bubble.bot h4,
254
- .bubble.bot h5,
255
- .bubble.bot h6,
256
- .bubble.bot strong,
257
- .bubble.bot em,
258
- .bubble.bot table,
259
- .bubble.bot th,
260
- .bubble.bot td {
261
- color: var(--pico-code-color);
262
- }
263
-
264
- /* For links specifically within bot messages, you might want them to also use the bot text color */
265
- .bubble.bot a {
266
- color: var(--pico-code-color);
267
- text-decoration: underline; /* Or your preferred link style */
268
- }
269
- .bubble.bot a:hover {
270
- color: var(--pico-primary-hover, var(--pico-primary));
271
- text-decoration: underline;
272
- }
273
-
274
- /* Styling for code blocks generated by Markdown and highlighted by Prism.js */
275
- /* The prism-okaidia theme will handle the internal colors of the code. */
276
- /* This is more about the container of the code block. */
277
- .bubble.bot pre[class*="language-"] {
278
- background-color: var(--pico-card-background-color); /* Or a slightly different dark shade */
279
- border: 1px solid var(--pico-muted-border-color);
280
- border-radius: var(--pico-border-radius);
281
- padding: 0.75em;
282
- margin: 0.5em 0;
283
- font-size: 0.875em; /* Adjust as needed */
284
- overflow-x: auto; /* Allow horizontal scrolling for long code lines */
285
- /* The text color *inside* the code block will be handled by the Prism theme (e.g., Okaidia) */
286
- }
287
-
288
- /* Ensure the code itself inside the pre block also resets its base color if needed,
289
- though Prism themes usually take care of this. This is a fallback. */
290
- .bubble.bot pre[class*="language-"] code {
291
- /* color: inherit; */ /* This might not be necessary if Prism theme is comprehensive - try without first */
292
- background: none;
293
- padding: 0;
294
- }
295
-
296
- /* Styles for preformatted text wrapping */
297
- .bubble pre {
298
- white-space: pre-wrap; /* Allows wrapping and preserves sequences of white space and newlines */
299
- word-wrap: break-word; /* Breaks long words/strings if they would overflow */
300
- overflow-x: auto; /* Adds a scrollbar if content is still too wide */
301
- }