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
@@ -1,96 +0,0 @@
1
- # src/flock/config/temporal_config.py
2
-
3
- """Pydantic models for configuring Temporal execution settings."""
4
-
5
- from __future__ import annotations
6
-
7
- from datetime import timedelta
8
- from typing import TYPE_CHECKING
9
-
10
- # Conditionally import for type hinting only
11
- if TYPE_CHECKING:
12
- from temporalio.common import RetryPolicy
13
-
14
- # Note: Importing temporalio types directly into config models can complicate serialization
15
- # if these models are meant to be purely data containers (e.g., for YAML/JSON).
16
- # We define the structure and provide a helper method to convert to the actual Temporal object.
17
- # Be careful if using workflow/activity decorators directly on methods within these config models.
18
- from pydantic import BaseModel, Field
19
-
20
-
21
- class TemporalRetryPolicyConfig(BaseModel):
22
- """Configuration parameters for Temporal Retry Policies."""
23
-
24
- initial_interval: timedelta = Field(
25
- default=timedelta(seconds=1),
26
- description="Initial delay before the first retry.",
27
- )
28
- backoff_coefficient: float = Field(
29
- default=2.0, description="Multiplier for the delay between retries."
30
- )
31
- maximum_interval: timedelta | None = Field(
32
- default=timedelta(seconds=100),
33
- description="Maximum delay between retries.",
34
- )
35
- maximum_attempts: int = Field(
36
- default=3,
37
- description="Maximum number of retry attempts (0 means no retries after first failure).",
38
- )
39
- non_retryable_error_types: list[str] = Field(
40
- default_factory=list,
41
- description="List of error type names (strings) that should not be retried.",
42
- )
43
-
44
- # Helper to convert to actual Temporalio object when needed (e.g., in workflow/executor)
45
- def to_temporalio_policy(self) -> RetryPolicy:
46
- # Import locally to avoid making temporalio a hard dependency of the config module itself
47
- # The type hint RetryPolicy is now available due to TYPE_CHECKING block
48
- from temporalio.common import RetryPolicy
49
-
50
- return RetryPolicy(
51
- initial_interval=self.initial_interval,
52
- backoff_coefficient=self.backoff_coefficient,
53
- maximum_interval=self.maximum_interval,
54
- maximum_attempts=self.maximum_attempts,
55
- non_retryable_error_types=self.non_retryable_error_types,
56
- )
57
-
58
-
59
- class TemporalWorkflowConfig(BaseModel):
60
- """Configuration specific to Temporal Workflow Execution for a Flock."""
61
-
62
- task_queue: str = Field(
63
- default="flock-queue",
64
- description="Default task queue for the workflow execution.",
65
- )
66
- workflow_execution_timeout: timedelta | None = Field(
67
- default=None, # Default to no timeout (Temporal server default)
68
- description="Total time limit for the workflow execution.",
69
- )
70
- workflow_run_timeout: timedelta | None = Field(
71
- default=None, # Default to no timeout (Temporal server default)
72
- description="Time limit for a single workflow run attempt.",
73
- )
74
- # Default retry policy for activities if not specified per-agent
75
- default_activity_retry_policy: TemporalRetryPolicyConfig = Field(
76
- default_factory=TemporalRetryPolicyConfig,
77
- description="Default retry policy applied to activities if not overridden by the agent.",
78
- )
79
-
80
-
81
- class TemporalActivityConfig(BaseModel):
82
- """Configuration specific to Temporal Activity Execution (per Agent)."""
83
-
84
- task_queue: str | None = Field(
85
- default=None,
86
- description="Specific task queue for this agent's activity execution (overrides workflow default).",
87
- )
88
- start_to_close_timeout: timedelta | None = Field(
89
- default=timedelta(minutes=5), # Default to 5 minutes
90
- description="Time limit for a single activity attempt.",
91
- )
92
- retry_policy: TemporalRetryPolicyConfig | None = Field(
93
- default=None,
94
- description="Specific retry policy for this activity (overrides workflow default).",
95
- )
96
- # Other timeouts like schedule_to_start, heartbeat_timeout could be added here if needed
@@ -1,68 +0,0 @@
1
- import uuid
2
- from typing import Optional
3
-
4
- from temporalio.client import Client
5
- from temporalio.worker import Worker
6
- from flock.config import TEMPORAL_SERVER_URL
7
-
8
-
9
- async def create_temporal_client(server_address: Optional[str] = None) -> Client:
10
- """Create a Temporal client using configured server address.
11
-
12
- Args:
13
- server_address: Optional override for the Temporal server endpoint. If not
14
- provided, falls back to flock.config.TEMPORAL_SERVER_URL.
15
- """
16
- address = server_address or TEMPORAL_SERVER_URL
17
- client = await Client.connect(address)
18
- return client
19
-
20
-
21
- async def setup_worker(
22
- client: Client, task_queue: str, workflow: type, activities: list
23
- ) -> Worker:
24
- """Creates and configures a worker instance, but does not run it.
25
-
26
- Args:
27
- client: The Temporal client to associate with the worker.
28
- task_queue: The task queue the worker should listen on.
29
- workflow: The workflow class definition.
30
- activities: A list of activity functions.
31
-
32
- Returns:
33
- A configured Worker instance.
34
- """
35
- # Creates and configures the worker instance
36
- worker = Worker(
37
- client,
38
- task_queue=task_queue,
39
- workflows=[workflow],
40
- activities=activities,
41
- )
42
- return worker # Return the configured worker instance
43
-
44
-
45
- async def run_worker(client: Client, task_queue: str, workflows, activities):
46
- worker = Worker(
47
- client,
48
- task_queue=task_queue,
49
- workflows=workflows,
50
- activities=activities,
51
- )
52
- await worker.run()
53
-
54
-
55
- async def run_activity(client: Client, name: str, func, param):
56
- run_id = f"{name}_{uuid.uuid4().hex[:4]}"
57
-
58
- try:
59
- result = await client.execute_activity(
60
- func,
61
- param,
62
- id=run_id,
63
- task_queue="flock-queue",
64
- start_to_close_timeout=300, # e.g., 5 minutes
65
- )
66
- return result
67
- except Exception:
68
- raise
@@ -1,274 +0,0 @@
1
- Metadata-Version: 2.4
2
- Name: flock-core
3
- Version: 0.5.0b28
4
- Summary: Declarative LLM Orchestration at Scale
5
- Author-email: Andre Ratzenberger <andre.ratzenberger@whiteduck.de>
6
- License-File: LICENSE
7
- Classifier: License :: OSI Approved :: MIT License
8
- Classifier: Operating System :: OS Independent
9
- Classifier: Programming Language :: Python :: 3
10
- Requires-Python: >=3.10
11
- Requires-Dist: aiosqlite>=0.21.0
12
- Requires-Dist: azure-data-tables>=12.7.0
13
- Requires-Dist: azure-storage-blob>=12.25.1
14
- Requires-Dist: chromadb>=0.6.3
15
- Requires-Dist: cloudpickle>=3.1.1
16
- Requires-Dist: croniter>=6.0.0
17
- Requires-Dist: datasets>=3.2.0
18
- Requires-Dist: devtools>=0.12.2
19
- Requires-Dist: dspy>=3.0.0
20
- Requires-Dist: fastapi>=0.115.8
21
- Requires-Dist: httpx>=0.28.1
22
- Requires-Dist: litellm>=1.75.3
23
- Requires-Dist: loguru>=0.7.3
24
- Requires-Dist: markdown2>=2.5.3
25
- Requires-Dist: mcp>=1.7.1
26
- Requires-Dist: msgpack>=1.1.0
27
- Requires-Dist: neo4j>=5.28.1
28
- Requires-Dist: openai==1.75.0
29
- Requires-Dist: opentelemetry-api>=1.30.0
30
- Requires-Dist: opentelemetry-exporter-jaeger-proto-grpc>=1.21.0
31
- Requires-Dist: opentelemetry-exporter-jaeger>=1.21.0
32
- Requires-Dist: opentelemetry-exporter-otlp>=1.30.0
33
- Requires-Dist: opentelemetry-instrumentation-logging>=0.51b0
34
- Requires-Dist: opentelemetry-sdk>=1.30.0
35
- Requires-Dist: opik>=1.7.26
36
- Requires-Dist: pandas>=2.2.3
37
- Requires-Dist: pillow>=10.4.0
38
- Requires-Dist: prometheus-client>=0.21.1
39
- Requires-Dist: psutil>=6.1.1
40
- Requires-Dist: pydantic-settings>=2.7.1
41
- Requires-Dist: pydantic>=2.10.5
42
- Requires-Dist: python-box>=7.3.2
43
- Requires-Dist: python-decouple>=3.8
44
- Requires-Dist: python-dotenv>=1.0.1
45
- Requires-Dist: pyyaml>=6.0
46
- Requires-Dist: questionary>=2.1.0
47
- Requires-Dist: rich>=13.7.0
48
- Requires-Dist: rouge-score>=0.1.2
49
- Requires-Dist: sentence-transformers>=3.4.1
50
- Requires-Dist: temporalio>=1.9.0
51
- Requires-Dist: thefuzz>=0.22.1
52
- Requires-Dist: tiktoken>=0.8.0
53
- Requires-Dist: toml>=0.10.2
54
- Requires-Dist: tqdm>=4.60.1
55
- Requires-Dist: uvicorn>=0.29.0
56
- Requires-Dist: wd-di>=0.2.14
57
- Requires-Dist: websockets>=13.0.1
58
- Requires-Dist: werkzeug>=3.1.3
59
- Requires-Dist: xlsxwriter>=3.2.3
60
- Provides-Extra: memory
61
- Requires-Dist: matplotlib>=3.10.0; extra == 'memory'
62
- Requires-Dist: mem0ai[graph]>=0.1.101; extra == 'memory'
63
- Requires-Dist: zep-python>=2.0.2; extra == 'memory'
64
- Description-Content-Type: text/markdown
65
-
66
- <p align="center">
67
- <!-- Placeholder for your Flock Logo/Banner - Replace URL -->
68
- <img alt="Flock Banner" src="https://raw.githubusercontent.com/whiteducksoftware/flock/master/docs/assets/images/flock.png" width="600">
69
- </p>
70
- <p align="center">
71
- <!-- Update badges -->
72
- <a href="https://pypi.org/project/flock-core/" target="_blank"><img alt="PyPI Version" src="https://img.shields.io/pypi/v/flock-core?style=for-the-badge&logo=pypi&label=pip%20version"></a>
73
- <img alt="Python Version" src="https://img.shields.io/badge/python-3.10%2B-blue?style=for-the-badge&logo=python">
74
- <a href="https://github.com/whiteducksoftware/flock/actions/workflows/deploy-whiteduck-pypi.yml" target="_blank"><img alt="CI Status" src="https://img.shields.io/github/actions/workflow/status/whiteducksoftware/flock/deploy-whiteduck-pypi.yml?branch=master&style=for-the-badge&logo=githubactions&logoColor=white"></a>
75
- <a href="https://github.com/whiteducksoftware/flock/blob/master/LICENSE" target="_blank"><img alt="License" src="https://img.shields.io/pypi/l/flock-core?style=for-the-badge"></a>
76
- <a href="https://whiteduck.de" target="_blank"><img alt="Built by white duck" src="https://img.shields.io/badge/Built%20by-white%20duck%20GmbH-white?style=for-the-badge&labelColor=black"></a>
77
- <a href="https://www.linkedin.com/company/whiteduck" target="_blank"><img alt="LinkedIn" src="https://img.shields.io/badge/linkedin-%230077B5.svg?style=for-the-badge&logo=linkedin&logoColor=white&label=whiteduck"></a>
78
- <a href="https://bsky.app/profile/whiteduck-gmbh.bsky.social" target="_blank"><img alt="Bluesky" src="https://img.shields.io/badge/bluesky-Follow-blue?style=for-the-badge&logo=bluesky&logoColor=%23fff&color=%23333&labelColor=%230285FF&label=whiteduck-gmbh"></a>
79
- </p>
80
-
81
-
82
- ---
83
-
84
-
85
- ## The Problem You Know Too Well
86
-
87
- 🤯 **Prompt Hell**: Brittle 500-line prompts that break with every model update.
88
- 💥 **System Failures**: One bad LLM response crashes your entire workflow
89
- 🧪 **Testing Nightmares**: "How do I unit test a prompt?" (You don't.)
90
- 🧪 **Measuring Quality**: "How do I know my prompts are close to optimal?" (You also don't.)
91
- 📄 **Output Chaos**: Parsing unstructured LLM responses into reliable data
92
- ⛓️ **Orchestration Limits**: Moving beyond simple chains and DAGs? Good luck
93
- 🚀 **Production Gap**: Jupyter notebooks don't scale to enterprise systems
94
-
95
- *After building dozens of AI systems for enterprise clients, we realized the tooling was fundamentally broken.*
96
-
97
-
98
- **Build with agents, not against them.**
99
-
100
-
101
- ## The Flock Solution
102
-
103
- **What if you could just skip that 'prompt engineering' step?**
104
-
105
- Flock is an agent framework for declarative AI workflows. You define what goes in and what should come out, the how is handled by the agent.
106
- No brittle prompts. No guesswork. Just reliable, testable AI agents.
107
-
108
-
109
- ✅ **Declarative Contracts**: Define inputs/outputs with Pydantic models. Flock handles the LLM complexity.
110
- ⚡ **Built-in Resilience**: Automatic retries, state persistence, and workflow resumption via Temporal.io
111
- 🧪 **Actually Testable**: Clear contracts make agents unit-testable like any other code
112
- 🧪 **Optimal Quality**: Agents posses multiple self-optimization algorithms based on latest research
113
- 🚀 **Dynamic Workflows**: Self-correcting loops, conditional routing, and intelligent decision-making
114
- 🔧 **Zero-Config Production**: Deploy as REST APIs with one command. Scale without rewriting.
115
-
116
- **Ready to see it in action?**
117
-
118
- ## ⚡ Quick Start
119
-
120
- ```python
121
- from flock.core import Flock, DefaultAgent
122
-
123
- # 1. Create the main orchestrator
124
- my_flock = Flock(model="openai/gpt-4.1")
125
-
126
- # 2. Declaratively define an agent
127
- brainstorm_agent = DefaultAgent(
128
- name="idea_generator",
129
- input="topic",
130
- output="catchy_title, key_points",
131
- )
132
-
133
- # 3. Add the agent to the Flock
134
- my_flock.add_agent(brainstorm_agent)
135
-
136
- # 4. Run the agent!
137
- input_data = {"topic": "The future of AI agents"}
138
- result = my_flock.run(start_agent="idea_generator", input=input_data)
139
-
140
- # The result is a Box object (dot-accessible dict)
141
- print(f"Generated Title: {result.catchy_title}")
142
- print(f"Key Points: {result.key_points}")
143
- ```
144
-
145
- **No 20-line prompt fiddling. Just structured output, every time.**
146
-
147
- ![image](https://github.com/user-attachments/assets/37a897cb-910f-49fc-89d4-510a780ad775)
148
-
149
- **Explore more examples →** [**Flock Showcase Repository**](https://github.com/whiteducksoftware/flock-showcase)
150
-
151
-
152
-
153
- ## 💾 Installation - Use Flock in your project
154
-
155
- Get started with the core Flock library:
156
-
157
- ```bash
158
- # Using uv (recommended)
159
- uv pip install flock-core
160
-
161
- # Using pip
162
- pip install flock-core
163
- ```
164
-
165
- Extras: Install optional dependencies for specific features:
166
-
167
- ```bash
168
- # Flock tools and mcp server
169
- uv pip install flock-mcp
170
- ```
171
-
172
- ## 🔑 Installation - Develop Flock
173
-
174
- ```bash
175
- git clone https://github.com/whiteducksoftware/flock.git
176
- cd flock
177
-
178
- # One-liner dev setup after cloning
179
- pip install poethepoet && poe install
180
- ```
181
-
182
- Additional provided `poe` tasks and commands:
183
-
184
- ```bash
185
- poe install # Install the project
186
- poe build # Build the project
187
- poe docs # Serve the docs
188
- poe format # Format the code
189
- poe lint # Lint the code
190
- ```
191
-
192
- ## 🔑 Environment Setup
193
-
194
- Flock uses environment variables (typically in a .env file) for configuration, especially API keys. Create a .env file in your project root:
195
-
196
- ```bash
197
- # .env - Example
198
-
199
- # --- LLM Provider API Keys (Required by most examples) ---
200
- # Add keys for providers you use (OpenAI, Anthropic, Gemini, Azure, etc.)
201
- # Refer to litellm docs (https://docs.litellm.ai/docs/providers) for names
202
- OPENAI_API_KEY="your-openai-api-key"
203
- # ANTHROPIC_API_KEY="your-anthropic-api-key"
204
-
205
- # --- Tool-Specific Keys (Optional) ---
206
- # TAVILY_API_KEY="your-tavily-search-key"
207
- # GITHUB_PAT="your-github-personal-access-token"
208
-
209
- # --- Default Flock Settings (Optional) ---
210
- DEFAULT_MODEL="openai/gpt-4o" # Default LLM if agent doesn't specify
211
-
212
- # --- Flock CLI Settings (Managed by `flock settings`) ---
213
- # SHOW_SECRETS="False"
214
- # VARS_PER_PAGE="20"
215
- ```
216
-
217
- Be sure that the .env file is added to your .gitignore!
218
-
219
-
220
- ## 🐤 New in Flock 0.5.0 `Kea` 🐤
221
-
222
- Keas are one of the smartest birds in the world famous for figuring out multi-step puzzles, unlatching doors, and coordinating in small groups to get what it wants.
223
-
224
- <Insert Kea Logo>
225
-
226
- ### Self-optimizing agents
227
-
228
- ### Everything you need to evaluate and optimize agents
229
-
230
- ### Benchmarks
231
-
232
- ### Smooth Jupyter experience
233
-
234
- ### Multi-Threading and Thread Safety
235
-
236
-
237
- --------------------------------
238
-
239
- ## 📚 Examples & Tutorials
240
-
241
- For a comprehensive set of examples, ranging from basic usage to complex projects and advanced features, please visit our dedicated showcase repository:
242
-
243
- ➡️ [github.com/whiteducksoftware/flock-showcase](https://github.com/whiteducksoftware/flock-showcase) ⬅️
244
-
245
- The showcase includes:
246
-
247
- - Step-by-step guides for core concepts.
248
- - Examples of tool usage, routing, memory, and more.
249
- - Complete mini-projects demonstrating practical applications.
250
-
251
- ## 📖 Documentation
252
-
253
- Full documentation, including API references and conceptual explanations, can be found at:
254
-
255
- ➡️ [whiteducksoftware.github.io/flock/](https://whiteducksoftware.github.io/flock/) ⬅️
256
-
257
- ## 🤝 Contributing
258
-
259
- We welcome contributions! Please see the CONTRIBUTING.md file (if available) or open an issue/pull request on GitHub.
260
-
261
- Ways to contribute:
262
-
263
- - Report bugs or suggest features.
264
- - Improve documentation.
265
- - Contribute new Modules, Evaluators, or Routers.
266
- - Add examples to the flock-showcase repository.
267
-
268
- ## 📜 License
269
-
270
- Flock is licensed under the MIT License. See the LICENSE file for details.
271
-
272
- ## 🏢 About
273
-
274
- Flock is developed and maintained by white duck GmbH, your partner for cloud-native solutions and AI integration.