langchain-agentx-python 0.4.9__tar.gz → 0.5.0__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.9 → langchain-agentx-python-0.5.0}/PKG-INFO +1 -1
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/__init__.py +1 -1
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/__init__.py +5 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/adapter.py +40 -1
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/__init__.py +5 -0
- langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/auto_mode/config_update.py +59 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/decision.py +22 -2
- langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/auto_mode/feedback.py +103 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/hook.py +4 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/loader.py +63 -0
- langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/override.py +153 -0
- langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/permission_decision.py +99 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/pipeline.py +17 -8
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/policy.py +65 -14
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/session_store.py +19 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/backend.py +139 -32
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/PKG-INFO +1 -1
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/SOURCES.txt +4 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/requires.txt +1 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/pyproject.toml +2 -1
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/LICENSE +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/README.md +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/clear.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/compact.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/reload_plugins.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/context.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/dispatcher.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/registry.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/result.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/model_profiles.yaml +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/model_profiles.yaml.example +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/agent_config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/agent_loop_config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/model_context_resolver.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/runtime_settings.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/token_estimator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/blocking_guard.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/compaction_service.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/message_utils.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/pipeline.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/settings.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/autocompact.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/collapse.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/microcompact.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/noop.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/snip.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/tool_result_budget.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/exit_logic.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/reason_codes.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/builtin_loop_control.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/graph_edges.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/async_hook_runner.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/engine.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/agent.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/command.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/http.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/graph_wiring.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/registry.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/trust.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/injection/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/injection/dedup.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/loop_abort.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/model_node.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/model_nodes.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/orphan_tool_results.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retrier.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_bridge.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_events.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_policy.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/schema_and_format.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_and_model_binding.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_call_degradation_corrector.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_transcript_guard.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/builder.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/builtin.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/compact.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/sections.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/session_context.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/context.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/context_factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/subagent_execution_paths.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/async_runner.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/context.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/fork_worktree_notice.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/graph.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/orchestrator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/progress.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/runner.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/transcript.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/resolver.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/sections.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/age.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/agent_memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/extractor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/paths.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/recall.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/scan.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/compact_bridge.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/prompts.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/session_memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/compaction.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/degradation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/exit_quality.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/session_memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/tool_behavior.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/retention_scheduler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/service.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/state.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/store.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/events/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/events/langchain_agentx_event_adapter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/debug_burst.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/logging_config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/logging_contract.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/cli.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/service.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/store.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/ui.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/collector.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/event_emitter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/hook_event_emitter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/sqlite_store.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/trace_callback.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/trace_lifecycle_collector.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/builtin.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/manifest.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/registries.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/anthropic.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/compatible_chat_openai.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/env.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/model_profile.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/openai.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/agent_session.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_recovery.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_session.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/protocol.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/ids.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/interfaces.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/notification_priority.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/loop_adapter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/loop_integration.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/prefetch_providers.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/provider_factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/queued_command_provider.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/sqlite_queued_command_provider.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/tool_use_summary_provider.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/orchestrator/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/orchestrator/runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/output/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/output/sink.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/policy/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/policy/withhold_visibility.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/queue/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/queue/in_memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/attachments.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/provider.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/in_memory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/sqlite_store.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/high_water_mark.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/lock.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/path_resolver.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/store.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/evaluation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/registry.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/scheduler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/base/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/base/contracts.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/state.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/runner.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/notification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/spec.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/bootstrap.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/executor.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/scheduler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/allowlist.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/classifier.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/parser.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/schema.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/transcript.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/events.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/factory.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/rule_stripping.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/state.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/errors.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/identical_call_cache.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/permission_context.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/policy_decorator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/_abort.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/cli_interactive.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/handler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/headless.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/legacy_resolver_adapter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/race.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/registry.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/agent_session.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/background.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/conversation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/workflow.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/smoke_test_runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/state_bridge.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/agentx_guide.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/explore.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/general.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/plan.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/statusline_setup.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/verification.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/builtin_subagent_loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/cwd_resolution.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/registry.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/scope.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/constants.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/html_preview.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/validators.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/ast_security.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/auto_mode_adapter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/bash_hardening.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/bash_runtime_contract.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/cwd_reporter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/events.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/mode_validation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/observability.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/output_utils.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/path_security.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/read_only_validation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/result_presenter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sandbox_decision.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/security.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sed_edit_parser.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sed_validation.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/semantics.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/session_manager.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/session_runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/shell_locator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/task_runtime.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/windows_shell_quoting.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/diff_generator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/git_diff_generator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/quote_match.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/quote_normalizer.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/settings_validator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/staleness.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/validator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/pagination.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/rg_list_backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/rg_pattern.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/rg_subprocess_controller.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ripgrep_plugin_exclusions.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/argument_substitution.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/policy.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/hooks.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/hooks.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/attachments.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/runtime_config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/preapproved.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/summary.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/events.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/loader.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/backend.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/limits.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/models.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/prompt.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/tool.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/validator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/cwd.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/host_platform.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/path_hierarchy.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/path_user_input.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/rg_executable.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/subprocess_text.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/temp_paths.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/unc_path.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/win_reserved_paths.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/base.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/batch.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/dag.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/adapter.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/depth_resolver.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/parallel_handler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/route_handler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/stage_handler.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/stack.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/types.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/node.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/chaining.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/evaluator_optimizer.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/orchestrator.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/parallelization.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/routing.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/state.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/__init__.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/capabilities.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/config.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/path_key_normalizer.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/resolver.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/validators.py +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/dependency_links.txt +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/not-zip-safe +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/top_level.txt +0 -0
- {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/setup.cfg +0 -0
|
@@ -52,6 +52,7 @@ from .resolvers import (
|
|
|
52
52
|
PermissionResolver,
|
|
53
53
|
WorkflowPermissionResolver,
|
|
54
54
|
)
|
|
55
|
+
from .override import DenyOverrideManager, DenyOverrideRecord, enrich_blocked_deny_envelope
|
|
55
56
|
from .session_store import AgentSessionStore, FileReadRecord, FileWriteRecord
|
|
56
57
|
from .state_bridge import ToolStateBridge
|
|
57
58
|
|
|
@@ -97,6 +98,10 @@ __all__ = [
|
|
|
97
98
|
"AgentSessionStore",
|
|
98
99
|
"FileReadRecord",
|
|
99
100
|
"FileWriteRecord",
|
|
101
|
+
# deny override (L4 UX seam)
|
|
102
|
+
"DenyOverrideRecord",
|
|
103
|
+
"DenyOverrideManager",
|
|
104
|
+
"enrich_blocked_deny_envelope",
|
|
100
105
|
# pipeline
|
|
101
106
|
"ToolOutputManager",
|
|
102
107
|
"ToolExecutorPipeline",
|
|
@@ -58,6 +58,40 @@ from .base import RuntimeTool
|
|
|
58
58
|
from .pipeline import ToolExecutorPipeline
|
|
59
59
|
|
|
60
60
|
|
|
61
|
+
def _resolve_tool_call_id(
|
|
62
|
+
*,
|
|
63
|
+
config: RunnableConfig,
|
|
64
|
+
tool_runtime: ToolRuntime | None,
|
|
65
|
+
kwargs: dict[str, Any],
|
|
66
|
+
) -> str | None:
|
|
67
|
+
"""在构造 ctx 前解析 tool_call_id(对齐 CC toolUseID 贯穿决策链)。
|
|
68
|
+
|
|
69
|
+
优先级:ToolRuntime.tool_call_id → configurable → 工具入参 id 字段。
|
|
70
|
+
"""
|
|
71
|
+
tid: str | None = None
|
|
72
|
+
if tool_runtime is not None:
|
|
73
|
+
raw = getattr(tool_runtime, "tool_call_id", None)
|
|
74
|
+
if isinstance(raw, str) and raw:
|
|
75
|
+
tid = raw
|
|
76
|
+
|
|
77
|
+
configurable = config.get("configurable", {}) or {}
|
|
78
|
+
if not tid:
|
|
79
|
+
for key in ("tool_call_id", "tool_use_id"):
|
|
80
|
+
val = configurable.get(key)
|
|
81
|
+
if isinstance(val, str) and val:
|
|
82
|
+
tid = val
|
|
83
|
+
break
|
|
84
|
+
|
|
85
|
+
if not tid:
|
|
86
|
+
for key in ("tool_call_id", "id"):
|
|
87
|
+
val = kwargs.get(key)
|
|
88
|
+
if isinstance(val, str) and val:
|
|
89
|
+
tid = val
|
|
90
|
+
break
|
|
91
|
+
|
|
92
|
+
return tid
|
|
93
|
+
|
|
94
|
+
|
|
61
95
|
class LangChainAdapter:
|
|
62
96
|
"""
|
|
63
97
|
LangChain 集成适配器。
|
|
@@ -298,12 +332,17 @@ class LangChainAdapter:
|
|
|
298
332
|
effective_tool_flags["sandbox_excluded_commands"] = configurable[
|
|
299
333
|
"sandbox_excluded_commands"
|
|
300
334
|
]
|
|
335
|
+
resolved_tool_call_id = _resolve_tool_call_id(
|
|
336
|
+
config=config,
|
|
337
|
+
tool_runtime=tool_runtime,
|
|
338
|
+
kwargs=kwargs,
|
|
339
|
+
)
|
|
301
340
|
return adapter.build_tool_execution_context(
|
|
302
341
|
tool_name=tool.name,
|
|
303
342
|
raw_input=kwargs,
|
|
304
343
|
state=effective_state,
|
|
305
344
|
config=config,
|
|
306
|
-
tool_call_id=
|
|
345
|
+
tool_call_id=resolved_tool_call_id,
|
|
307
346
|
tool_flags=effective_tool_flags,
|
|
308
347
|
)
|
|
309
348
|
|
|
@@ -40,6 +40,7 @@ from .allowlist import SafeToolAllowlist
|
|
|
40
40
|
from .events import AutoModeDecisionEvent
|
|
41
41
|
from .hook import AutoModeAuthHook
|
|
42
42
|
from .factory import build_auto_mode_hook
|
|
43
|
+
from .feedback import AutoModeFeedback, FeedbackIngest, feedback_from_decision_event
|
|
43
44
|
from .rule_stripping import (
|
|
44
45
|
CROSS_PLATFORM_CODE_EXEC,
|
|
45
46
|
DEFAULT_DANGEROUS_BASH_PATTERNS,
|
|
@@ -72,6 +73,10 @@ __all__ = [
|
|
|
72
73
|
"AutoModeAuthHook",
|
|
73
74
|
# Factory
|
|
74
75
|
"build_auto_mode_hook",
|
|
76
|
+
# Feedback
|
|
77
|
+
"AutoModeFeedback",
|
|
78
|
+
"FeedbackIngest",
|
|
79
|
+
"feedback_from_decision_event",
|
|
75
80
|
# Rule Stripping
|
|
76
81
|
"CROSS_PLATFORM_CODE_EXEC",
|
|
77
82
|
"DEFAULT_DANGEROUS_BASH_PATTERNS",
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/config_update.py — Auto Mode 配置热更新
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
在运行时合并/替换 AutoModeConfig,并同步 PolicyEngine hook 与全局开关。
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
from __future__ import annotations
|
|
9
|
+
|
|
10
|
+
from dataclasses import replace
|
|
11
|
+
from typing import TYPE_CHECKING, Any
|
|
12
|
+
|
|
13
|
+
from .config import AutoModeConfig
|
|
14
|
+
from .state import get_auto_mode_state
|
|
15
|
+
|
|
16
|
+
if TYPE_CHECKING:
|
|
17
|
+
from ..policy import DefaultPolicyEngine, ToolPolicyConfig
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
def merge_auto_mode_config(
|
|
21
|
+
current: AutoModeConfig | None,
|
|
22
|
+
*,
|
|
23
|
+
enabled: bool | None = None,
|
|
24
|
+
classifier_model: str | None = None,
|
|
25
|
+
use_classifier: bool | None = None,
|
|
26
|
+
) -> AutoModeConfig:
|
|
27
|
+
"""基于当前配置生成新的 AutoModeConfig(frozen dataclass replace)。"""
|
|
28
|
+
base = current if current is not None else AutoModeConfig()
|
|
29
|
+
fields: dict[str, Any] = {}
|
|
30
|
+
if enabled is not None:
|
|
31
|
+
fields["enabled"] = enabled
|
|
32
|
+
if classifier_model is not None:
|
|
33
|
+
fields["classifier_model"] = classifier_model
|
|
34
|
+
if use_classifier is not None:
|
|
35
|
+
fields["use_classifier"] = use_classifier
|
|
36
|
+
if not fields:
|
|
37
|
+
return base
|
|
38
|
+
return replace(base, **fields)
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
def apply_auto_mode_config_to_engine(
|
|
42
|
+
engine: DefaultPolicyEngine,
|
|
43
|
+
config: AutoModeConfig,
|
|
44
|
+
) -> None:
|
|
45
|
+
"""将 AutoModeConfig 写入 DefaultPolicyEngine 与已挂载的 hook。"""
|
|
46
|
+
engine._config.auto_mode = config
|
|
47
|
+
hook = engine._auto_mode_hook
|
|
48
|
+
if hook is not None and hasattr(hook, "update_config"):
|
|
49
|
+
hook.update_config(config)
|
|
50
|
+
get_auto_mode_state().enabled = config.enabled
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
def apply_auto_mode_config_to_policy(
|
|
54
|
+
policy_config: ToolPolicyConfig,
|
|
55
|
+
config: AutoModeConfig,
|
|
56
|
+
) -> None:
|
|
57
|
+
"""更新 ToolPolicyConfig.auto_mode 字段。"""
|
|
58
|
+
policy_config.auto_mode = config
|
|
59
|
+
get_auto_mode_state().enabled = config.enabled
|
|
@@ -66,6 +66,12 @@ class AutoModeDecision:
|
|
|
66
66
|
def to_authorization_decision(self) -> "AuthorizationDecision":
|
|
67
67
|
"""转换为 AuthorizationDecision(用于 PolicyEngine 集成)。"""
|
|
68
68
|
from ..models import AuthorizationDecision
|
|
69
|
+
from ..permission_decision import (
|
|
70
|
+
POLICY_ID_PREFIX_AUTO_MODE,
|
|
71
|
+
PermissionDecisionType,
|
|
72
|
+
attach_decision_reason,
|
|
73
|
+
make_decision_reason,
|
|
74
|
+
)
|
|
69
75
|
|
|
70
76
|
metadata = {
|
|
71
77
|
"auto_mode_layer": self.layer,
|
|
@@ -78,12 +84,26 @@ class AutoModeDecision:
|
|
|
78
84
|
if self.matched_pattern:
|
|
79
85
|
metadata["auto_mode_pattern"] = self.matched_pattern
|
|
80
86
|
|
|
81
|
-
|
|
87
|
+
reason_type = (
|
|
88
|
+
PermissionDecisionType.CLASSIFIER
|
|
89
|
+
if self.layer == "L4"
|
|
90
|
+
else PermissionDecisionType.AUTO_MODE
|
|
91
|
+
)
|
|
92
|
+
decision = AuthorizationDecision(
|
|
82
93
|
behavior=self.behavior,
|
|
83
94
|
message=self.explanation,
|
|
84
|
-
policy_id=f"
|
|
95
|
+
policy_id=f"{POLICY_ID_PREFIX_AUTO_MODE}{self.layer}:{self.reason.value}",
|
|
85
96
|
metadata=metadata,
|
|
86
97
|
)
|
|
98
|
+
return attach_decision_reason(
|
|
99
|
+
decision,
|
|
100
|
+
make_decision_reason(
|
|
101
|
+
reason_type,
|
|
102
|
+
layer=self.layer,
|
|
103
|
+
reason=self.reason.value,
|
|
104
|
+
behavior=self.behavior,
|
|
105
|
+
),
|
|
106
|
+
)
|
|
87
107
|
|
|
88
108
|
|
|
89
109
|
@dataclass(frozen=True)
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/auto_mode/feedback.py — Auto Mode 反馈摄入
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
收集用户对 auto-approve 的纠正信号;有 endpoint 时 POST,否则追加本地 jsonl。
|
|
6
|
+
|
|
7
|
+
链路位置:
|
|
8
|
+
UI/CLI → FeedbackIngest.submit → Analytics 或 ~/.cache/.../auto_mode_feedback.jsonl
|
|
9
|
+
"""
|
|
10
|
+
|
|
11
|
+
from __future__ import annotations
|
|
12
|
+
|
|
13
|
+
import json
|
|
14
|
+
import time
|
|
15
|
+
from dataclasses import asdict, dataclass
|
|
16
|
+
from pathlib import Path
|
|
17
|
+
from typing import Any, Literal
|
|
18
|
+
from urllib import error as urllib_error
|
|
19
|
+
from urllib import request as urllib_request
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
@dataclass
|
|
23
|
+
class AutoModeFeedback:
|
|
24
|
+
tool_use_id: str
|
|
25
|
+
tool_name: str
|
|
26
|
+
was_auto_approved: bool
|
|
27
|
+
user_correction: Literal["approve", "deny"] | None
|
|
28
|
+
model_family: str
|
|
29
|
+
timestamp: float
|
|
30
|
+
session_id: str | None = None
|
|
31
|
+
extra: dict[str, Any] | None = None
|
|
32
|
+
|
|
33
|
+
def to_dict(self) -> dict[str, Any]:
|
|
34
|
+
out = asdict(self)
|
|
35
|
+
if out.get("extra") is None:
|
|
36
|
+
out.pop("extra", None)
|
|
37
|
+
return out
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
class FeedbackIngest:
|
|
41
|
+
"""Auto Mode 反馈摄入:本地 jsonl 或 HTTP POST。"""
|
|
42
|
+
|
|
43
|
+
def __init__(
|
|
44
|
+
self,
|
|
45
|
+
endpoint: str | None = None,
|
|
46
|
+
*,
|
|
47
|
+
local_path: str | Path | None = None,
|
|
48
|
+
timeout_s: float = 10.0,
|
|
49
|
+
) -> None:
|
|
50
|
+
self.endpoint = endpoint
|
|
51
|
+
self.timeout_s = timeout_s
|
|
52
|
+
if local_path is None:
|
|
53
|
+
local_path = Path.home() / ".cache" / "langchain_agentx" / "auto_mode_feedback.jsonl"
|
|
54
|
+
self._local_path = Path(local_path)
|
|
55
|
+
|
|
56
|
+
def submit(self, feedback: AutoModeFeedback) -> None:
|
|
57
|
+
"""提交反馈:有 endpoint 时 POST,否则仅本地 jsonl。"""
|
|
58
|
+
if self.endpoint:
|
|
59
|
+
self._post_remote(feedback)
|
|
60
|
+
else:
|
|
61
|
+
self._append_local(feedback)
|
|
62
|
+
|
|
63
|
+
def _append_local(self, feedback: AutoModeFeedback) -> None:
|
|
64
|
+
self._local_path.parent.mkdir(parents=True, exist_ok=True)
|
|
65
|
+
line = json.dumps(feedback.to_dict(), ensure_ascii=False)
|
|
66
|
+
with self._local_path.open("a", encoding="utf-8") as f:
|
|
67
|
+
f.write(line + "\n")
|
|
68
|
+
|
|
69
|
+
def _post_remote(self, feedback: AutoModeFeedback) -> None:
|
|
70
|
+
body = json.dumps(feedback.to_dict()).encode("utf-8")
|
|
71
|
+
req = urllib_request.Request(
|
|
72
|
+
self.endpoint,
|
|
73
|
+
data=body,
|
|
74
|
+
headers={"Content-Type": "application/json"},
|
|
75
|
+
method="POST",
|
|
76
|
+
)
|
|
77
|
+
try:
|
|
78
|
+
with urllib_request.urlopen(req, timeout=self.timeout_s) as resp:
|
|
79
|
+
if resp.status >= 400:
|
|
80
|
+
raise OSError(f"feedback endpoint returned {resp.status}")
|
|
81
|
+
except urllib_error.URLError as exc:
|
|
82
|
+
raise OSError(f"failed to POST auto-mode feedback: {exc}") from exc
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
def feedback_from_decision_event(
|
|
86
|
+
*,
|
|
87
|
+
tool_use_id: str,
|
|
88
|
+
tool_name: str,
|
|
89
|
+
was_auto_approved: bool,
|
|
90
|
+
user_correction: Literal["approve", "deny"] | None = None,
|
|
91
|
+
model_family: str = "",
|
|
92
|
+
session_id: str | None = None,
|
|
93
|
+
) -> AutoModeFeedback:
|
|
94
|
+
"""从 UI 事件构造 AutoModeFeedback。"""
|
|
95
|
+
return AutoModeFeedback(
|
|
96
|
+
tool_use_id=tool_use_id,
|
|
97
|
+
tool_name=tool_name,
|
|
98
|
+
was_auto_approved=was_auto_approved,
|
|
99
|
+
user_correction=user_correction,
|
|
100
|
+
model_family=model_family,
|
|
101
|
+
timestamp=time.time(),
|
|
102
|
+
session_id=session_id,
|
|
103
|
+
)
|
|
@@ -89,6 +89,10 @@ class AutoModeAuthHook:
|
|
|
89
89
|
self._tool_registry = tool_registry
|
|
90
90
|
self._event_bus = event_bus
|
|
91
91
|
|
|
92
|
+
def update_config(self, config: AutoModeConfig) -> None:
|
|
93
|
+
"""热更新 Auto Mode 配置(下一笔 decide 立即生效)。"""
|
|
94
|
+
self._config = config
|
|
95
|
+
|
|
92
96
|
def _emit_event(
|
|
93
97
|
self,
|
|
94
98
|
decision: AutoModeDecision,
|
|
@@ -27,6 +27,13 @@ from langchain_core.tools import BaseTool
|
|
|
27
27
|
from .adapter import LangChainAdapter
|
|
28
28
|
from .base import RuntimeTool
|
|
29
29
|
from .pipeline import ToolExecutorPipeline, ToolOutputManager
|
|
30
|
+
from .auto_mode.config import AutoModeConfig
|
|
31
|
+
from .auto_mode.config_update import (
|
|
32
|
+
apply_auto_mode_config_to_engine,
|
|
33
|
+
apply_auto_mode_config_to_policy,
|
|
34
|
+
merge_auto_mode_config,
|
|
35
|
+
)
|
|
36
|
+
from .auto_mode.state import get_auto_mode_state
|
|
30
37
|
from .policy import DefaultPolicyEngine, PolicyEngine, ToolPolicyConfig
|
|
31
38
|
from .registry import RuntimeToolRegistry
|
|
32
39
|
from .prompt.handler import PermissionPromptHandler
|
|
@@ -73,6 +80,7 @@ class ToolRuntimeLoader:
|
|
|
73
80
|
pipeline=self._pipeline,
|
|
74
81
|
adapter=self._adapter,
|
|
75
82
|
)
|
|
83
|
+
self._policy_config = policy_config
|
|
76
84
|
# 优先使用外部传入的 policy_engine;其次从 policy_config 构造;否则为 None
|
|
77
85
|
if policy_engine is not None:
|
|
78
86
|
self._policy: PolicyEngine | None = policy_engine
|
|
@@ -214,6 +222,61 @@ class ToolRuntimeLoader:
|
|
|
214
222
|
self._prompt_handler = prompt_handler
|
|
215
223
|
self._pipeline.set_prompt_handler(prompt_handler)
|
|
216
224
|
|
|
225
|
+
def update_auto_mode_config(
|
|
226
|
+
self,
|
|
227
|
+
*,
|
|
228
|
+
enabled: bool | None = None,
|
|
229
|
+
classifier_model: str | None = None,
|
|
230
|
+
classifier_path: str | None = None,
|
|
231
|
+
use_classifier: bool | None = None,
|
|
232
|
+
auto_mode_config: AutoModeConfig | None = None,
|
|
233
|
+
) -> AutoModeConfig:
|
|
234
|
+
"""热更新 auto_mode 配置,下一轮 authorize 立即生效。
|
|
235
|
+
|
|
236
|
+
Args:
|
|
237
|
+
enabled: 总开关(同步 AutoModeState.enabled)
|
|
238
|
+
classifier_model: 分类器模型 ID
|
|
239
|
+
classifier_path: classifier_model 别名(历史命名兼容)
|
|
240
|
+
use_classifier: 是否启用 L4 LLM 分类器
|
|
241
|
+
auto_mode_config: 整包替换(优先级最高)
|
|
242
|
+
|
|
243
|
+
Returns:
|
|
244
|
+
生效后的 AutoModeConfig
|
|
245
|
+
"""
|
|
246
|
+
model_id = classifier_model if classifier_model is not None else classifier_path
|
|
247
|
+
|
|
248
|
+
if auto_mode_config is not None:
|
|
249
|
+
effective = auto_mode_config
|
|
250
|
+
else:
|
|
251
|
+
current: AutoModeConfig | None = None
|
|
252
|
+
if self._policy_config is not None:
|
|
253
|
+
current = self._policy_config.auto_mode
|
|
254
|
+
elif isinstance(self._policy, DefaultPolicyEngine):
|
|
255
|
+
current = self._policy._config.auto_mode
|
|
256
|
+
effective = merge_auto_mode_config(
|
|
257
|
+
current,
|
|
258
|
+
enabled=enabled,
|
|
259
|
+
classifier_model=model_id,
|
|
260
|
+
use_classifier=use_classifier,
|
|
261
|
+
)
|
|
262
|
+
|
|
263
|
+
if self._policy_config is not None:
|
|
264
|
+
apply_auto_mode_config_to_policy(self._policy_config, effective)
|
|
265
|
+
if isinstance(self._policy, DefaultPolicyEngine):
|
|
266
|
+
apply_auto_mode_config_to_engine(self._policy, effective)
|
|
267
|
+
elif enabled is not None:
|
|
268
|
+
get_auto_mode_state().enabled = enabled
|
|
269
|
+
|
|
270
|
+
return effective
|
|
271
|
+
|
|
272
|
+
@property
|
|
273
|
+
def policy_config(self) -> ToolPolicyConfig | None:
|
|
274
|
+
return self._policy_config
|
|
275
|
+
|
|
276
|
+
@property
|
|
277
|
+
def policy(self) -> PolicyEngine | None:
|
|
278
|
+
return self._policy
|
|
279
|
+
|
|
217
280
|
@property
|
|
218
281
|
def registry(self) -> RuntimeToolRegistry:
|
|
219
282
|
return self._registry
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/override.py — deny 决策覆盖(L4 UX seam)
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
记录 policy deny 的 tool_call,供 UI/CLI 展示覆盖横幅;
|
|
6
|
+
apply_override 更新会话态,实际重试由宿主命令路由触发。
|
|
7
|
+
|
|
8
|
+
链路位置:
|
|
9
|
+
pipeline deny → enrich_blocked_deny_envelope → AgentSessionStore
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
from __future__ import annotations
|
|
13
|
+
|
|
14
|
+
import time
|
|
15
|
+
from dataclasses import dataclass
|
|
16
|
+
from typing import TYPE_CHECKING, Any, Literal
|
|
17
|
+
|
|
18
|
+
from .models import AuthorizationDecision, ToolExecutionContext, ToolResultEnvelope
|
|
19
|
+
|
|
20
|
+
if TYPE_CHECKING:
|
|
21
|
+
from .session_store import AgentSessionStore
|
|
22
|
+
|
|
23
|
+
OverrideDecision = Literal["allow", "confirm_deny"]
|
|
24
|
+
OverrideActor = Literal["user", "admin"]
|
|
25
|
+
RecordStatus = Literal["pending", "allow", "confirm_deny"]
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
@dataclass
|
|
29
|
+
class DenyOverrideRecord:
|
|
30
|
+
"""单次 deny 的覆盖记录。"""
|
|
31
|
+
|
|
32
|
+
tool_call_id: str
|
|
33
|
+
tool_name: str
|
|
34
|
+
original_decision: AuthorizationDecision
|
|
35
|
+
override_decision: RecordStatus = "pending"
|
|
36
|
+
override_at: float | None = None
|
|
37
|
+
override_by: OverrideActor | None = None
|
|
38
|
+
|
|
39
|
+
def to_dict(self) -> dict[str, Any]:
|
|
40
|
+
orig = self.original_decision
|
|
41
|
+
return {
|
|
42
|
+
"tool_call_id": self.tool_call_id,
|
|
43
|
+
"tool_name": self.tool_name,
|
|
44
|
+
"original_decision": {
|
|
45
|
+
"behavior": orig.behavior,
|
|
46
|
+
"message": orig.message,
|
|
47
|
+
"policy_id": orig.policy_id,
|
|
48
|
+
"metadata": orig.metadata,
|
|
49
|
+
},
|
|
50
|
+
"override_decision": self.override_decision,
|
|
51
|
+
"override_at": self.override_at,
|
|
52
|
+
"override_by": self.override_by,
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
class DenyOverrideManager:
|
|
57
|
+
"""deny 覆盖管理器,绑定 AgentSessionStore。"""
|
|
58
|
+
|
|
59
|
+
_STORE_KEY = "_deny_overrides"
|
|
60
|
+
|
|
61
|
+
def __init__(self, session_store: AgentSessionStore) -> None:
|
|
62
|
+
self._store = session_store
|
|
63
|
+
if not hasattr(session_store, self._STORE_KEY):
|
|
64
|
+
setattr(session_store, self._STORE_KEY, {})
|
|
65
|
+
|
|
66
|
+
def _records(self) -> dict[str, DenyOverrideRecord]:
|
|
67
|
+
raw = getattr(self._store, self._STORE_KEY)
|
|
68
|
+
return raw if isinstance(raw, dict) else {}
|
|
69
|
+
|
|
70
|
+
def request_override(
|
|
71
|
+
self,
|
|
72
|
+
tool_call_id: str,
|
|
73
|
+
tool_name: str,
|
|
74
|
+
original_decision: AuthorizationDecision,
|
|
75
|
+
*,
|
|
76
|
+
override_by: OverrideActor = "user",
|
|
77
|
+
) -> DenyOverrideRecord:
|
|
78
|
+
"""标记某次 deny 为待覆盖状态,返回记录供 UI 展示。"""
|
|
79
|
+
if not tool_call_id:
|
|
80
|
+
raise ValueError("tool_call_id is required for deny override")
|
|
81
|
+
|
|
82
|
+
record = DenyOverrideRecord(
|
|
83
|
+
tool_call_id=tool_call_id,
|
|
84
|
+
tool_name=tool_name,
|
|
85
|
+
original_decision=original_decision,
|
|
86
|
+
override_decision="pending",
|
|
87
|
+
override_by=override_by,
|
|
88
|
+
)
|
|
89
|
+
self._records()[tool_call_id] = record
|
|
90
|
+
self._store.append_audit(
|
|
91
|
+
{
|
|
92
|
+
"event": "deny_override_requested",
|
|
93
|
+
"ts": time.time(),
|
|
94
|
+
**record.to_dict(),
|
|
95
|
+
}
|
|
96
|
+
)
|
|
97
|
+
return record
|
|
98
|
+
|
|
99
|
+
def get(self, tool_call_id: str) -> DenyOverrideRecord | None:
|
|
100
|
+
return self._records().get(tool_call_id)
|
|
101
|
+
|
|
102
|
+
def apply_override(self, tool_call_id: str, decision: OverrideDecision) -> bool:
|
|
103
|
+
"""应用覆盖决策,更新会话状态。"""
|
|
104
|
+
records = self._records()
|
|
105
|
+
record = records.get(tool_call_id)
|
|
106
|
+
if record is None or record.override_decision != "pending":
|
|
107
|
+
return False
|
|
108
|
+
|
|
109
|
+
record.override_decision = decision
|
|
110
|
+
record.override_at = time.time()
|
|
111
|
+
self._store.append_audit(
|
|
112
|
+
{
|
|
113
|
+
"event": "deny_override_applied",
|
|
114
|
+
"ts": record.override_at,
|
|
115
|
+
"tool_call_id": tool_call_id,
|
|
116
|
+
"override_decision": decision,
|
|
117
|
+
"override_by": record.override_by,
|
|
118
|
+
}
|
|
119
|
+
)
|
|
120
|
+
return True
|
|
121
|
+
|
|
122
|
+
def list_pending(self) -> list[DenyOverrideRecord]:
|
|
123
|
+
return [r for r in self._records().values() if r.override_decision == "pending"]
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
def enrich_blocked_deny_envelope(
|
|
127
|
+
envelope: ToolResultEnvelope,
|
|
128
|
+
*,
|
|
129
|
+
ctx: ToolExecutionContext,
|
|
130
|
+
auth: AuthorizationDecision,
|
|
131
|
+
) -> ToolResultEnvelope:
|
|
132
|
+
"""在 blocked deny envelope 上附加 can_override 并登记待覆盖记录。"""
|
|
133
|
+
tool_call_id = ctx.tool_call_id
|
|
134
|
+
if not tool_call_id or auth.behavior != "deny":
|
|
135
|
+
return envelope
|
|
136
|
+
|
|
137
|
+
meta = dict(envelope.meta or {})
|
|
138
|
+
meta["can_override"] = True
|
|
139
|
+
meta.setdefault("tool_call_id", tool_call_id)
|
|
140
|
+
meta.setdefault("policy_id", auth.policy_id)
|
|
141
|
+
|
|
142
|
+
store = ctx.session_store
|
|
143
|
+
if store is not None:
|
|
144
|
+
mgr = DenyOverrideManager(store)
|
|
145
|
+
record = mgr.request_override(
|
|
146
|
+
tool_call_id,
|
|
147
|
+
ctx.tool_name,
|
|
148
|
+
auth,
|
|
149
|
+
)
|
|
150
|
+
meta["deny_override"] = record.to_dict()
|
|
151
|
+
|
|
152
|
+
envelope.meta = meta
|
|
153
|
+
return envelope
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"""
|
|
2
|
+
tool_runtime/permission_decision.py — 权限决策结构化契约
|
|
3
|
+
|
|
4
|
+
职责:
|
|
5
|
+
对齐 CC PermissionDecisionReason.type,提供稳定的 decision_reason 与
|
|
6
|
+
policy_id 解析辅助,避免调用方依赖字符串前缀嗅探。
|
|
7
|
+
|
|
8
|
+
链路位置:
|
|
9
|
+
PolicyEngine / AutoModeDecision → AuthorizationDecision.metadata
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
from __future__ import annotations
|
|
13
|
+
|
|
14
|
+
from enum import Enum
|
|
15
|
+
from typing import Any
|
|
16
|
+
|
|
17
|
+
from .models import AuthorizationDecision
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
class PermissionDecisionType(str, Enum):
|
|
21
|
+
"""CC PermissionDecisionReason.type 对齐子集。"""
|
|
22
|
+
|
|
23
|
+
RULE = "rule"
|
|
24
|
+
MODE = "mode"
|
|
25
|
+
CLASSIFIER = "classifier"
|
|
26
|
+
HOOK = "hook"
|
|
27
|
+
AUTO_MODE = "auto_mode"
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
# 公开 policy_id 前缀(文档化契约;新代码优先读 metadata["decision_reason"])
|
|
31
|
+
POLICY_ID_PREFIX_AUTO_MODE = "auto_mode:"
|
|
32
|
+
POLICY_ID_PREFIX_ALWAYS_ASK_TOOL = "always_ask_tool:"
|
|
33
|
+
POLICY_ID_PREFIX_DENY_GLOB = "deny_glob:"
|
|
34
|
+
POLICY_ID_PREFIX_ASK_GLOB = "ask_glob:"
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
def normalize_tool_name_set(names: Any) -> frozenset[str]:
|
|
38
|
+
"""工具名集合归一化为小写 frozenset。"""
|
|
39
|
+
if names is None:
|
|
40
|
+
return frozenset()
|
|
41
|
+
if isinstance(names, frozenset):
|
|
42
|
+
return frozenset(n.lower() for n in names if isinstance(n, str) and n.strip())
|
|
43
|
+
return frozenset(str(n).strip().lower() for n in names if str(n).strip())
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
def make_decision_reason(
|
|
47
|
+
reason_type: PermissionDecisionType | str,
|
|
48
|
+
**fields: Any,
|
|
49
|
+
) -> dict[str, Any]:
|
|
50
|
+
"""构造 CC 风格的 decision_reason 字典。"""
|
|
51
|
+
type_value = reason_type.value if isinstance(reason_type, PermissionDecisionType) else reason_type
|
|
52
|
+
out: dict[str, Any] = {"type": type_value}
|
|
53
|
+
for key, value in fields.items():
|
|
54
|
+
if value is not None:
|
|
55
|
+
out[key] = value
|
|
56
|
+
return out
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
def attach_decision_reason(
|
|
60
|
+
decision: AuthorizationDecision,
|
|
61
|
+
reason: dict[str, Any],
|
|
62
|
+
) -> AuthorizationDecision:
|
|
63
|
+
"""将 decision_reason 写入 metadata(就地更新 metadata 引用)。"""
|
|
64
|
+
meta = dict(decision.metadata or {})
|
|
65
|
+
meta["decision_reason"] = reason
|
|
66
|
+
decision.metadata = meta
|
|
67
|
+
return decision
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
def is_auto_mode_policy_id(policy_id: str | None) -> bool:
|
|
71
|
+
"""判断 policy_id 是否来自 Auto Mode(稳定契约,非前缀嗅探首选)。"""
|
|
72
|
+
if not policy_id:
|
|
73
|
+
return False
|
|
74
|
+
return policy_id.startswith(POLICY_ID_PREFIX_AUTO_MODE) or policy_id.startswith("auto_mode_")
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
def decision_type_from_policy_id(policy_id: str | None) -> PermissionDecisionType | None:
|
|
78
|
+
"""从 policy_id 推断 decision_reason.type(向后兼容)。"""
|
|
79
|
+
if not policy_id:
|
|
80
|
+
return None
|
|
81
|
+
if is_auto_mode_policy_id(policy_id):
|
|
82
|
+
return PermissionDecisionType.AUTO_MODE
|
|
83
|
+
if policy_id.startswith(POLICY_ID_PREFIX_ALWAYS_ASK_TOOL):
|
|
84
|
+
return PermissionDecisionType.RULE
|
|
85
|
+
if policy_id.startswith(POLICY_ID_PREFIX_DENY_GLOB) or policy_id.startswith(
|
|
86
|
+
POLICY_ID_PREFIX_ASK_GLOB
|
|
87
|
+
):
|
|
88
|
+
return PermissionDecisionType.RULE
|
|
89
|
+
if policy_id in ("read_only_mode", "builtin_deny", "read_roots", "write_roots"):
|
|
90
|
+
return PermissionDecisionType.RULE
|
|
91
|
+
return None
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
def get_decision_reason(decision: AuthorizationDecision) -> dict[str, Any] | None:
|
|
95
|
+
"""读取 metadata 中的 decision_reason。"""
|
|
96
|
+
if not decision.metadata:
|
|
97
|
+
return None
|
|
98
|
+
reason = decision.metadata.get("decision_reason")
|
|
99
|
+
return reason if isinstance(reason, dict) else None
|