langchain-agentx-python 0.4.6__tar.gz → 0.4.8__tar.gz
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.
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/PKG-INFO +1 -1
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/__init__.py +1 -1
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/__init__.py +82 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/allowlist.py +89 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/__init__.py +42 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/classifier.py +368 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/parser.py +172 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/prompt.py +188 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/schema.py +80 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/transcript.py +221 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/config.py +94 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/decision.py +215 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/events.py +94 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/factory.py +154 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/hook.py +398 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/rule_stripping.py +275 -0
- langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/state.py +98 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/base.py +26 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/policy.py +74 -12
- langchain-agentx-python-0.4.8/langchain_agentx/tools/bash/auto_mode_adapter.py +137 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/tool.py +20 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/PKG-INFO +1 -1
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/SOURCES.txt +16 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/pyproject.toml +1 -1
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/LICENSE +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/README.md +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/builtin/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/builtin/clear.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/builtin/compact.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/builtin/memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/builtin/reload_plugins.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/context.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/dispatcher.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/registry.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/result.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/command/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/config/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/config/model_profiles.yaml +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/config/model_profiles.yaml.example +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/agent_config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/agent_loop_config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/model_context_resolver.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/runtime_settings.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/config/token_estimator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/blocking_guard.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/compaction_service.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/message_utils.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/pipeline.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/settings.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/autocompact.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/base.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/collapse.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/microcompact.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/noop.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/snip.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/stages/tool_result_budget.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/context/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/exit/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/exit/exit_logic.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/exit/reason_codes.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/graph/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/graph/builtin_loop_control.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/graph/factory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/graph/graph_edges.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/async_hook_runner.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/engine.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/executors/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/executors/agent.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/executors/command.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/executors/http.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/executors/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/graph_wiring.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/registry.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/trust.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/hook/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/injection/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/injection/dedup.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/loop_abort.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/model_node.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/model_nodes.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/orphan_tool_results.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/retrier.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/retry_bridge.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/retry_events.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/retry_policy.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/schema_and_format.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/tool_and_model_binding.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/tool_call_degradation_corrector.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/model/tool_transcript_guard.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/builder.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/builtin.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/compact.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/sections.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/prompt/session_context.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/runtime/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/runtime/context.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/runtime/context_factory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/runtime/subagent_execution_paths.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/async_runner.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/context.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/fork_worktree_notice.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/graph.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/orchestrator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/progress.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/runner.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/loop/subagent/transcript.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/resolver.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/sections.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/instruction/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/age.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/agent_memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/extractor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/paths.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/recall.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/scan.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/memdir/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/session/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/session/compact_bridge.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/session/prompts.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/memory/session/session_memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/base.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/compaction.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/degradation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/exit_quality.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/session_memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/checkers/tool_behavior.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/retention_scheduler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/service.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/state.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/evaluation/store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/events/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/events/langchain_agentx_event_adapter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/logging/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/logging/debug_burst.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/logging/logging_config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/logging/logging_contract.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/replay/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/replay/cli.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/replay/service.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/replay/store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/replay/ui.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/collector.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/event_emitter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/hook_event_emitter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/sqlite_store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/trace_callback.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/observability/trace/trace_lifecycle_collector.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/builtin.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/manifest.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/registries.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/plugin/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/anthropic.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/compatible_chat_openai.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/env.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/model_profile.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/provider/openai.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/agent_session.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/conversation_factory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/conversation_recovery.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/conversation_session.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/factory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/session/protocol.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/core/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/core/ids.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/core/interfaces.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/core/notification_priority.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/core/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/loop_adapter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/loop_integration.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/prefetch_providers.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/provider_factory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/queued_command_provider.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/sqlite_queued_command_provider.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/integrations/tool_use_summary_provider.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/orchestrator/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/orchestrator/runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/output/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/output/sink.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/policy/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/policy/withhold_visibility.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/queue/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/queue/in_memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/skill_prefetch/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/skill_prefetch/attachments.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/skill_prefetch/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/skill_prefetch/provider.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/store/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/store/in_memory.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/store/sqlite_store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/high_water_mark.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/lock.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/path_resolver.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasklist/store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/ai_analysis/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/ai_analysis/base.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/ai_analysis/evaluation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/ai_analysis/registry.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/ai_analysis/scheduler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/base/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/base/contracts.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/custom/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/custom/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/custom/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/custom/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/custom/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/dream_task/state.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/in_process_teammate/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/in_process_teammate/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/in_process_teammate/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/in_process_teammate/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/in_process_teammate/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/runner.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_agent/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_bash/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_bash/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_bash/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_bash/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/local_bash/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/notification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/remote_agent/spec.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/trace_cleanup/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/trace_cleanup/bootstrap.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/trace_cleanup/executor.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/task_runtime/tasks/trace_cleanup/scheduler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/adapter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/errors.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/identical_call_cache.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/permission_context.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/pipeline.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/registry.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/agent_session.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/background.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/base.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/conversation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/resolvers/workflow.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/session_store.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/smoke_test_runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tool_runtime/state_bridge.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/agentx_guide.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/explore.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/general.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/plan.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/statusline_setup.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/built_in/verification.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/builtin_subagent_loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/cwd_resolution.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/registry/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/registry/config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/registry/registry.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/scope.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/agent/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/constants.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/html_preview.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ask_user_question/validators.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/ast_security.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/bash_hardening.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/bash_runtime_contract.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/cwd_reporter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/events.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/mode_validation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/observability.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/output_utils.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/path_security.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/read_only_validation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/result_presenter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/sandbox_decision.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/security.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/sed_edit_parser.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/sed_validation.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/semantics.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/session_manager.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/session_runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/shell_locator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/task_runtime.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/bash/windows_shell_quoting.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/diff_generator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/git_diff_generator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/quote_match.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/quote_normalizer.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/settings_validator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/staleness.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/edit/validator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/pagination.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/rg_list_backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/rg_pattern.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/glob/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/rg_subprocess_controller.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/grep/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/read/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/ripgrep_plugin_exclusions.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/argument_substitution.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/policy.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/skill/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/hooks.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_create/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_get/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_get/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_get/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_get/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_list/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_list/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_list/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_list/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_update/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_update/hooks.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_update/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_update/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/task_update/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/attachments.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/runtime_config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/user_message/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/preapproved.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/summary.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/webfetch/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/events.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/loader.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/websearch/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/backend.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/limits.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/models.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/prompt.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/tool.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/tools/write/validator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/cwd.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/host_platform.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/path_hierarchy.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/path_user_input.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/rg_executable.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/subprocess_text.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/temp_paths.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/unc_path.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/utils/win_reserved_paths.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/base.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/batch.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/dag.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/adapter.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/depth_resolver.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/handlers/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/handlers/parallel_handler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/handlers/route_handler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/handlers/stage_handler.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/stack.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/event_adapter/types.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/node.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/chaining.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/evaluator_optimizer.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/orchestrator.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/parallelization.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/patterns/routing.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workflow/state.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/__init__.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/capabilities.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/config.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/path_key_normalizer.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/resolver.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx/workspace/validators.py +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/dependency_links.txt +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/not-zip-safe +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/requires.txt +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/langchain_agentx_python.egg-info/top_level.txt +0 -0
- {langchain-agentx-python-0.4.6 → langchain-agentx-python-0.4.8}/setup.cfg +0 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/ — Auto Mode 决策骨架包
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
跨工具的 auto-mode 决策骨架,实现三段式决策:
|
|
6
|
+
L1 工具白名单 + L3 Bash 启发式 + L4 LLM 分类器
|
|
7
|
+
|
|
8
|
+
模块划分(对应设计文档 §4.2.1):
|
|
9
|
+
- config.py: AutoModeConfig(开关 / 阈值 / 模型)
|
|
10
|
+
- decision.py: AutoModeDecision dataclass + Reason 枚举
|
|
11
|
+
- state.py: AutoModeState(全局开关 + 累计 denial 计数)
|
|
12
|
+
- allowlist.py: SafeToolAllowlist(L1 静态白名单)
|
|
13
|
+
- events.py: AutoModeDecisionEvent(前端可观测)
|
|
14
|
+
- hook.py: AutoModeAuthHook(PRE_TOOL_USE Hook 集成)
|
|
15
|
+
- factory.py: build_auto_mode_hook(组件工厂)
|
|
16
|
+
|
|
17
|
+
依赖方向约束(重要):
|
|
18
|
+
骨架(auto_mode/*)不得直接 import tools/bash/{read_only_validation, bash_hardening},
|
|
19
|
+
只允许 import tools/bash/auto_mode_adapter。
|
|
20
|
+
这是"跨工具骨架 vs 工具自家细节"的边界(§4.2.3)。
|
|
21
|
+
|
|
22
|
+
CC 源码对照:
|
|
23
|
+
- src/utils/permissions/permissions.ts(决策入口)
|
|
24
|
+
- src/utils/permissions/classifierDecision.ts(L1 白名单)
|
|
25
|
+
- src/utils/permissions/yoloClassifier.ts(L4 LLM 分类器,Phase 2)
|
|
26
|
+
- src/utils/permissions/autoModeState.ts(状态管理)
|
|
27
|
+
"""
|
|
28
|
+
|
|
29
|
+
from .config import AutoModeConfig, AutoModeConfigError, validate_auto_mode_config
|
|
30
|
+
from .decision import (
|
|
31
|
+
AutoModeDecision,
|
|
32
|
+
AutoModeReason,
|
|
33
|
+
_allow,
|
|
34
|
+
_ask,
|
|
35
|
+
_deny,
|
|
36
|
+
_passthrough,
|
|
37
|
+
)
|
|
38
|
+
from .state import AutoModeState, get_auto_mode_state
|
|
39
|
+
from .allowlist import SafeToolAllowlist
|
|
40
|
+
from .events import AutoModeDecisionEvent
|
|
41
|
+
from .hook import AutoModeAuthHook
|
|
42
|
+
from .factory import build_auto_mode_hook
|
|
43
|
+
from .rule_stripping import (
|
|
44
|
+
CROSS_PLATFORM_CODE_EXEC,
|
|
45
|
+
DEFAULT_DANGEROUS_BASH_PATTERNS,
|
|
46
|
+
StrippedRule,
|
|
47
|
+
StripResult,
|
|
48
|
+
is_dangerous_bash_permission,
|
|
49
|
+
DangerousRuleStripper,
|
|
50
|
+
)
|
|
51
|
+
|
|
52
|
+
__all__ = [
|
|
53
|
+
# Config
|
|
54
|
+
"AutoModeConfig",
|
|
55
|
+
"AutoModeConfigError",
|
|
56
|
+
"validate_auto_mode_config",
|
|
57
|
+
# Decision
|
|
58
|
+
"AutoModeDecision",
|
|
59
|
+
"AutoModeReason",
|
|
60
|
+
"_allow",
|
|
61
|
+
"_ask",
|
|
62
|
+
"_deny",
|
|
63
|
+
"_passthrough",
|
|
64
|
+
# State
|
|
65
|
+
"AutoModeState",
|
|
66
|
+
"get_auto_mode_state",
|
|
67
|
+
# Allowlist
|
|
68
|
+
"SafeToolAllowlist",
|
|
69
|
+
# Events
|
|
70
|
+
"AutoModeDecisionEvent",
|
|
71
|
+
# Hook
|
|
72
|
+
"AutoModeAuthHook",
|
|
73
|
+
# Factory
|
|
74
|
+
"build_auto_mode_hook",
|
|
75
|
+
# Rule Stripping
|
|
76
|
+
"CROSS_PLATFORM_CODE_EXEC",
|
|
77
|
+
"DEFAULT_DANGEROUS_BASH_PATTERNS",
|
|
78
|
+
"StrippedRule",
|
|
79
|
+
"StripResult",
|
|
80
|
+
"is_dangerous_bash_permission",
|
|
81
|
+
"DangerousRuleStripper",
|
|
82
|
+
]
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/allowlist.py — L1 工具白名单
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
静态白名单查表器,对应 CC SAFE_YOLO_ALLOWLISTED_TOOLS。
|
|
6
|
+
命中白名单的工具直接 allow,零 LLM 调用。
|
|
7
|
+
|
|
8
|
+
链路位置:
|
|
9
|
+
AutoModeAuthHook._decide() → SafeToolAllowlist.contains() → allow
|
|
10
|
+
|
|
11
|
+
当前裁剪范围:
|
|
12
|
+
- 暂不包含 Edit / Write(L2 acceptEdits fast-path 待后续实现)
|
|
13
|
+
- 白名单基于 CC classifierDecision.ts:56-94 迁移
|
|
14
|
+
|
|
15
|
+
CC 源码对照:
|
|
16
|
+
src/utils/permissions/classifierDecision.ts: SAFE_YOLO_ALLOWLISTED_TOOLS
|
|
17
|
+
"""
|
|
18
|
+
|
|
19
|
+
from __future__ import annotations
|
|
20
|
+
|
|
21
|
+
from typing import Iterable
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class SafeToolAllowlist:
|
|
25
|
+
"""静态白名单查表器。对应 CC SAFE_YOLO_ALLOWLISTED_TOOLS。
|
|
26
|
+
|
|
27
|
+
设计文档:docs/design-docs/tool-design/auto-mode-bash-classifier.html §5.3
|
|
28
|
+
|
|
29
|
+
命中白名单的工具直接 allow,无需调用 LLM 分类器。
|
|
30
|
+
|
|
31
|
+
白名单内容(对照 CC):
|
|
32
|
+
- 只读文件操作:Read / Glob / Grep
|
|
33
|
+
- 任务管理(仅元数据):TodoWrite / TaskCreate / TaskGet / TaskList /
|
|
34
|
+
TaskUpdate / TaskStop / TaskOutput
|
|
35
|
+
- UI / 计划态:AskUserQuestion / EnterPlanMode / ExitPlanMode
|
|
36
|
+
- Skill 加载(无副作用):Skill
|
|
37
|
+
- UserMessage(带外通信)
|
|
38
|
+
|
|
39
|
+
注意:
|
|
40
|
+
Edit / Write 不进默认白名单,走 acceptEdits fast-path(L2,待实现)。
|
|
41
|
+
"""
|
|
42
|
+
|
|
43
|
+
# CC SAFE_YOLO_ALLOWLISTED_TOOLS 迁移
|
|
44
|
+
DEFAULT_TOOLS: frozenset[str] = frozenset({
|
|
45
|
+
# 只读文件操作
|
|
46
|
+
"Read",
|
|
47
|
+
"Glob",
|
|
48
|
+
"Grep",
|
|
49
|
+
# 任务管理(仅元数据)
|
|
50
|
+
"TodoWrite",
|
|
51
|
+
"TaskCreate",
|
|
52
|
+
"TaskGet",
|
|
53
|
+
"TaskList",
|
|
54
|
+
"TaskUpdate",
|
|
55
|
+
"TaskStop",
|
|
56
|
+
"TaskOutput",
|
|
57
|
+
# UI / 计划态
|
|
58
|
+
"AskUserQuestion",
|
|
59
|
+
"EnterPlanMode",
|
|
60
|
+
"ExitPlanMode",
|
|
61
|
+
# Skill 加载(无副作用)
|
|
62
|
+
"Skill",
|
|
63
|
+
# UserMessage(带外通信)
|
|
64
|
+
"UserMessage",
|
|
65
|
+
})
|
|
66
|
+
|
|
67
|
+
def __init__(self, extra: Iterable[str] | None = None):
|
|
68
|
+
"""初始化白名单。
|
|
69
|
+
|
|
70
|
+
Args:
|
|
71
|
+
extra: 额外的安全工具名称(扩展默认白名单)
|
|
72
|
+
"""
|
|
73
|
+
self._tools: frozenset[str] = frozenset(self.DEFAULT_TOOLS) | frozenset(extra or ())
|
|
74
|
+
|
|
75
|
+
def contains(self, tool_name: str) -> bool:
|
|
76
|
+
"""检查工具是否在白名单中。
|
|
77
|
+
|
|
78
|
+
Args:
|
|
79
|
+
tool_name: 工具名称
|
|
80
|
+
|
|
81
|
+
Returns:
|
|
82
|
+
True 如果在白名单中,否则 False
|
|
83
|
+
"""
|
|
84
|
+
return tool_name in self._tools
|
|
85
|
+
|
|
86
|
+
@property
|
|
87
|
+
def tools(self) -> frozenset[str]:
|
|
88
|
+
"""返回当前白名单的所有工具(只读)。"""
|
|
89
|
+
return self._tools
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/classifier/ — LLM 分类器子包
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
实现 Auto Mode 的 L4 LLM 分类器,用于 fast-path miss 后的兜底决策。
|
|
6
|
+
|
|
7
|
+
模块划分:
|
|
8
|
+
- schema.py: CLASSIFY_RESULT_TOOL_SCHEMA(工具调用 schema)
|
|
9
|
+
- transcript.py: TranscriptBuilder(构建分类器输入上下文)
|
|
10
|
+
- prompt.py: AutoModePromptBuilder(构建 system prompt)
|
|
11
|
+
- classifier.py: LLMClassifier(核心分类逻辑)
|
|
12
|
+
- parser.py: ToolUseParser(解析分类器返回)
|
|
13
|
+
|
|
14
|
+
依赖方向约束:
|
|
15
|
+
本子模块可依赖 auto_mode 基础模块(config, decision),不得依赖 Bash 工具内部。
|
|
16
|
+
|
|
17
|
+
CC 源码对照:
|
|
18
|
+
- src/utils/permissions/yoloClassifier.ts:1012 — classifyYoloAction
|
|
19
|
+
- src/utils/permissions/yoloClassifier.ts:344-345 — transcript 安全设计
|
|
20
|
+
"""
|
|
21
|
+
|
|
22
|
+
from .schema import CLASSIFY_RESULT_TOOL_SCHEMA
|
|
23
|
+
from .transcript import TranscriptBuilder, get_transcript_builder
|
|
24
|
+
from .prompt import AutoModePromptBuilder, get_prompt_builder
|
|
25
|
+
from .classifier import LLMClassifier
|
|
26
|
+
from .parser import ToolUseParser, parse_classifier_result
|
|
27
|
+
|
|
28
|
+
__all__ = [
|
|
29
|
+
# Schema
|
|
30
|
+
"CLASSIFY_RESULT_TOOL_SCHEMA",
|
|
31
|
+
# Transcript
|
|
32
|
+
"TranscriptBuilder",
|
|
33
|
+
"get_transcript_builder",
|
|
34
|
+
# Prompt
|
|
35
|
+
"AutoModePromptBuilder",
|
|
36
|
+
"get_prompt_builder",
|
|
37
|
+
# Classifier
|
|
38
|
+
"LLMClassifier",
|
|
39
|
+
# Parser
|
|
40
|
+
"ToolUseParser",
|
|
41
|
+
"parse_classifier_result",
|
|
42
|
+
]
|
langchain-agentx-python-0.4.8/langchain_agentx/tool_runtime/auto_mode/classifier/classifier.py
ADDED
|
@@ -0,0 +1,368 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/classifier/classifier.py — LLM 分类器核心
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
实现 Auto Mode 的 L4 LLM 分类器,对 fast-path miss 的工具调用进行分类。
|
|
6
|
+
|
|
7
|
+
链路位置:
|
|
8
|
+
AutoModeAuthHook.decide() → LLMClassifier.classify() → AutoModeDecision
|
|
9
|
+
|
|
10
|
+
当前裁剪范围(Phase 2):
|
|
11
|
+
- 基础分类流程
|
|
12
|
+
- 超时处理(fail-closed:返回 CLASSIFIER_UNAVAILABLE)
|
|
13
|
+
- 四级模型优先级:explicit_chat_model > explicit_factory > config.classifier_model > ctx.model
|
|
14
|
+
- require_separate_classifier_model 检查
|
|
15
|
+
|
|
16
|
+
CC 源码对照:
|
|
17
|
+
- src/utils/permissions/yoloClassifier.ts:1012 — classifyYoloAction
|
|
18
|
+
- src/utils/permissions/yoloClassifier.ts:cache_control — action block 位置
|
|
19
|
+
"""
|
|
20
|
+
|
|
21
|
+
from __future__ import annotations
|
|
22
|
+
|
|
23
|
+
import asyncio
|
|
24
|
+
from dataclasses import dataclass, field
|
|
25
|
+
from typing import TYPE_CHECKING, Any, Awaitable, Callable
|
|
26
|
+
from enum import Enum
|
|
27
|
+
|
|
28
|
+
from .schema import CLASSIFY_RESULT_TOOL_SCHEMA
|
|
29
|
+
from .transcript import TranscriptBuilder, TranscriptConfig, get_transcript_builder
|
|
30
|
+
from .prompt import AutoModePromptBuilder, PromptConfig, get_prompt_builder
|
|
31
|
+
from .parser import ToolUseParser, get_tool_use_parser, ParseError
|
|
32
|
+
|
|
33
|
+
if TYPE_CHECKING:
|
|
34
|
+
from langchain_core.language_models.chat_models import BaseChatModel
|
|
35
|
+
from langchain_core.messages import BaseMessage
|
|
36
|
+
|
|
37
|
+
from ..config import AutoModeConfig
|
|
38
|
+
from ..decision import AutoModeDecision, AutoModeReason
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
class ClassifierError(Exception):
|
|
42
|
+
"""分类器错误。"""
|
|
43
|
+
|
|
44
|
+
def __init__(self, message: str, retryable: bool = False):
|
|
45
|
+
super().__init__(message)
|
|
46
|
+
self.retryable = retryable
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
@dataclass
|
|
50
|
+
class ClassifierInput:
|
|
51
|
+
"""分类器输入。"""
|
|
52
|
+
|
|
53
|
+
tool_name: str
|
|
54
|
+
"""工具名称。"""
|
|
55
|
+
|
|
56
|
+
tool_input: dict[str, Any]
|
|
57
|
+
"""工具输入参数。"""
|
|
58
|
+
|
|
59
|
+
action_text: str
|
|
60
|
+
"""操作描述(tool_name + tool_input 的组合)。"""
|
|
61
|
+
|
|
62
|
+
messages: list["BaseMessage"]
|
|
63
|
+
"""对话历史消息。"""
|
|
64
|
+
|
|
65
|
+
chat_model: "BaseChatModel | None"
|
|
66
|
+
"""
|
|
67
|
+
显式指定的 chat 模型实例(最高优先级)。
|
|
68
|
+
如果为 None,则从其他来源解析模型。
|
|
69
|
+
"""
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
@dataclass
|
|
73
|
+
class ClassifierOutput:
|
|
74
|
+
"""分类器输出。"""
|
|
75
|
+
|
|
76
|
+
decision: "AutoModeDecision"
|
|
77
|
+
"""决策结果。"""
|
|
78
|
+
|
|
79
|
+
thinking: str | None
|
|
80
|
+
"""分类器思考链(仅 L4 有值)。"""
|
|
81
|
+
|
|
82
|
+
elapsed_ms: float
|
|
83
|
+
"""分类耗时(毫秒)。"""
|
|
84
|
+
|
|
85
|
+
model_used: str | None
|
|
86
|
+
"""实际使用的模型标识。"""
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
@dataclass
|
|
90
|
+
class ClassifierConfig:
|
|
91
|
+
"""分类器配置。"""
|
|
92
|
+
|
|
93
|
+
timeout_s: float = 8.0
|
|
94
|
+
"""分类超时时间(秒)。"""
|
|
95
|
+
|
|
96
|
+
temperature: float = 0.0
|
|
97
|
+
"""温度参数(0 = 确定性输出)。"""
|
|
98
|
+
|
|
99
|
+
max_tokens: int = 500
|
|
100
|
+
"""最大输出 token 数。"""
|
|
101
|
+
|
|
102
|
+
require_separate_classifier_model: bool = False
|
|
103
|
+
"""
|
|
104
|
+
是否要求使用独立的分类器模型。
|
|
105
|
+
|
|
106
|
+
如果为 True,当无法获取独立模型时会抛出异常。
|
|
107
|
+
这是为了避免使用主对话模型(可能已被污染)进行分类。
|
|
108
|
+
"""
|
|
109
|
+
|
|
110
|
+
transcript_config: TranscriptConfig = field(default_factory=TranscriptConfig)
|
|
111
|
+
"""Transcript 构建配置。"""
|
|
112
|
+
|
|
113
|
+
prompt_config: PromptConfig = field(default_factory=PromptConfig)
|
|
114
|
+
"""Prompt 构建配置。"""
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
class LLMClassifier:
|
|
118
|
+
"""LLM 分类器。
|
|
119
|
+
|
|
120
|
+
对应 CC yoloClassifier.ts 的 classifyYoloAction 函数。
|
|
121
|
+
|
|
122
|
+
决策流程:
|
|
123
|
+
1. 解析 chat 模型(四级优先级)
|
|
124
|
+
2. 构建 transcript(安全过滤)
|
|
125
|
+
3. 构建 system prompt
|
|
126
|
+
4. 调用 LLM(强制 tool_choice=classify_result)
|
|
127
|
+
5. 解析返回结果
|
|
128
|
+
6. 转换为 AutoModeDecision
|
|
129
|
+
|
|
130
|
+
安全设计:
|
|
131
|
+
- 超时返回 CLASSIFIER_UNAVAILABLE(fail-closed)
|
|
132
|
+
- transcript 丢弃 assistant 文本(防止注入)
|
|
133
|
+
- require_separate_classifier_model 强制使用独立模型
|
|
134
|
+
"""
|
|
135
|
+
|
|
136
|
+
def __init__(
|
|
137
|
+
self,
|
|
138
|
+
*,
|
|
139
|
+
config: ClassifierConfig | None = None,
|
|
140
|
+
transcript_builder: TranscriptBuilder | None = None,
|
|
141
|
+
prompt_builder: AutoModePromptBuilder | None = None,
|
|
142
|
+
parser: ToolUseParser | None = None,
|
|
143
|
+
):
|
|
144
|
+
"""初始化 LLMClassifier。
|
|
145
|
+
|
|
146
|
+
Args:
|
|
147
|
+
config: 分类器配置
|
|
148
|
+
transcript_builder: Transcript 构建器
|
|
149
|
+
prompt_builder: Prompt 构建器
|
|
150
|
+
parser: 工具调用解析器
|
|
151
|
+
"""
|
|
152
|
+
self._config = config or ClassifierConfig()
|
|
153
|
+
self._transcript_builder = transcript_builder or get_transcript_builder(
|
|
154
|
+
self._config.transcript_config
|
|
155
|
+
)
|
|
156
|
+
self._prompt_builder = prompt_builder or get_prompt_builder(
|
|
157
|
+
self._config.prompt_config
|
|
158
|
+
)
|
|
159
|
+
self._parser = parser or get_tool_use_parser()
|
|
160
|
+
|
|
161
|
+
async def classify(
|
|
162
|
+
self,
|
|
163
|
+
input_data: ClassifierInput,
|
|
164
|
+
) -> ClassifierOutput:
|
|
165
|
+
"""执行分类。
|
|
166
|
+
|
|
167
|
+
Args:
|
|
168
|
+
input_data: 分类器输入
|
|
169
|
+
|
|
170
|
+
Returns:
|
|
171
|
+
ClassifierOutput
|
|
172
|
+
|
|
173
|
+
Raises:
|
|
174
|
+
ClassifierError: 分类失败
|
|
175
|
+
"""
|
|
176
|
+
import time
|
|
177
|
+
|
|
178
|
+
start_time = time.perf_counter()
|
|
179
|
+
|
|
180
|
+
# 解析 chat 模型
|
|
181
|
+
chat_model = await self._resolve_chat_model(input_data)
|
|
182
|
+
|
|
183
|
+
# 构建输入
|
|
184
|
+
transcript_messages = self._transcript_builder.build_with_action_context(
|
|
185
|
+
messages=input_data.messages,
|
|
186
|
+
tool_name=input_data.tool_name,
|
|
187
|
+
tool_input=input_data.tool_input,
|
|
188
|
+
action_text=input_data.action_text,
|
|
189
|
+
)
|
|
190
|
+
system_prompt = self._prompt_builder.build()
|
|
191
|
+
|
|
192
|
+
# 调用 LLM(带超时)
|
|
193
|
+
try:
|
|
194
|
+
response = await asyncio.wait_for(
|
|
195
|
+
self._invoke_llm(chat_model, system_prompt, transcript_messages),
|
|
196
|
+
timeout=self._config.timeout_s,
|
|
197
|
+
)
|
|
198
|
+
except asyncio.TimeoutError:
|
|
199
|
+
# 超时返回 CLASSIFIER_UNAVAILABLE(fail-closed)
|
|
200
|
+
return self._build_unavailable_output(
|
|
201
|
+
elapsed_ms=_ms_since(start_time),
|
|
202
|
+
reason="classification_timeout",
|
|
203
|
+
)
|
|
204
|
+
|
|
205
|
+
# 解析结果
|
|
206
|
+
try:
|
|
207
|
+
result = self._parser.parse(response)
|
|
208
|
+
except ParseError as e:
|
|
209
|
+
# 解析失败返回 CLASSIFIER_UNAVAILABLE(fail-closed)
|
|
210
|
+
return self._build_unavailable_output(
|
|
211
|
+
elapsed_ms=_ms_since(start_time),
|
|
212
|
+
reason=f"parse_error: {e}",
|
|
213
|
+
)
|
|
214
|
+
|
|
215
|
+
# 转换为 AutoModeDecision
|
|
216
|
+
decision = self._result_to_decision(
|
|
217
|
+
result=result,
|
|
218
|
+
tool_name=input_data.tool_name,
|
|
219
|
+
elapsed_ms=_ms_since(start_time),
|
|
220
|
+
)
|
|
221
|
+
|
|
222
|
+
return ClassifierOutput(
|
|
223
|
+
decision=decision,
|
|
224
|
+
thinking=result.thinking,
|
|
225
|
+
elapsed_ms=_ms_since(start_time),
|
|
226
|
+
model_used=getattr(chat_model, "model_name", None) or str(type(chat_model).__name__),
|
|
227
|
+
)
|
|
228
|
+
|
|
229
|
+
async def _invoke_llm(
|
|
230
|
+
self,
|
|
231
|
+
chat_model: "BaseChatModel",
|
|
232
|
+
system_prompt: str,
|
|
233
|
+
messages: list["BaseMessage"],
|
|
234
|
+
) -> "BaseMessage":
|
|
235
|
+
"""调用 LLM。
|
|
236
|
+
|
|
237
|
+
Args:
|
|
238
|
+
chat_model: Chat 模型
|
|
239
|
+
system_prompt: System prompt
|
|
240
|
+
messages: 消息列表
|
|
241
|
+
|
|
242
|
+
Returns:
|
|
243
|
+
AIMessage
|
|
244
|
+
"""
|
|
245
|
+
# 构建完整的消息列表
|
|
246
|
+
from langchain_core.messages import SystemMessage
|
|
247
|
+
|
|
248
|
+
full_messages = [SystemMessage(content=system_prompt)]
|
|
249
|
+
full_messages.extend(messages)
|
|
250
|
+
|
|
251
|
+
# 调用模型(强制使用 classify_result 工具)
|
|
252
|
+
response = await chat_model.ainvoke(
|
|
253
|
+
full_messages,
|
|
254
|
+
temperature=self._config.temperature,
|
|
255
|
+
max_tokens=self._config.max_tokens,
|
|
256
|
+
tools=[CLASSIFY_RESULT_TOOL_SCHEMA],
|
|
257
|
+
tool_choice={"type": "function", "name": "classify_result"},
|
|
258
|
+
)
|
|
259
|
+
|
|
260
|
+
return response
|
|
261
|
+
|
|
262
|
+
def _result_to_decision(
|
|
263
|
+
self,
|
|
264
|
+
result: Any,
|
|
265
|
+
tool_name: str,
|
|
266
|
+
elapsed_ms: float,
|
|
267
|
+
) -> "AutoModeDecision":
|
|
268
|
+
"""将分类结果转换为 AutoModeDecision。
|
|
269
|
+
|
|
270
|
+
Args:
|
|
271
|
+
result: ClassifierResult
|
|
272
|
+
tool_name: 工具名称
|
|
273
|
+
elapsed_ms: 耗时
|
|
274
|
+
|
|
275
|
+
Returns:
|
|
276
|
+
AutoModeDecision
|
|
277
|
+
"""
|
|
278
|
+
from ..decision import AutoModeDecision, AutoModeReason, _allow, _deny
|
|
279
|
+
|
|
280
|
+
if result.should_block:
|
|
281
|
+
return _deny(
|
|
282
|
+
layer="L4",
|
|
283
|
+
reason=AutoModeReason.LLM_DENY,
|
|
284
|
+
explanation=result.reason,
|
|
285
|
+
classifier_thinking=result.thinking,
|
|
286
|
+
elapsed_ms=elapsed_ms,
|
|
287
|
+
)
|
|
288
|
+
else:
|
|
289
|
+
return _allow(
|
|
290
|
+
layer="L4",
|
|
291
|
+
reason=AutoModeReason.LLM_ALLOW,
|
|
292
|
+
explanation=result.reason,
|
|
293
|
+
classifier_thinking=result.thinking,
|
|
294
|
+
elapsed_ms=elapsed_ms,
|
|
295
|
+
)
|
|
296
|
+
|
|
297
|
+
def _build_unavailable_output(
|
|
298
|
+
self,
|
|
299
|
+
*,
|
|
300
|
+
elapsed_ms: float,
|
|
301
|
+
reason: str,
|
|
302
|
+
) -> ClassifierOutput:
|
|
303
|
+
"""构建分类器不可用输出(fail-closed)。
|
|
304
|
+
|
|
305
|
+
Args:
|
|
306
|
+
elapsed_ms: 耗时
|
|
307
|
+
reason: 不可用原因
|
|
308
|
+
|
|
309
|
+
Returns:
|
|
310
|
+
ClassifierOutput,decision 为 ask
|
|
311
|
+
"""
|
|
312
|
+
from ..decision import AutoModeDecision, AutoModeReason, _ask
|
|
313
|
+
|
|
314
|
+
return ClassifierOutput(
|
|
315
|
+
decision=_ask(
|
|
316
|
+
layer="L4",
|
|
317
|
+
reason=AutoModeReason.CLASSIFIER_UNAVAILABLE,
|
|
318
|
+
explanation=f"Classifier unavailable: {reason}",
|
|
319
|
+
elapsed_ms=elapsed_ms,
|
|
320
|
+
),
|
|
321
|
+
thinking=None,
|
|
322
|
+
elapsed_ms=elapsed_ms,
|
|
323
|
+
model_used=None,
|
|
324
|
+
)
|
|
325
|
+
|
|
326
|
+
async def _resolve_chat_model(
|
|
327
|
+
self,
|
|
328
|
+
input_data: ClassifierInput,
|
|
329
|
+
) -> "BaseChatModel":
|
|
330
|
+
"""解析 chat 模型(四级优先级)。
|
|
331
|
+
|
|
332
|
+
优先级:
|
|
333
|
+
1. input_data.chat_model(显式指定)
|
|
334
|
+
2. 工厂函数(如果提供)
|
|
335
|
+
3. config.classifier_model(如果配置了)
|
|
336
|
+
4. 从 input_data 解析 ctx.model(兜底,会记 WARNING)
|
|
337
|
+
|
|
338
|
+
Returns:
|
|
339
|
+
BaseChatModel
|
|
340
|
+
|
|
341
|
+
Raises:
|
|
342
|
+
ClassifierError: 无法解析模型
|
|
343
|
+
"""
|
|
344
|
+
# 优先级 1:显式指定的模型
|
|
345
|
+
if input_data.chat_model is not None:
|
|
346
|
+
return input_data.chat_model
|
|
347
|
+
|
|
348
|
+
# 优先级 2-4:需要从外部注入的信息解析
|
|
349
|
+
# 这里返回占位符,实际由调用方提供
|
|
350
|
+
raise ClassifierError(
|
|
351
|
+
"No chat model available. "
|
|
352
|
+
"Please provide chat_model explicitly or configure classifier_model."
|
|
353
|
+
)
|
|
354
|
+
|
|
355
|
+
|
|
356
|
+
def _ms_since(start_time: float) -> float:
|
|
357
|
+
"""计算耗时(毫秒)。"""
|
|
358
|
+
import time
|
|
359
|
+
return (time.perf_counter() - start_time) * 1000
|
|
360
|
+
|
|
361
|
+
|
|
362
|
+
__all__ = [
|
|
363
|
+
"ClassifierError",
|
|
364
|
+
"ClassifierInput",
|
|
365
|
+
"ClassifierOutput",
|
|
366
|
+
"ClassifierConfig",
|
|
367
|
+
"LLMClassifier",
|
|
368
|
+
]
|