flock-core 0.4.543__py3-none-any.whl → 0.5.0__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.
- flock/__init__.py +12 -217
- flock/agent.py +1079 -0
- flock/api/themes.py +71 -0
- flock/artifacts.py +86 -0
- flock/cli.py +147 -0
- flock/components.py +189 -0
- flock/dashboard/__init__.py +30 -0
- flock/dashboard/collector.py +559 -0
- flock/dashboard/events.py +188 -0
- flock/dashboard/graph_builder.py +563 -0
- flock/dashboard/launcher.py +235 -0
- flock/dashboard/models/graph.py +156 -0
- flock/dashboard/service.py +991 -0
- flock/dashboard/static_v2/assets/index-DFRnI_mt.js +111 -0
- flock/dashboard/static_v2/assets/index-fPLNdmp1.css +1 -0
- flock/dashboard/static_v2/index.html +13 -0
- flock/dashboard/websocket.py +246 -0
- flock/engines/__init__.py +6 -0
- flock/engines/dspy_engine.py +932 -0
- flock/examples.py +131 -0
- flock/frontend/README.md +778 -0
- flock/frontend/docs/DESIGN_SYSTEM.md +1980 -0
- flock/frontend/index.html +12 -0
- flock/frontend/package-lock.json +4337 -0
- flock/frontend/package.json +48 -0
- flock/frontend/src/App.tsx +139 -0
- flock/frontend/src/__tests__/integration/graph-snapshot.test.tsx +647 -0
- flock/frontend/src/__tests__/integration/indexeddb-persistence.test.tsx +699 -0
- flock/frontend/src/components/common/BuildInfo.tsx +39 -0
- flock/frontend/src/components/common/EmptyState.module.css +115 -0
- flock/frontend/src/components/common/EmptyState.tsx +128 -0
- flock/frontend/src/components/common/ErrorBoundary.module.css +169 -0
- flock/frontend/src/components/common/ErrorBoundary.tsx +118 -0
- flock/frontend/src/components/common/KeyboardShortcutsDialog.css +251 -0
- flock/frontend/src/components/common/KeyboardShortcutsDialog.tsx +151 -0
- flock/frontend/src/components/common/LoadingSpinner.module.css +97 -0
- flock/frontend/src/components/common/LoadingSpinner.tsx +29 -0
- flock/frontend/src/components/controls/PublishControl.css +547 -0
- flock/frontend/src/components/controls/PublishControl.test.tsx +543 -0
- flock/frontend/src/components/controls/PublishControl.tsx +432 -0
- flock/frontend/src/components/details/DetailWindowContainer.tsx +58 -0
- flock/frontend/src/components/details/LiveOutputTab.test.tsx +792 -0
- flock/frontend/src/components/details/LiveOutputTab.tsx +220 -0
- flock/frontend/src/components/details/MessageDetailWindow.tsx +439 -0
- flock/frontend/src/components/details/MessageHistoryTab.tsx +374 -0
- flock/frontend/src/components/details/NodeDetailWindow.test.tsx +501 -0
- flock/frontend/src/components/details/NodeDetailWindow.tsx +218 -0
- flock/frontend/src/components/details/RunStatusTab.tsx +348 -0
- flock/frontend/src/components/details/tabs.test.tsx +1015 -0
- flock/frontend/src/components/filters/ArtifactTypeFilter.tsx +21 -0
- flock/frontend/src/components/filters/CorrelationIDFilter.module.css +102 -0
- flock/frontend/src/components/filters/CorrelationIDFilter.test.tsx +197 -0
- flock/frontend/src/components/filters/CorrelationIDFilter.tsx +121 -0
- flock/frontend/src/components/filters/FilterFlyout.module.css +104 -0
- flock/frontend/src/components/filters/FilterFlyout.tsx +80 -0
- flock/frontend/src/components/filters/FilterPills.module.css +220 -0
- flock/frontend/src/components/filters/FilterPills.test.tsx +189 -0
- flock/frontend/src/components/filters/FilterPills.tsx +143 -0
- flock/frontend/src/components/filters/ProducerFilter.tsx +21 -0
- flock/frontend/src/components/filters/SavedFiltersControl.module.css +60 -0
- flock/frontend/src/components/filters/SavedFiltersControl.test.tsx +158 -0
- flock/frontend/src/components/filters/SavedFiltersControl.tsx +159 -0
- flock/frontend/src/components/filters/TagFilter.tsx +21 -0
- flock/frontend/src/components/filters/TimeRangeFilter.module.css +115 -0
- flock/frontend/src/components/filters/TimeRangeFilter.test.tsx +154 -0
- flock/frontend/src/components/filters/TimeRangeFilter.tsx +110 -0
- flock/frontend/src/components/filters/VisibilityFilter.tsx +21 -0
- flock/frontend/src/components/graph/AgentNode.test.tsx +77 -0
- flock/frontend/src/components/graph/AgentNode.tsx +324 -0
- flock/frontend/src/components/graph/GraphCanvas.tsx +613 -0
- flock/frontend/src/components/graph/MessageFlowEdge.tsx +128 -0
- flock/frontend/src/components/graph/MessageNode.test.tsx +64 -0
- flock/frontend/src/components/graph/MessageNode.tsx +129 -0
- flock/frontend/src/components/graph/MiniMap.tsx +47 -0
- flock/frontend/src/components/graph/TransformEdge.tsx +123 -0
- flock/frontend/src/components/layout/DashboardLayout.css +420 -0
- flock/frontend/src/components/layout/DashboardLayout.tsx +287 -0
- flock/frontend/src/components/layout/Header.module.css +88 -0
- flock/frontend/src/components/layout/Header.tsx +52 -0
- flock/frontend/src/components/modules/HistoricalArtifactsModule.module.css +288 -0
- flock/frontend/src/components/modules/HistoricalArtifactsModule.tsx +450 -0
- flock/frontend/src/components/modules/HistoricalArtifactsModuleWrapper.tsx +13 -0
- flock/frontend/src/components/modules/JsonAttributeRenderer.tsx +140 -0
- flock/frontend/src/components/modules/ModuleRegistry.test.ts +333 -0
- flock/frontend/src/components/modules/ModuleRegistry.ts +93 -0
- flock/frontend/src/components/modules/ModuleWindow.tsx +223 -0
- flock/frontend/src/components/modules/TraceModuleJaeger.tsx +1971 -0
- flock/frontend/src/components/modules/TraceModuleJaegerWrapper.tsx +13 -0
- flock/frontend/src/components/modules/registerModules.ts +29 -0
- flock/frontend/src/components/settings/AdvancedSettings.tsx +175 -0
- flock/frontend/src/components/settings/AppearanceSettings.tsx +185 -0
- flock/frontend/src/components/settings/GraphSettings.tsx +110 -0
- flock/frontend/src/components/settings/MultiSelect.tsx +235 -0
- flock/frontend/src/components/settings/SettingsPanel.css +327 -0
- flock/frontend/src/components/settings/SettingsPanel.tsx +131 -0
- flock/frontend/src/components/settings/ThemeSelector.tsx +298 -0
- flock/frontend/src/components/settings/TracingSettings.tsx +404 -0
- flock/frontend/src/hooks/useKeyboardShortcuts.ts +148 -0
- flock/frontend/src/hooks/useModulePersistence.test.ts +442 -0
- flock/frontend/src/hooks/useModulePersistence.ts +154 -0
- flock/frontend/src/hooks/useModules.ts +157 -0
- flock/frontend/src/hooks/usePersistence.ts +141 -0
- flock/frontend/src/main.tsx +13 -0
- flock/frontend/src/services/api.ts +337 -0
- flock/frontend/src/services/graphService.test.ts +330 -0
- flock/frontend/src/services/graphService.ts +75 -0
- flock/frontend/src/services/indexeddb.test.ts +793 -0
- flock/frontend/src/services/indexeddb.ts +848 -0
- flock/frontend/src/services/layout.test.ts +437 -0
- flock/frontend/src/services/layout.ts +357 -0
- flock/frontend/src/services/themeApplicator.ts +140 -0
- flock/frontend/src/services/themeService.ts +77 -0
- flock/frontend/src/services/websocket.ts +650 -0
- flock/frontend/src/store/filterStore.test.ts +250 -0
- flock/frontend/src/store/filterStore.ts +272 -0
- flock/frontend/src/store/graphStore.test.ts +570 -0
- flock/frontend/src/store/graphStore.ts +462 -0
- flock/frontend/src/store/moduleStore.test.ts +253 -0
- flock/frontend/src/store/moduleStore.ts +75 -0
- flock/frontend/src/store/settingsStore.ts +188 -0
- flock/frontend/src/store/streamStore.ts +68 -0
- flock/frontend/src/store/uiStore.test.ts +54 -0
- flock/frontend/src/store/uiStore.ts +122 -0
- flock/frontend/src/store/wsStore.ts +34 -0
- flock/frontend/src/styles/index.css +15 -0
- flock/frontend/src/styles/scrollbar.css +47 -0
- flock/frontend/src/styles/variables.css +488 -0
- flock/frontend/src/test/setup.ts +1 -0
- flock/frontend/src/types/filters.ts +47 -0
- flock/frontend/src/types/graph.ts +95 -0
- flock/frontend/src/types/modules.ts +10 -0
- flock/frontend/src/types/theme.ts +55 -0
- flock/frontend/src/utils/artifacts.ts +24 -0
- flock/frontend/src/utils/mockData.ts +98 -0
- flock/frontend/src/utils/performance.ts +16 -0
- flock/frontend/src/vite-env.d.ts +17 -0
- flock/frontend/tsconfig.json +27 -0
- flock/frontend/tsconfig.node.json +11 -0
- flock/frontend/vite.config.ts +25 -0
- flock/frontend/vitest.config.ts +11 -0
- flock/{core/util → helper}/cli_helper.py +9 -5
- flock/{core/logging → logging}/__init__.py +2 -3
- flock/logging/auto_trace.py +159 -0
- flock/{core/logging → logging}/formatters/enum_builder.py +3 -4
- flock/{core/logging → logging}/formatters/theme_builder.py +19 -44
- flock/{core/logging → logging}/formatters/themed_formatter.py +69 -107
- flock/{core/logging → logging}/logging.py +78 -61
- flock/{core/logging → logging}/telemetry.py +66 -26
- flock/{core/logging → logging}/telemetry_exporter/base_exporter.py +2 -2
- flock/logging/telemetry_exporter/duckdb_exporter.py +216 -0
- flock/{core/logging → logging}/telemetry_exporter/file_exporter.py +13 -10
- flock/{core/logging → logging}/telemetry_exporter/sqlite_exporter.py +2 -3
- flock/logging/trace_and_logged.py +304 -0
- flock/mcp/__init__.py +91 -0
- flock/{core/mcp/mcp_client.py → mcp/client.py} +131 -158
- flock/{core/mcp/mcp_config.py → mcp/config.py} +86 -132
- flock/mcp/manager.py +286 -0
- flock/mcp/servers/sse/__init__.py +1 -1
- flock/mcp/servers/sse/flock_sse_server.py +16 -58
- flock/mcp/servers/stdio/__init__.py +1 -1
- flock/mcp/servers/stdio/flock_stdio_server.py +13 -53
- flock/mcp/servers/streamable_http/flock_streamable_http_server.py +22 -67
- flock/mcp/servers/websockets/flock_websocket_server.py +12 -45
- flock/{core/mcp/flock_mcp_tool_base.py → mcp/tool.py} +24 -78
- flock/mcp/types/__init__.py +42 -0
- flock/{core/mcp → mcp}/types/callbacks.py +12 -15
- flock/{core/mcp → mcp}/types/factories.py +7 -6
- flock/{core/mcp → mcp}/types/handlers.py +13 -18
- flock/{core/mcp → mcp}/types/types.py +70 -74
- flock/{core/mcp → mcp}/util/helpers.py +3 -3
- flock/orchestrator.py +970 -0
- flock/registry.py +148 -0
- flock/runtime.py +262 -0
- flock/service.py +277 -0
- flock/store.py +1214 -0
- flock/subscription.py +111 -0
- flock/themes/andromeda.toml +1 -1
- flock/themes/apple-system-colors.toml +1 -1
- flock/themes/arcoiris.toml +1 -1
- flock/themes/atomonelight.toml +1 -1
- flock/themes/ayu copy.toml +1 -1
- flock/themes/ayu-light.toml +1 -1
- flock/themes/belafonte-day.toml +1 -1
- flock/themes/belafonte-night.toml +1 -1
- flock/themes/blulocodark.toml +1 -1
- flock/themes/breeze.toml +1 -1
- flock/themes/broadcast.toml +1 -1
- flock/themes/brogrammer.toml +1 -1
- flock/themes/builtin-dark.toml +1 -1
- flock/themes/builtin-pastel-dark.toml +1 -1
- flock/themes/catppuccin-latte.toml +1 -1
- flock/themes/catppuccin-macchiato.toml +1 -1
- flock/themes/catppuccin-mocha.toml +1 -1
- flock/themes/cga.toml +1 -1
- flock/themes/chalk.toml +1 -1
- flock/themes/ciapre.toml +1 -1
- flock/themes/coffee-theme.toml +1 -1
- flock/themes/cyberpunkscarletprotocol.toml +1 -1
- flock/themes/dark+.toml +1 -1
- flock/themes/darkermatrix.toml +1 -1
- flock/themes/darkmatrix.toml +2 -2
- flock/themes/darkside.toml +1 -1
- flock/themes/deep.toml +2 -2
- flock/themes/desert.toml +1 -1
- flock/themes/django.toml +1 -1
- flock/themes/djangosmooth.toml +1 -1
- flock/themes/doomone.toml +1 -1
- flock/themes/dotgov.toml +1 -1
- flock/themes/dracula+.toml +1 -1
- flock/themes/duckbones.toml +1 -1
- flock/themes/encom.toml +1 -1
- flock/themes/espresso.toml +1 -1
- flock/themes/everblush.toml +1 -1
- flock/themes/fairyfloss.toml +1 -1
- flock/themes/fideloper.toml +1 -1
- flock/themes/fishtank.toml +1 -1
- flock/themes/flexoki-light.toml +1 -1
- flock/themes/floraverse.toml +1 -1
- flock/themes/framer.toml +1 -1
- flock/themes/galizur.toml +1 -1
- flock/themes/github.toml +1 -1
- flock/themes/grass.toml +1 -1
- flock/themes/grey-green.toml +1 -1
- flock/themes/gruvboxlight.toml +1 -1
- flock/themes/guezwhoz.toml +1 -1
- flock/themes/harper.toml +1 -1
- flock/themes/hax0r-blue.toml +1 -1
- flock/themes/hopscotch.256.toml +1 -1
- flock/themes/ic-green-ppl.toml +1 -1
- flock/themes/iceberg-dark.toml +1 -1
- flock/themes/japanesque.toml +1 -1
- flock/themes/jubi.toml +1 -1
- flock/themes/kibble.toml +1 -1
- flock/themes/kolorit.toml +1 -1
- flock/themes/kurokula.toml +1 -1
- flock/themes/materialdesigncolors.toml +1 -1
- flock/themes/matrix.toml +1 -1
- flock/themes/mellifluous.toml +1 -1
- flock/themes/midnight-in-mojave.toml +1 -1
- flock/themes/monokai-remastered.toml +1 -1
- flock/themes/monokai-soda.toml +1 -1
- flock/themes/neon.toml +1 -1
- flock/themes/neopolitan.toml +5 -5
- flock/themes/nord-light.toml +1 -1
- flock/themes/ocean.toml +1 -1
- flock/themes/onehalfdark.toml +1 -1
- flock/themes/onehalflight.toml +1 -1
- flock/themes/palenighthc.toml +1 -1
- flock/themes/paulmillr.toml +1 -1
- flock/themes/pencildark.toml +1 -1
- flock/themes/pnevma.toml +1 -1
- flock/themes/purple-rain.toml +1 -1
- flock/themes/purplepeter.toml +1 -1
- flock/themes/raycast-dark.toml +1 -1
- flock/themes/red-sands.toml +1 -1
- flock/themes/relaxed.toml +1 -1
- flock/themes/retro.toml +1 -1
- flock/themes/rose-pine.toml +1 -1
- flock/themes/royal.toml +1 -1
- flock/themes/ryuuko.toml +1 -1
- flock/themes/sakura.toml +1 -1
- flock/themes/scarlet-protocol.toml +1 -1
- flock/themes/seoulbones-dark.toml +1 -1
- flock/themes/shades-of-purple.toml +1 -1
- flock/themes/smyck.toml +1 -1
- flock/themes/softserver.toml +1 -1
- flock/themes/solarized-darcula.toml +1 -1
- flock/themes/square.toml +1 -1
- flock/themes/sugarplum.toml +1 -1
- flock/themes/thayer-bright.toml +1 -1
- flock/themes/tokyonight.toml +1 -1
- flock/themes/tomorrow.toml +1 -1
- flock/themes/ubuntu.toml +1 -1
- flock/themes/ultradark.toml +1 -1
- flock/themes/ultraviolent.toml +1 -1
- flock/themes/unikitty.toml +1 -1
- flock/themes/urple.toml +1 -1
- flock/themes/vesper.toml +1 -1
- flock/themes/vimbones.toml +1 -1
- flock/themes/wildcherry.toml +1 -1
- flock/themes/wilmersdorf.toml +1 -1
- flock/themes/wryan.toml +1 -1
- flock/themes/xcodedarkhc.toml +1 -1
- flock/themes/xcodelight.toml +1 -1
- flock/themes/zenbones-light.toml +1 -1
- flock/themes/zenwritten-dark.toml +1 -1
- flock/utilities.py +301 -0
- flock/utility/output_utility_component.py +226 -0
- flock/visibility.py +107 -0
- flock_core-0.5.0.dist-info/METADATA +964 -0
- flock_core-0.5.0.dist-info/RECORD +525 -0
- flock_core-0.5.0.dist-info/entry_points.txt +2 -0
- {flock_core-0.4.543.dist-info → flock_core-0.5.0.dist-info}/licenses/LICENSE +1 -1
- flock/adapter/__init__.py +0 -14
- flock/adapter/azure_adapter.py +0 -68
- flock/adapter/chroma_adapter.py +0 -73
- flock/adapter/faiss_adapter.py +0 -97
- flock/adapter/pinecone_adapter.py +0 -51
- flock/adapter/vector_base.py +0 -47
- flock/cli/assets/release_notes.md +0 -140
- flock/cli/config.py +0 -8
- flock/cli/constants.py +0 -36
- flock/cli/create_agent.py +0 -1
- flock/cli/create_flock.py +0 -280
- flock/cli/execute_flock.py +0 -620
- flock/cli/load_agent.py +0 -1
- flock/cli/load_examples.py +0 -1
- flock/cli/load_flock.py +0 -192
- flock/cli/load_release_notes.py +0 -20
- flock/cli/loaded_flock_cli.py +0 -254
- flock/cli/manage_agents.py +0 -459
- flock/cli/registry_management.py +0 -889
- flock/cli/runner.py +0 -41
- flock/cli/settings.py +0 -857
- flock/cli/utils.py +0 -135
- flock/cli/view_results.py +0 -29
- flock/cli/yaml_editor.py +0 -396
- flock/config.py +0 -56
- flock/core/__init__.py +0 -44
- flock/core/api/__init__.py +0 -10
- flock/core/api/custom_endpoint.py +0 -45
- flock/core/api/endpoints.py +0 -262
- flock/core/api/main.py +0 -162
- flock/core/api/models.py +0 -101
- flock/core/api/run_store.py +0 -224
- flock/core/api/runner.py +0 -44
- flock/core/api/service.py +0 -214
- flock/core/config/flock_agent_config.py +0 -11
- flock/core/config/scheduled_agent_config.py +0 -40
- flock/core/context/context.py +0 -214
- flock/core/context/context_manager.py +0 -40
- flock/core/context/context_vars.py +0 -11
- flock/core/evaluation/utils.py +0 -395
- flock/core/execution/batch_executor.py +0 -369
- flock/core/execution/evaluation_executor.py +0 -438
- flock/core/execution/local_executor.py +0 -31
- flock/core/execution/opik_executor.py +0 -103
- flock/core/execution/temporal_executor.py +0 -166
- flock/core/flock.py +0 -1003
- flock/core/flock_agent.py +0 -1258
- flock/core/flock_evaluator.py +0 -60
- flock/core/flock_factory.py +0 -513
- flock/core/flock_module.py +0 -207
- flock/core/flock_registry.py +0 -702
- flock/core/flock_router.py +0 -83
- flock/core/flock_scheduler.py +0 -166
- flock/core/flock_server_manager.py +0 -136
- flock/core/interpreter/python_interpreter.py +0 -689
- flock/core/logging/live_capture.py +0 -137
- flock/core/logging/trace_and_logged.py +0 -59
- flock/core/mcp/__init__.py +0 -1
- flock/core/mcp/flock_mcp_server.py +0 -640
- flock/core/mcp/mcp_client_manager.py +0 -201
- flock/core/mcp/types/__init__.py +0 -1
- flock/core/mixin/dspy_integration.py +0 -445
- flock/core/mixin/prompt_parser.py +0 -125
- flock/core/serialization/__init__.py +0 -13
- flock/core/serialization/callable_registry.py +0 -52
- flock/core/serialization/flock_serializer.py +0 -854
- flock/core/serialization/json_encoder.py +0 -41
- flock/core/serialization/secure_serializer.py +0 -175
- flock/core/serialization/serializable.py +0 -342
- flock/core/serialization/serialization_utils.py +0 -409
- flock/core/util/file_path_utils.py +0 -223
- flock/core/util/hydrator.py +0 -309
- flock/core/util/input_resolver.py +0 -141
- flock/core/util/loader.py +0 -59
- flock/core/util/splitter.py +0 -219
- flock/di.py +0 -41
- flock/evaluators/__init__.py +0 -1
- flock/evaluators/declarative/__init__.py +0 -1
- flock/evaluators/declarative/declarative_evaluator.py +0 -217
- flock/evaluators/memory/memory_evaluator.py +0 -90
- flock/evaluators/test/test_case_evaluator.py +0 -38
- flock/evaluators/zep/zep_evaluator.py +0 -59
- flock/modules/__init__.py +0 -1
- flock/modules/assertion/__init__.py +0 -1
- flock/modules/assertion/assertion_module.py +0 -286
- flock/modules/callback/__init__.py +0 -1
- flock/modules/callback/callback_module.py +0 -91
- flock/modules/enterprise_memory/README.md +0 -99
- flock/modules/enterprise_memory/enterprise_memory_module.py +0 -526
- flock/modules/mem0/__init__.py +0 -1
- flock/modules/mem0/mem0_module.py +0 -126
- flock/modules/mem0_async/__init__.py +0 -1
- flock/modules/mem0_async/async_mem0_module.py +0 -126
- flock/modules/memory/__init__.py +0 -1
- flock/modules/memory/memory_module.py +0 -429
- flock/modules/memory/memory_parser.py +0 -125
- flock/modules/memory/memory_storage.py +0 -736
- flock/modules/output/__init__.py +0 -1
- flock/modules/output/output_module.py +0 -196
- flock/modules/performance/__init__.py +0 -1
- flock/modules/performance/metrics_module.py +0 -678
- flock/modules/zep/__init__.py +0 -1
- flock/modules/zep/zep_module.py +0 -192
- flock/platform/docker_tools.py +0 -49
- flock/platform/jaeger_install.py +0 -86
- flock/routers/__init__.py +0 -1
- flock/routers/agent/__init__.py +0 -1
- flock/routers/agent/agent_router.py +0 -236
- flock/routers/agent/handoff_agent.py +0 -58
- flock/routers/conditional/conditional_router.py +0 -486
- flock/routers/default/__init__.py +0 -1
- flock/routers/default/default_router.py +0 -80
- flock/routers/feedback/feedback_router.py +0 -114
- flock/routers/list_generator/list_generator_router.py +0 -166
- flock/routers/llm/__init__.py +0 -1
- flock/routers/llm/llm_router.py +0 -365
- flock/tools/__init__.py +0 -0
- flock/tools/azure_tools.py +0 -781
- flock/tools/code_tools.py +0 -167
- flock/tools/file_tools.py +0 -149
- flock/tools/github_tools.py +0 -157
- flock/tools/markdown_tools.py +0 -205
- flock/tools/system_tools.py +0 -9
- flock/tools/text_tools.py +0 -810
- flock/tools/web_tools.py +0 -92
- flock/tools/zendesk_tools.py +0 -501
- flock/webapp/__init__.py +0 -1
- flock/webapp/app/__init__.py +0 -0
- flock/webapp/app/api/__init__.py +0 -0
- flock/webapp/app/api/agent_management.py +0 -237
- flock/webapp/app/api/execution.py +0 -503
- flock/webapp/app/api/flock_management.py +0 -125
- flock/webapp/app/api/registry_viewer.py +0 -29
- flock/webapp/app/chat.py +0 -662
- flock/webapp/app/config.py +0 -104
- flock/webapp/app/dependencies.py +0 -117
- flock/webapp/app/main.py +0 -1086
- flock/webapp/app/middleware.py +0 -113
- flock/webapp/app/models_ui.py +0 -7
- flock/webapp/app/services/__init__.py +0 -0
- flock/webapp/app/services/feedback_file_service.py +0 -363
- flock/webapp/app/services/flock_service.py +0 -345
- flock/webapp/app/services/sharing_models.py +0 -81
- flock/webapp/app/services/sharing_store.py +0 -597
- flock/webapp/app/templates/theme_mapper.html +0 -326
- flock/webapp/app/theme_mapper.py +0 -811
- flock/webapp/app/utils.py +0 -85
- flock/webapp/run.py +0 -219
- flock/webapp/static/css/chat.css +0 -301
- flock/webapp/static/css/components.css +0 -167
- flock/webapp/static/css/header.css +0 -39
- flock/webapp/static/css/layout.css +0 -281
- flock/webapp/static/css/sidebar.css +0 -127
- flock/webapp/static/css/two-pane.css +0 -48
- flock/webapp/templates/base.html +0 -389
- flock/webapp/templates/chat.html +0 -152
- flock/webapp/templates/chat_settings.html +0 -19
- flock/webapp/templates/flock_editor.html +0 -16
- flock/webapp/templates/index.html +0 -12
- flock/webapp/templates/partials/_agent_detail_form.html +0 -93
- flock/webapp/templates/partials/_agent_list.html +0 -18
- flock/webapp/templates/partials/_agent_manager_view.html +0 -51
- flock/webapp/templates/partials/_agent_tools_checklist.html +0 -14
- flock/webapp/templates/partials/_chat_container.html +0 -15
- flock/webapp/templates/partials/_chat_messages.html +0 -57
- flock/webapp/templates/partials/_chat_settings_form.html +0 -85
- flock/webapp/templates/partials/_create_flock_form.html +0 -50
- flock/webapp/templates/partials/_dashboard_flock_detail.html +0 -17
- flock/webapp/templates/partials/_dashboard_flock_file_list.html +0 -16
- flock/webapp/templates/partials/_dashboard_flock_properties_preview.html +0 -28
- flock/webapp/templates/partials/_dashboard_upload_flock_form.html +0 -16
- flock/webapp/templates/partials/_dynamic_input_form_content.html +0 -22
- flock/webapp/templates/partials/_env_vars_table.html +0 -23
- flock/webapp/templates/partials/_execution_form.html +0 -127
- flock/webapp/templates/partials/_execution_view_container.html +0 -28
- flock/webapp/templates/partials/_flock_file_list.html +0 -23
- flock/webapp/templates/partials/_flock_properties_form.html +0 -52
- flock/webapp/templates/partials/_flock_upload_form.html +0 -16
- flock/webapp/templates/partials/_header_flock_status.html +0 -5
- flock/webapp/templates/partials/_live_logs.html +0 -13
- flock/webapp/templates/partials/_load_manager_view.html +0 -49
- flock/webapp/templates/partials/_registry_table.html +0 -25
- flock/webapp/templates/partials/_registry_viewer_content.html +0 -70
- flock/webapp/templates/partials/_results_display.html +0 -78
- flock/webapp/templates/partials/_settings_env_content.html +0 -9
- flock/webapp/templates/partials/_settings_theme_content.html +0 -14
- flock/webapp/templates/partials/_settings_view.html +0 -36
- flock/webapp/templates/partials/_share_chat_link_snippet.html +0 -11
- flock/webapp/templates/partials/_share_link_snippet.html +0 -35
- flock/webapp/templates/partials/_sidebar.html +0 -74
- flock/webapp/templates/partials/_structured_data_view.html +0 -40
- flock/webapp/templates/partials/_theme_preview.html +0 -36
- flock/webapp/templates/registry_viewer.html +0 -84
- flock/webapp/templates/shared_run_page.html +0 -140
- flock/workflow/__init__.py +0 -0
- flock/workflow/activities.py +0 -237
- flock/workflow/agent_activities.py +0 -24
- flock/workflow/agent_execution_activity.py +0 -240
- flock/workflow/flock_workflow.py +0 -225
- flock/workflow/temporal_config.py +0 -96
- flock/workflow/temporal_setup.py +0 -60
- flock_core-0.4.543.dist-info/METADATA +0 -676
- flock_core-0.4.543.dist-info/RECORD +0 -572
- flock_core-0.4.543.dist-info/entry_points.txt +0 -2
- /flock/{core/logging → logging}/formatters/themes.py +0 -0
- /flock/{core/logging → logging}/span_middleware/baggage_span_processor.py +0 -0
- /flock/{core/mcp → mcp}/util/__init__.py +0 -0
- {flock_core-0.4.543.dist-info → flock_core-0.5.0.dist-info}/WHEEL +0 -0
flock/modules/zep/zep_module.py
DELETED
|
@@ -1,192 +0,0 @@
|
|
|
1
|
-
import uuid
|
|
2
|
-
from typing import Any
|
|
3
|
-
|
|
4
|
-
from pydantic import Field
|
|
5
|
-
from zep_python.client import Zep
|
|
6
|
-
from zep_python.types import Message as ZepMessage, SessionSearchResult
|
|
7
|
-
|
|
8
|
-
from flock.core.context.context import FlockContext
|
|
9
|
-
from flock.core.flock_agent import FlockAgent
|
|
10
|
-
from flock.core.flock_module import FlockModule, FlockModuleConfig
|
|
11
|
-
from flock.core.flock_registry import flock_component
|
|
12
|
-
from flock.core.logging.logging import get_logger
|
|
13
|
-
|
|
14
|
-
logger = get_logger("module.zep")
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
class ZepModuleConfig(FlockModuleConfig):
|
|
18
|
-
"""Configuration for the Zep module."""
|
|
19
|
-
|
|
20
|
-
zep_url: str = "http://localhost:8000"
|
|
21
|
-
zep_api_key: str = "apikey"
|
|
22
|
-
min_fact_rating: float = Field(
|
|
23
|
-
default=0.7, description="Minimum rating for facts to be considered"
|
|
24
|
-
)
|
|
25
|
-
enable_read: bool = True
|
|
26
|
-
enable_write: bool = False
|
|
27
|
-
top_k: int = Field(default=10, description="Number of memories to retrieve")
|
|
28
|
-
user_id: str = Field(default="flock", description="User ID the memories will be associated with")
|
|
29
|
-
agent_id: str = Field(default="flock", description="Agent ID the memories will be associated with")
|
|
30
|
-
memory_input_key: str | None = Field(default=None, description="Input key to use for memory, if none the description of the agent will be used")
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
@flock_component(config_class=ZepModuleConfig)
|
|
35
|
-
class ZepModule(FlockModule):
|
|
36
|
-
"""Module that adds Zep capabilities to a Flock agent."""
|
|
37
|
-
|
|
38
|
-
name: str = "zep"
|
|
39
|
-
config: ZepModuleConfig = ZepModuleConfig()
|
|
40
|
-
session_id: str | None = None
|
|
41
|
-
user_id: str | None = None
|
|
42
|
-
|
|
43
|
-
def __init__(self, name, config: ZepModuleConfig) -> None:
|
|
44
|
-
"""Initialize Zep module."""
|
|
45
|
-
super().__init__(name=name, config=config)
|
|
46
|
-
logger.debug("Initializing Zep module")
|
|
47
|
-
zep_client = Zep(
|
|
48
|
-
base_url=self.config.zep_url, api_key=self.config.zep_api_key
|
|
49
|
-
)
|
|
50
|
-
self.user_id = self.name
|
|
51
|
-
self._setup_user(zep_client)
|
|
52
|
-
self.session_id = str(uuid.uuid4())
|
|
53
|
-
self._setup_session(zep_client)
|
|
54
|
-
|
|
55
|
-
def _setup_user(self, zep_client: Zep) -> None:
|
|
56
|
-
"""Set up user in Zep."""
|
|
57
|
-
if not zep_client or not self.user_id:
|
|
58
|
-
raise ValueError("Zep service or user_id not initialized")
|
|
59
|
-
|
|
60
|
-
try:
|
|
61
|
-
user = zep_client.user.get(user_id=self.user_id)
|
|
62
|
-
if not user:
|
|
63
|
-
zep_client.user.add(user_id=self.user_id)
|
|
64
|
-
except Exception:
|
|
65
|
-
zep_client.user.add(user_id=self.user_id)
|
|
66
|
-
|
|
67
|
-
def _setup_session(self, zep_client: Zep) -> None:
|
|
68
|
-
"""Set up new session."""
|
|
69
|
-
if not zep_client or not self.user_id or not self.session_id:
|
|
70
|
-
raise ValueError(
|
|
71
|
-
"Zep service, user_id, or session_id not initialized"
|
|
72
|
-
)
|
|
73
|
-
|
|
74
|
-
zep_client.memory.add_session(
|
|
75
|
-
user_id=self.user_id,
|
|
76
|
-
session_id=self.session_id,
|
|
77
|
-
)
|
|
78
|
-
|
|
79
|
-
def get_client(self) -> Zep:
|
|
80
|
-
"""Get Zep client."""
|
|
81
|
-
return Zep(
|
|
82
|
-
base_url=self.config.zep_url, api_key=self.config.zep_api_key
|
|
83
|
-
)
|
|
84
|
-
|
|
85
|
-
def get_memory(self, zep_client: Zep) -> str | None:
|
|
86
|
-
"""Get memory for the current session."""
|
|
87
|
-
if not zep_client or not self.session_id:
|
|
88
|
-
logger.error("Zep service or session_id not initialized")
|
|
89
|
-
return None
|
|
90
|
-
|
|
91
|
-
try:
|
|
92
|
-
memory = zep_client.memory.get(
|
|
93
|
-
self.session_id, min_rating=self.config.min_fact_rating
|
|
94
|
-
)
|
|
95
|
-
if memory:
|
|
96
|
-
return f"{memory.relevant_facts}"
|
|
97
|
-
except Exception as e:
|
|
98
|
-
logger.error(f"Error fetching memory: {e}")
|
|
99
|
-
return None
|
|
100
|
-
|
|
101
|
-
return None
|
|
102
|
-
|
|
103
|
-
def split_text(
|
|
104
|
-
self, text: str | None, max_length: int = 1000
|
|
105
|
-
) -> list[ZepMessage]:
|
|
106
|
-
"""Split text into smaller chunks."""
|
|
107
|
-
result: list[ZepMessage] = []
|
|
108
|
-
if not text:
|
|
109
|
-
return result
|
|
110
|
-
if len(text) <= max_length:
|
|
111
|
-
return [ZepMessage(role="user", content=text, role_type="user")]
|
|
112
|
-
for i in range(0, len(text), max_length):
|
|
113
|
-
result.append(
|
|
114
|
-
ZepMessage(
|
|
115
|
-
role="user",
|
|
116
|
-
content=text[i : i + max_length],
|
|
117
|
-
role_type="user",
|
|
118
|
-
)
|
|
119
|
-
)
|
|
120
|
-
return result
|
|
121
|
-
|
|
122
|
-
def add_to_memory(self, text: str, zep_client: Zep) -> None:
|
|
123
|
-
"""Add text to memory."""
|
|
124
|
-
if not zep_client or not self.session_id:
|
|
125
|
-
logger.error("Zep service or session_id not initialized")
|
|
126
|
-
return
|
|
127
|
-
|
|
128
|
-
messages = self.split_text(text)
|
|
129
|
-
zep_client.memory.add(session_id=self.session_id, messages=messages)
|
|
130
|
-
|
|
131
|
-
def search_memory(
|
|
132
|
-
self, query: str, zep_client: Zep
|
|
133
|
-
) -> list[SessionSearchResult]:
|
|
134
|
-
"""Search memory for a query."""
|
|
135
|
-
if not zep_client or not self.user_id:
|
|
136
|
-
logger.error("Zep service or user_id not initialized")
|
|
137
|
-
return []
|
|
138
|
-
|
|
139
|
-
response = zep_client.memory.search_sessions(
|
|
140
|
-
text=query,
|
|
141
|
-
user_id=self.user_id,
|
|
142
|
-
search_scope="facts",
|
|
143
|
-
min_fact_rating=self.config.min_fact_rating,
|
|
144
|
-
)
|
|
145
|
-
if not response.results:
|
|
146
|
-
return []
|
|
147
|
-
return response.results
|
|
148
|
-
|
|
149
|
-
async def on_post_evaluate(
|
|
150
|
-
self,
|
|
151
|
-
agent: FlockAgent,
|
|
152
|
-
inputs: dict[str, Any],
|
|
153
|
-
context: FlockContext | None = None,
|
|
154
|
-
result: dict[str, Any] | None = None,
|
|
155
|
-
) -> dict[str, Any]:
|
|
156
|
-
"""Format and display the output."""
|
|
157
|
-
if not self.config.enable_write:
|
|
158
|
-
return result
|
|
159
|
-
logger.debug("Saving data to memory")
|
|
160
|
-
zep_client = Zep(
|
|
161
|
-
base_url=self.config.zep_url, api_key=self.config.zep_api_key
|
|
162
|
-
)
|
|
163
|
-
self.add_to_memory(str(result), zep_client)
|
|
164
|
-
return result
|
|
165
|
-
|
|
166
|
-
async def on_pre_evaluate(
|
|
167
|
-
self,
|
|
168
|
-
agent: FlockAgent,
|
|
169
|
-
inputs: dict[str, Any],
|
|
170
|
-
context: FlockContext | None = None,
|
|
171
|
-
) -> dict[str, Any]:
|
|
172
|
-
"""Format and display the output."""
|
|
173
|
-
if not self.config.enable_read:
|
|
174
|
-
return inputs
|
|
175
|
-
|
|
176
|
-
zep_client = Zep(
|
|
177
|
-
base_url=self.config.zep_url, api_key=self.config.zep_api_key
|
|
178
|
-
)
|
|
179
|
-
|
|
180
|
-
logger.debug("Searching memory")
|
|
181
|
-
facts = self.search_memory(str(inputs), zep_client)
|
|
182
|
-
|
|
183
|
-
# Add memory to inputs
|
|
184
|
-
facts_str = ""
|
|
185
|
-
if facts:
|
|
186
|
-
for fact in facts:
|
|
187
|
-
facts_str += fact.fact.fact + "\n"
|
|
188
|
-
logger.debug("Found facts in memory: {}", facts_str)
|
|
189
|
-
agent.input = agent.input + ", memory"
|
|
190
|
-
inputs["memory"] = facts_str
|
|
191
|
-
|
|
192
|
-
return inputs
|
flock/platform/docker_tools.py
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import subprocess
|
|
2
|
-
import time
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
def _check_docker_running():
|
|
6
|
-
"""Check if Docker is running by calling 'docker info'."""
|
|
7
|
-
try:
|
|
8
|
-
result = subprocess.run(
|
|
9
|
-
["docker", "info"],
|
|
10
|
-
stdout=subprocess.PIPE,
|
|
11
|
-
stderr=subprocess.PIPE,
|
|
12
|
-
text=True,
|
|
13
|
-
)
|
|
14
|
-
return result.returncode == 0
|
|
15
|
-
except Exception:
|
|
16
|
-
return False
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
def _start_docker():
|
|
20
|
-
"""Attempt to start Docker.
|
|
21
|
-
This example first tries 'systemctl start docker' and then 'service docker start'.
|
|
22
|
-
Adjust as needed for your environment.
|
|
23
|
-
"""
|
|
24
|
-
try:
|
|
25
|
-
print("Attempting to start Docker...")
|
|
26
|
-
result = subprocess.run(
|
|
27
|
-
["sudo", "systemctl", "start", "docker"],
|
|
28
|
-
stdout=subprocess.PIPE,
|
|
29
|
-
stderr=subprocess.PIPE,
|
|
30
|
-
text=True,
|
|
31
|
-
)
|
|
32
|
-
if result.returncode != 0:
|
|
33
|
-
result = subprocess.run(
|
|
34
|
-
["sudo", "service", "docker", "start"],
|
|
35
|
-
stdout=subprocess.PIPE,
|
|
36
|
-
stderr=subprocess.PIPE,
|
|
37
|
-
text=True,
|
|
38
|
-
)
|
|
39
|
-
# Give Docker a moment to start.
|
|
40
|
-
time.sleep(3)
|
|
41
|
-
if _check_docker_running():
|
|
42
|
-
print("Docker is now running.")
|
|
43
|
-
return True
|
|
44
|
-
else:
|
|
45
|
-
print("Docker did not start successfully.")
|
|
46
|
-
return False
|
|
47
|
-
except Exception as e:
|
|
48
|
-
print(f"Exception when trying to start Docker: {e}")
|
|
49
|
-
return False
|
flock/platform/jaeger_install.py
DELETED
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
import socket
|
|
2
|
-
import subprocess
|
|
3
|
-
from urllib.parse import urlparse
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class JaegerInstaller:
|
|
7
|
-
jaeger_endpoint: str = None
|
|
8
|
-
jaeger_transport: str = "grpc"
|
|
9
|
-
|
|
10
|
-
def _check_jaeger_running(self):
|
|
11
|
-
"""Check if Jaeger is reachable by attempting a socket connection.
|
|
12
|
-
For HTTP transport, we parse the URL; for gRPC, we expect "host:port".
|
|
13
|
-
"""
|
|
14
|
-
try:
|
|
15
|
-
if self.jaeger_transport == "grpc":
|
|
16
|
-
host, port = self.jaeger_endpoint.split(":")
|
|
17
|
-
port = int(port)
|
|
18
|
-
elif self.jaeger_transport == "http":
|
|
19
|
-
parsed = urlparse(self.jaeger_endpoint)
|
|
20
|
-
host = parsed.hostname
|
|
21
|
-
port = parsed.port if parsed.port else 80
|
|
22
|
-
else:
|
|
23
|
-
return False
|
|
24
|
-
|
|
25
|
-
# Try connecting to the host and port.
|
|
26
|
-
with socket.create_connection((host, port), timeout=3):
|
|
27
|
-
return True
|
|
28
|
-
except Exception:
|
|
29
|
-
return False
|
|
30
|
-
|
|
31
|
-
def _is_jaeger_container_running(self):
|
|
32
|
-
"""Check if a Jaeger container (using the official all-in-one image) is running.
|
|
33
|
-
This uses 'docker ps' to filter for containers running the Jaeger image.
|
|
34
|
-
"""
|
|
35
|
-
try:
|
|
36
|
-
result = subprocess.run(
|
|
37
|
-
[
|
|
38
|
-
"docker",
|
|
39
|
-
"ps",
|
|
40
|
-
"--filter",
|
|
41
|
-
"ancestor=jaegertracing/all-in-one:latest",
|
|
42
|
-
"--format",
|
|
43
|
-
"{{.ID}}",
|
|
44
|
-
],
|
|
45
|
-
stdout=subprocess.PIPE,
|
|
46
|
-
stderr=subprocess.PIPE,
|
|
47
|
-
text=True,
|
|
48
|
-
)
|
|
49
|
-
return bool(result.stdout.strip())
|
|
50
|
-
except Exception:
|
|
51
|
-
return False
|
|
52
|
-
|
|
53
|
-
def _provision_jaeger_container(self):
|
|
54
|
-
"""Provision a Jaeger container using Docker."""
|
|
55
|
-
try:
|
|
56
|
-
print("Provisioning Jaeger container using Docker...")
|
|
57
|
-
result = subprocess.run(
|
|
58
|
-
[
|
|
59
|
-
"docker",
|
|
60
|
-
"run",
|
|
61
|
-
"-d",
|
|
62
|
-
"--name",
|
|
63
|
-
"jaeger",
|
|
64
|
-
"-p",
|
|
65
|
-
"16686:16686",
|
|
66
|
-
"-p",
|
|
67
|
-
"14250:14250",
|
|
68
|
-
"-p",
|
|
69
|
-
"14268:14268",
|
|
70
|
-
"jaegertracing/all-in-one:latest",
|
|
71
|
-
],
|
|
72
|
-
stdout=subprocess.PIPE,
|
|
73
|
-
stderr=subprocess.PIPE,
|
|
74
|
-
text=True,
|
|
75
|
-
)
|
|
76
|
-
if result.returncode == 0:
|
|
77
|
-
print("Jaeger container started successfully.")
|
|
78
|
-
return True
|
|
79
|
-
else:
|
|
80
|
-
print(
|
|
81
|
-
f"Failed to start Jaeger container. Error: {result.stderr}"
|
|
82
|
-
)
|
|
83
|
-
return False
|
|
84
|
-
except Exception as e:
|
|
85
|
-
print(f"Exception when provisioning Jaeger container: {e}")
|
|
86
|
-
return False
|
flock/routers/__init__.py
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"""Routers for the Flock framework."""
|
flock/routers/agent/__init__.py
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"""Agent-based router implementation for the Flock framework."""
|
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
"""Agent-based router implementation for the Flock framework."""
|
|
2
|
-
|
|
3
|
-
from typing import Any
|
|
4
|
-
|
|
5
|
-
from flock.core.context.context import FlockContext
|
|
6
|
-
from flock.core.flock_agent import FlockAgent
|
|
7
|
-
from flock.core.flock_registry import flock_component
|
|
8
|
-
from flock.core.flock_router import (
|
|
9
|
-
FlockRouter,
|
|
10
|
-
FlockRouterConfig,
|
|
11
|
-
HandOffRequest,
|
|
12
|
-
)
|
|
13
|
-
from flock.core.logging.formatters.themes import OutputTheme
|
|
14
|
-
from flock.core.logging.logging import get_logger
|
|
15
|
-
from flock.evaluators.declarative.declarative_evaluator import (
|
|
16
|
-
DeclarativeEvaluator,
|
|
17
|
-
DeclarativeEvaluatorConfig,
|
|
18
|
-
)
|
|
19
|
-
from flock.modules.output.output_module import OutputModule, OutputModuleConfig
|
|
20
|
-
from flock.routers.agent.handoff_agent import (
|
|
21
|
-
AgentInfo,
|
|
22
|
-
HandoffAgent,
|
|
23
|
-
)
|
|
24
|
-
|
|
25
|
-
logger = get_logger("agent_router")
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
class AgentRouterConfig(FlockRouterConfig):
|
|
29
|
-
"""Configuration for the agent router.
|
|
30
|
-
|
|
31
|
-
This class extends FlockRouterConfig with parameters specific to the agent router.
|
|
32
|
-
"""
|
|
33
|
-
|
|
34
|
-
with_output: bool = False
|
|
35
|
-
confidence_threshold: float = 0.5 # No additional parameters needed for now
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
@flock_component(config_class=AgentRouterConfig)
|
|
39
|
-
class AgentRouter(FlockRouter):
|
|
40
|
-
"""Router that uses a FlockAgent to determine the next agent in a workflow.
|
|
41
|
-
|
|
42
|
-
This class is responsible for:
|
|
43
|
-
1. Creating and managing a HandoffAgent
|
|
44
|
-
2. Analyzing available agents in the registry
|
|
45
|
-
3. Using the HandoffAgent to determine the best next agent
|
|
46
|
-
4. Creating a HandOff object with the selected agent
|
|
47
|
-
"""
|
|
48
|
-
|
|
49
|
-
def __init__(
|
|
50
|
-
self,
|
|
51
|
-
name: str = "agent_router",
|
|
52
|
-
config: AgentRouterConfig | None = None,
|
|
53
|
-
):
|
|
54
|
-
"""Initialize the AgentRouter.
|
|
55
|
-
|
|
56
|
-
Args:
|
|
57
|
-
registry: The agent registry containing all available agents
|
|
58
|
-
name: The name of the router
|
|
59
|
-
config: The router configuration
|
|
60
|
-
"""
|
|
61
|
-
super().__init__(
|
|
62
|
-
name=name, config=config or AgentRouterConfig(name=name)
|
|
63
|
-
)
|
|
64
|
-
|
|
65
|
-
async def route(
|
|
66
|
-
self,
|
|
67
|
-
current_agent: FlockAgent,
|
|
68
|
-
result: dict[str, Any],
|
|
69
|
-
context: FlockContext,
|
|
70
|
-
) -> HandOffRequest:
|
|
71
|
-
"""Determine the next agent to hand off to based on the current agent's output.
|
|
72
|
-
|
|
73
|
-
Args:
|
|
74
|
-
current_agent: The agent that just completed execution
|
|
75
|
-
result: The output from the current agent
|
|
76
|
-
context: The global execution context
|
|
77
|
-
|
|
78
|
-
Returns:
|
|
79
|
-
A HandOff object containing the next agent and input data
|
|
80
|
-
"""
|
|
81
|
-
# Get all available agents from context.agent_definitions
|
|
82
|
-
agent_definitions = context.agent_definitions
|
|
83
|
-
handoff_agent = HandoffAgent(model=current_agent.model)
|
|
84
|
-
handoff_agent.evaluator = DeclarativeEvaluator(
|
|
85
|
-
name="evaluator",
|
|
86
|
-
config=DeclarativeEvaluatorConfig(
|
|
87
|
-
model=current_agent.model,
|
|
88
|
-
use_cache=True,
|
|
89
|
-
max_tokens=1000,
|
|
90
|
-
temperature=0.0,
|
|
91
|
-
),
|
|
92
|
-
)
|
|
93
|
-
if self.config.with_output:
|
|
94
|
-
handoff_agent.add_module(
|
|
95
|
-
OutputModule(
|
|
96
|
-
name="output",
|
|
97
|
-
config=OutputModuleConfig(
|
|
98
|
-
theme=OutputTheme.abernathy,
|
|
99
|
-
),
|
|
100
|
-
)
|
|
101
|
-
)
|
|
102
|
-
available_agents = self._get_available_agents(
|
|
103
|
-
agent_definitions, current_agent.name
|
|
104
|
-
)
|
|
105
|
-
|
|
106
|
-
if not available_agents:
|
|
107
|
-
logger.warning("No available agents for agent-based routing")
|
|
108
|
-
return HandOffRequest(
|
|
109
|
-
next_agent="",
|
|
110
|
-
output_to_input_merge_strategy="add",
|
|
111
|
-
override_next_agent=None,
|
|
112
|
-
override_context=None,
|
|
113
|
-
)
|
|
114
|
-
|
|
115
|
-
# Prepare input for the handoff agent
|
|
116
|
-
handoff_input = {
|
|
117
|
-
"current_agent_name": current_agent.name,
|
|
118
|
-
"current_agent_description": current_agent.description,
|
|
119
|
-
"current_agent_input": current_agent.input,
|
|
120
|
-
"current_agent_output": current_agent.output,
|
|
121
|
-
"current_result": result,
|
|
122
|
-
"available_agents": available_agents,
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
try:
|
|
126
|
-
# Run the handoff agent to determine the next agent
|
|
127
|
-
handoff_result = await handoff_agent.run_async(handoff_input)
|
|
128
|
-
|
|
129
|
-
# Extract the decision
|
|
130
|
-
next_agent_name = handoff_result.get("agent_name")
|
|
131
|
-
confidence = handoff_result.get("confidence")
|
|
132
|
-
reasoning = handoff_result.get("reasoning")
|
|
133
|
-
logger.info(
|
|
134
|
-
f"Agent router selected agent '{next_agent_name}' with confidence {confidence} and reasoning: {reasoning}"
|
|
135
|
-
)
|
|
136
|
-
|
|
137
|
-
if confidence < self.config.confidence_threshold:
|
|
138
|
-
logger.info(
|
|
139
|
-
f"No suitable next agent found (best score: {confidence})"
|
|
140
|
-
)
|
|
141
|
-
return HandOffRequest(
|
|
142
|
-
next_agent="",
|
|
143
|
-
output_to_input_merge_strategy="add",
|
|
144
|
-
override_next_agent=None,
|
|
145
|
-
override_context=None,
|
|
146
|
-
)
|
|
147
|
-
|
|
148
|
-
next_agent = agent_definitions.get(next_agent_name)
|
|
149
|
-
if not next_agent:
|
|
150
|
-
logger.error(
|
|
151
|
-
f"Selected agent '{next_agent_name}' not found in agent definitions"
|
|
152
|
-
)
|
|
153
|
-
return HandOffRequest(
|
|
154
|
-
next_agent="",
|
|
155
|
-
output_to_input_merge_strategy="add",
|
|
156
|
-
override_next_agent=None,
|
|
157
|
-
override_context=None,
|
|
158
|
-
)
|
|
159
|
-
|
|
160
|
-
logger.info(
|
|
161
|
-
f"Agent router selected agent '{next_agent_name}' with confidence {confidence}"
|
|
162
|
-
)
|
|
163
|
-
return HandOffRequest(
|
|
164
|
-
next_agent=next_agent_name,
|
|
165
|
-
output_to_input_merge_strategy="add",
|
|
166
|
-
override_next_agent=None,
|
|
167
|
-
override_context=None,
|
|
168
|
-
)
|
|
169
|
-
|
|
170
|
-
except Exception as e:
|
|
171
|
-
logger.error(f"Error in agent-based routing: {e}")
|
|
172
|
-
return HandOffRequest(
|
|
173
|
-
next_agent="",
|
|
174
|
-
output_to_input_merge_strategy="add",
|
|
175
|
-
override_next_agent=None,
|
|
176
|
-
override_context=None,
|
|
177
|
-
)
|
|
178
|
-
|
|
179
|
-
def _get_available_agents(
|
|
180
|
-
self, agent_definitions: dict[str, Any], current_agent_name: str
|
|
181
|
-
) -> list[AgentInfo]:
|
|
182
|
-
"""Get all available agents except the current one and the handoff agent.
|
|
183
|
-
|
|
184
|
-
Args:
|
|
185
|
-
agent_definitions: Dictionary of available agents
|
|
186
|
-
current_agent_name: Name of the current agent to exclude
|
|
187
|
-
|
|
188
|
-
Returns:
|
|
189
|
-
List of available agents as AgentInfo objects
|
|
190
|
-
"""
|
|
191
|
-
agents = []
|
|
192
|
-
for agent_name in agent_definitions:
|
|
193
|
-
if agent_name != current_agent_name:
|
|
194
|
-
agent = agent_definitions[agent_name]
|
|
195
|
-
agent_info = AgentInfo(
|
|
196
|
-
name=agent_name,
|
|
197
|
-
description=agent.agent_data["description"]
|
|
198
|
-
if agent.agent_data["description"]
|
|
199
|
-
else "",
|
|
200
|
-
input_schema=agent.agent_data["input"],
|
|
201
|
-
output_schema=agent.agent_data["output"],
|
|
202
|
-
)
|
|
203
|
-
agents.append(agent_info)
|
|
204
|
-
return agents
|
|
205
|
-
|
|
206
|
-
def _get_schema_from_agent(
|
|
207
|
-
self, agent: Any, schema_type: str
|
|
208
|
-
) -> dict[str, Any]:
|
|
209
|
-
"""Extract input or output schema from an agent.
|
|
210
|
-
|
|
211
|
-
Args:
|
|
212
|
-
agent: The agent to extract schema from
|
|
213
|
-
schema_type: Either "input" or "output"
|
|
214
|
-
|
|
215
|
-
Returns:
|
|
216
|
-
Dictionary representation of the schema
|
|
217
|
-
"""
|
|
218
|
-
schema = {}
|
|
219
|
-
schema_str = agent.agent_data.get(schema_type, "")
|
|
220
|
-
|
|
221
|
-
# Parse the schema string to extract field names, types, and descriptions
|
|
222
|
-
if schema_str:
|
|
223
|
-
fields = schema_str.split(",")
|
|
224
|
-
for field in fields:
|
|
225
|
-
field = field.strip()
|
|
226
|
-
if ":" in field:
|
|
227
|
-
name, rest = field.split(":", 1)
|
|
228
|
-
name = name.strip()
|
|
229
|
-
schema[name] = rest.strip()
|
|
230
|
-
else:
|
|
231
|
-
schema[field] = "Any"
|
|
232
|
-
|
|
233
|
-
return schema
|
|
234
|
-
|
|
235
|
-
# The _create_next_input method is no longer needed since we're using hand_off_mode="add"
|
|
236
|
-
# instead of manually preparing inputs for the next agent
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
"""Handoff agent for the agent-based router."""
|
|
2
|
-
|
|
3
|
-
from pydantic import BaseModel
|
|
4
|
-
|
|
5
|
-
from flock.core.flock_agent import FlockAgent
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class AgentInfo(BaseModel):
|
|
9
|
-
"""Information about an agent for handoff decisions."""
|
|
10
|
-
|
|
11
|
-
name: str
|
|
12
|
-
description: str = ""
|
|
13
|
-
input_schema: str = ""
|
|
14
|
-
output_schema: str = ""
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
class HandoffDecision(BaseModel):
|
|
18
|
-
"""Decision about which agent to hand off to."""
|
|
19
|
-
|
|
20
|
-
agent_name: str
|
|
21
|
-
confidence: float
|
|
22
|
-
reasoning: str
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
class HandoffAgent(FlockAgent):
|
|
26
|
-
"""Agent that decides which agent to hand off to next.
|
|
27
|
-
|
|
28
|
-
This agent analyzes the current agent's output and available agents
|
|
29
|
-
to determine the best next agent in the workflow.
|
|
30
|
-
"""
|
|
31
|
-
|
|
32
|
-
def __init__(
|
|
33
|
-
self,
|
|
34
|
-
name: str = "handoff_agent",
|
|
35
|
-
model: str | None = None,
|
|
36
|
-
description: str = "Decides which agent to hand off to next",
|
|
37
|
-
):
|
|
38
|
-
"""Initialize the HandoffAgent.
|
|
39
|
-
|
|
40
|
-
Args:
|
|
41
|
-
name: The name of the agent
|
|
42
|
-
model: The model to use (e.g., 'openai/gpt-4o')
|
|
43
|
-
description: A human-readable description of the agent
|
|
44
|
-
"""
|
|
45
|
-
super().__init__(
|
|
46
|
-
name=name,
|
|
47
|
-
model=model,
|
|
48
|
-
description=description,
|
|
49
|
-
input=(
|
|
50
|
-
"current_agent_name: str | Name of the current agent, "
|
|
51
|
-
"current_agent_description: str | Description of the current agent, "
|
|
52
|
-
"current_agent_input: str | Input schema of the current agent, "
|
|
53
|
-
"current_agent_output: str | Output schema of the current agent, "
|
|
54
|
-
"current_result: dict | Output from the current agent, "
|
|
55
|
-
"available_agents: list[AgentInfo] | List of available agents"
|
|
56
|
-
),
|
|
57
|
-
output="agent_name: str | Name of the agent to hand off to, confidence: float | Confidence in the decision, reasoning: str | Reasoning for the decision",
|
|
58
|
-
)
|