langchain-agentx-python 0.4.9__tar.gz → 0.5.1__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.
Files changed (486) hide show
  1. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/PKG-INFO +1 -1
  2. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/__init__.py +1 -1
  3. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/__init__.py +5 -0
  4. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/adapter.py +40 -1
  5. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/__init__.py +5 -0
  6. langchain-agentx-python-0.5.1/langchain_agentx/tool_runtime/auto_mode/config_update.py +59 -0
  7. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/decision.py +22 -2
  8. langchain-agentx-python-0.5.1/langchain_agentx/tool_runtime/auto_mode/feedback.py +103 -0
  9. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/hook.py +4 -0
  10. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/loader.py +63 -0
  11. langchain-agentx-python-0.5.1/langchain_agentx/tool_runtime/override.py +267 -0
  12. langchain-agentx-python-0.5.1/langchain_agentx/tool_runtime/permission_decision.py +110 -0
  13. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/pipeline.py +25 -15
  14. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/policy.py +65 -14
  15. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/session_store.py +19 -0
  16. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/backend.py +139 -32
  17. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/PKG-INFO +1 -1
  18. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/SOURCES.txt +4 -0
  19. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/requires.txt +1 -0
  20. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/pyproject.toml +2 -1
  21. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/LICENSE +0 -0
  22. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/README.md +0 -0
  23. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/__init__.py +0 -0
  24. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/builtin/__init__.py +0 -0
  25. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/builtin/clear.py +0 -0
  26. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/builtin/compact.py +0 -0
  27. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/builtin/memory.py +0 -0
  28. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/builtin/reload_plugins.py +0 -0
  29. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/context.py +0 -0
  30. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/dispatcher.py +0 -0
  31. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/registry.py +0 -0
  32. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/result.py +0 -0
  33. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/command/types.py +0 -0
  34. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/config/__init__.py +0 -0
  35. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/config/model_profiles.yaml +0 -0
  36. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/config/model_profiles.yaml.example +0 -0
  37. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/__init__.py +0 -0
  38. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/__init__.py +0 -0
  39. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/agent_config.py +0 -0
  40. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/agent_loop_config.py +0 -0
  41. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/model_context_resolver.py +0 -0
  42. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/runtime_settings.py +0 -0
  43. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/config/token_estimator.py +0 -0
  44. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/__init__.py +0 -0
  45. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/blocking_guard.py +0 -0
  46. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/compaction_service.py +0 -0
  47. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/message_utils.py +0 -0
  48. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/pipeline.py +0 -0
  49. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/settings.py +0 -0
  50. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/__init__.py +0 -0
  51. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/autocompact.py +0 -0
  52. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/base.py +0 -0
  53. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/collapse.py +0 -0
  54. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/microcompact.py +0 -0
  55. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/noop.py +0 -0
  56. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/snip.py +0 -0
  57. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/stages/tool_result_budget.py +0 -0
  58. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/context/types.py +0 -0
  59. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/exit/__init__.py +0 -0
  60. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/exit/exit_logic.py +0 -0
  61. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/exit/reason_codes.py +0 -0
  62. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/graph/__init__.py +0 -0
  63. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/graph/builtin_loop_control.py +0 -0
  64. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/graph/factory.py +0 -0
  65. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/graph/graph_edges.py +0 -0
  66. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/__init__.py +0 -0
  67. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/async_hook_runner.py +0 -0
  68. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/config.py +0 -0
  69. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/engine.py +0 -0
  70. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/executors/__init__.py +0 -0
  71. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/executors/agent.py +0 -0
  72. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/executors/command.py +0 -0
  73. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/executors/http.py +0 -0
  74. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/executors/prompt.py +0 -0
  75. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/graph_wiring.py +0 -0
  76. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/registry.py +0 -0
  77. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/trust.py +0 -0
  78. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/hook/types.py +0 -0
  79. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/injection/__init__.py +0 -0
  80. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/injection/dedup.py +0 -0
  81. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/loop_abort.py +0 -0
  82. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/__init__.py +0 -0
  83. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/model_node.py +0 -0
  84. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/model_nodes.py +0 -0
  85. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/orphan_tool_results.py +0 -0
  86. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/retrier.py +0 -0
  87. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/retry_bridge.py +0 -0
  88. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/retry_events.py +0 -0
  89. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/retry_policy.py +0 -0
  90. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/schema_and_format.py +0 -0
  91. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/tool_and_model_binding.py +0 -0
  92. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/tool_call_degradation_corrector.py +0 -0
  93. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/model/tool_transcript_guard.py +0 -0
  94. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/__init__.py +0 -0
  95. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/builder.py +0 -0
  96. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/builtin.py +0 -0
  97. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/compact.py +0 -0
  98. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/sections.py +0 -0
  99. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/prompt/session_context.py +0 -0
  100. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/runtime/__init__.py +0 -0
  101. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/runtime/context.py +0 -0
  102. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/runtime/context_factory.py +0 -0
  103. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/runtime/subagent_execution_paths.py +0 -0
  104. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/__init__.py +0 -0
  105. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/async_runner.py +0 -0
  106. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/context.py +0 -0
  107. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/fork_worktree_notice.py +0 -0
  108. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/graph.py +0 -0
  109. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/orchestrator.py +0 -0
  110. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/progress.py +0 -0
  111. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/prompt.py +0 -0
  112. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/runner.py +0 -0
  113. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/loop/subagent/transcript.py +0 -0
  114. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/__init__.py +0 -0
  115. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/__init__.py +0 -0
  116. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/loader.py +0 -0
  117. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/resolver.py +0 -0
  118. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/runtime.py +0 -0
  119. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/sections.py +0 -0
  120. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/instruction/types.py +0 -0
  121. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/__init__.py +0 -0
  122. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/age.py +0 -0
  123. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/agent_memory.py +0 -0
  124. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/extractor.py +0 -0
  125. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/loader.py +0 -0
  126. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/paths.py +0 -0
  127. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/recall.py +0 -0
  128. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/runtime.py +0 -0
  129. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/scan.py +0 -0
  130. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/memdir/types.py +0 -0
  131. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/session/__init__.py +0 -0
  132. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/session/compact_bridge.py +0 -0
  133. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/session/prompts.py +0 -0
  134. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/memory/session/session_memory.py +0 -0
  135. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/__init__.py +0 -0
  136. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/__init__.py +0 -0
  137. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/__init__.py +0 -0
  138. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/base.py +0 -0
  139. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/compaction.py +0 -0
  140. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/degradation.py +0 -0
  141. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/exit_quality.py +0 -0
  142. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/session_memory.py +0 -0
  143. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/checkers/tool_behavior.py +0 -0
  144. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/retention_scheduler.py +0 -0
  145. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/service.py +0 -0
  146. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/state.py +0 -0
  147. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/evaluation/store.py +0 -0
  148. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/events/__init__.py +0 -0
  149. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/events/langchain_agentx_event_adapter.py +0 -0
  150. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/logging/__init__.py +0 -0
  151. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/logging/debug_burst.py +0 -0
  152. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/logging/logging_config.py +0 -0
  153. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/logging/logging_contract.py +0 -0
  154. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/replay/__init__.py +0 -0
  155. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/replay/cli.py +0 -0
  156. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/replay/service.py +0 -0
  157. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/replay/store.py +0 -0
  158. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/replay/ui.py +0 -0
  159. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/__init__.py +0 -0
  160. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/collector.py +0 -0
  161. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/event_emitter.py +0 -0
  162. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/hook_event_emitter.py +0 -0
  163. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/models.py +0 -0
  164. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/sqlite_store.py +0 -0
  165. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/trace_callback.py +0 -0
  166. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/observability/trace/trace_lifecycle_collector.py +0 -0
  167. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/__init__.py +0 -0
  168. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/builtin.py +0 -0
  169. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/config.py +0 -0
  170. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/loader.py +0 -0
  171. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/manifest.py +0 -0
  172. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/registries.py +0 -0
  173. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/plugin/types.py +0 -0
  174. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/__init__.py +0 -0
  175. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/anthropic.py +0 -0
  176. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/compatible_chat_openai.py +0 -0
  177. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/env.py +0 -0
  178. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/model_profile.py +0 -0
  179. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/provider/openai.py +0 -0
  180. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/__init__.py +0 -0
  181. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/agent_session.py +0 -0
  182. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/conversation_factory.py +0 -0
  183. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/conversation_recovery.py +0 -0
  184. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/conversation_session.py +0 -0
  185. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/factory.py +0 -0
  186. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/session/protocol.py +0 -0
  187. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/__init__.py +0 -0
  188. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/core/__init__.py +0 -0
  189. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/core/ids.py +0 -0
  190. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/core/interfaces.py +0 -0
  191. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/core/notification_priority.py +0 -0
  192. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/core/types.py +0 -0
  193. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/__init__.py +0 -0
  194. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/loop_adapter.py +0 -0
  195. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/loop_integration.py +0 -0
  196. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/prefetch_providers.py +0 -0
  197. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/provider_factory.py +0 -0
  198. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/queued_command_provider.py +0 -0
  199. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/sqlite_queued_command_provider.py +0 -0
  200. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/integrations/tool_use_summary_provider.py +0 -0
  201. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/orchestrator/__init__.py +0 -0
  202. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/orchestrator/runtime.py +0 -0
  203. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/output/__init__.py +0 -0
  204. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/output/sink.py +0 -0
  205. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/policy/__init__.py +0 -0
  206. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/policy/withhold_visibility.py +0 -0
  207. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/queue/__init__.py +0 -0
  208. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/queue/in_memory.py +0 -0
  209. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/skill_prefetch/__init__.py +0 -0
  210. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/skill_prefetch/attachments.py +0 -0
  211. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/skill_prefetch/models.py +0 -0
  212. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/skill_prefetch/provider.py +0 -0
  213. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/store/__init__.py +0 -0
  214. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/store/in_memory.py +0 -0
  215. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/store/sqlite_store.py +0 -0
  216. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/__init__.py +0 -0
  217. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/high_water_mark.py +0 -0
  218. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/lock.py +0 -0
  219. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/models.py +0 -0
  220. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/path_resolver.py +0 -0
  221. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasklist/store.py +0 -0
  222. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/__init__.py +0 -0
  223. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/ai_analysis/__init__.py +0 -0
  224. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/ai_analysis/base.py +0 -0
  225. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/ai_analysis/evaluation.py +0 -0
  226. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/ai_analysis/registry.py +0 -0
  227. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/ai_analysis/scheduler.py +0 -0
  228. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/base/__init__.py +0 -0
  229. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/base/contracts.py +0 -0
  230. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/custom/__init__.py +0 -0
  231. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/custom/executor.py +0 -0
  232. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/custom/notification.py +0 -0
  233. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/custom/semantics.py +0 -0
  234. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/custom/spec.py +0 -0
  235. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/__init__.py +0 -0
  236. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/executor.py +0 -0
  237. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/notification.py +0 -0
  238. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/semantics.py +0 -0
  239. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/spec.py +0 -0
  240. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/dream_task/state.py +0 -0
  241. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/in_process_teammate/__init__.py +0 -0
  242. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/in_process_teammate/executor.py +0 -0
  243. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/in_process_teammate/notification.py +0 -0
  244. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/in_process_teammate/semantics.py +0 -0
  245. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/in_process_teammate/spec.py +0 -0
  246. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/__init__.py +0 -0
  247. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/executor.py +0 -0
  248. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/notification.py +0 -0
  249. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/runner.py +0 -0
  250. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/semantics.py +0 -0
  251. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_agent/spec.py +0 -0
  252. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_bash/__init__.py +0 -0
  253. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_bash/executor.py +0 -0
  254. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_bash/notification.py +0 -0
  255. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_bash/semantics.py +0 -0
  256. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/local_bash/spec.py +0 -0
  257. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/__init__.py +0 -0
  258. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/backend.py +0 -0
  259. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/executor.py +0 -0
  260. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/notification.py +0 -0
  261. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/semantics.py +0 -0
  262. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/remote_agent/spec.py +0 -0
  263. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/trace_cleanup/__init__.py +0 -0
  264. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/trace_cleanup/bootstrap.py +0 -0
  265. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/trace_cleanup/executor.py +0 -0
  266. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/task_runtime/tasks/trace_cleanup/scheduler.py +0 -0
  267. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/allowlist.py +0 -0
  268. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/__init__.py +0 -0
  269. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/classifier.py +0 -0
  270. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/parser.py +0 -0
  271. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/prompt.py +0 -0
  272. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/schema.py +0 -0
  273. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/classifier/transcript.py +0 -0
  274. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/config.py +0 -0
  275. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/events.py +0 -0
  276. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/factory.py +0 -0
  277. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/rule_stripping.py +0 -0
  278. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/auto_mode/state.py +0 -0
  279. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/base.py +0 -0
  280. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/errors.py +0 -0
  281. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/identical_call_cache.py +0 -0
  282. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/models.py +0 -0
  283. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/permission_context.py +0 -0
  284. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/policy_decorator.py +0 -0
  285. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/__init__.py +0 -0
  286. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/_abort.py +0 -0
  287. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/cli_interactive.py +0 -0
  288. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/handler.py +0 -0
  289. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/headless.py +0 -0
  290. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/legacy_resolver_adapter.py +0 -0
  291. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/race.py +0 -0
  292. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/prompt/types.py +0 -0
  293. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/registry.py +0 -0
  294. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/__init__.py +0 -0
  295. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/agent_session.py +0 -0
  296. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/background.py +0 -0
  297. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/base.py +0 -0
  298. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/conversation.py +0 -0
  299. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/resolvers/workflow.py +0 -0
  300. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/smoke_test_runtime.py +0 -0
  301. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tool_runtime/state_bridge.py +0 -0
  302. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/__init__.py +0 -0
  303. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/__init__.py +0 -0
  304. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/backend.py +0 -0
  305. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/__init__.py +0 -0
  306. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/agentx_guide.py +0 -0
  307. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/explore.py +0 -0
  308. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/general.py +0 -0
  309. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/plan.py +0 -0
  310. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/statusline_setup.py +0 -0
  311. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/built_in/verification.py +0 -0
  312. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/builtin_subagent_loader.py +0 -0
  313. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/cwd_resolution.py +0 -0
  314. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/limits.py +0 -0
  315. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/loader.py +0 -0
  316. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/models.py +0 -0
  317. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/prompt.py +0 -0
  318. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/registry/__init__.py +0 -0
  319. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/registry/config.py +0 -0
  320. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/registry/registry.py +0 -0
  321. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/scope.py +0 -0
  322. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/agent/tool.py +0 -0
  323. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/__init__.py +0 -0
  324. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/constants.py +0 -0
  325. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/html_preview.py +0 -0
  326. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/models.py +0 -0
  327. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/prompt.py +0 -0
  328. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/tool.py +0 -0
  329. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ask_user_question/validators.py +0 -0
  330. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/__init__.py +0 -0
  331. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/ast_security.py +0 -0
  332. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/auto_mode_adapter.py +0 -0
  333. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/backend.py +0 -0
  334. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/bash_hardening.py +0 -0
  335. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/bash_runtime_contract.py +0 -0
  336. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/cwd_reporter.py +0 -0
  337. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/events.py +0 -0
  338. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/limits.py +0 -0
  339. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/mode_validation.py +0 -0
  340. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/models.py +0 -0
  341. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/observability.py +0 -0
  342. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/output_utils.py +0 -0
  343. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/path_security.py +0 -0
  344. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/prompt.py +0 -0
  345. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/read_only_validation.py +0 -0
  346. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/result_presenter.py +0 -0
  347. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/sandbox_decision.py +0 -0
  348. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/security.py +0 -0
  349. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/sed_edit_parser.py +0 -0
  350. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/sed_validation.py +0 -0
  351. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/semantics.py +0 -0
  352. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/session_manager.py +0 -0
  353. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/session_runtime.py +0 -0
  354. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/shell_locator.py +0 -0
  355. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/task_runtime.py +0 -0
  356. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/tool.py +0 -0
  357. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/bash/windows_shell_quoting.py +0 -0
  358. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/__init__.py +0 -0
  359. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/backend.py +0 -0
  360. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/diff_generator.py +0 -0
  361. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/git_diff_generator.py +0 -0
  362. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/limits.py +0 -0
  363. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/models.py +0 -0
  364. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/prompt.py +0 -0
  365. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/quote_match.py +0 -0
  366. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/quote_normalizer.py +0 -0
  367. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/settings_validator.py +0 -0
  368. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/staleness.py +0 -0
  369. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/tool.py +0 -0
  370. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/edit/validator.py +0 -0
  371. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/__init__.py +0 -0
  372. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/models.py +0 -0
  373. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/pagination.py +0 -0
  374. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/prompt.py +0 -0
  375. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/rg_list_backend.py +0 -0
  376. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/rg_pattern.py +0 -0
  377. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/glob/tool.py +0 -0
  378. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/__init__.py +0 -0
  379. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/backend.py +0 -0
  380. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/models.py +0 -0
  381. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/prompt.py +0 -0
  382. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/rg_subprocess_controller.py +0 -0
  383. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/grep/tool.py +0 -0
  384. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/__init__.py +0 -0
  385. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/backend.py +0 -0
  386. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/limits.py +0 -0
  387. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/models.py +0 -0
  388. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/prompt.py +0 -0
  389. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/read/tool.py +0 -0
  390. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/ripgrep_plugin_exclusions.py +0 -0
  391. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/__init__.py +0 -0
  392. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/argument_substitution.py +0 -0
  393. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/loader.py +0 -0
  394. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/models.py +0 -0
  395. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/policy.py +0 -0
  396. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/prompt.py +0 -0
  397. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/skill/tool.py +0 -0
  398. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/__init__.py +0 -0
  399. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/hooks.py +0 -0
  400. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/limits.py +0 -0
  401. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/models.py +0 -0
  402. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/prompt.py +0 -0
  403. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_create/tool.py +0 -0
  404. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_get/__init__.py +0 -0
  405. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_get/models.py +0 -0
  406. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_get/prompt.py +0 -0
  407. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_get/tool.py +0 -0
  408. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_list/__init__.py +0 -0
  409. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_list/models.py +0 -0
  410. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_list/prompt.py +0 -0
  411. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_list/tool.py +0 -0
  412. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_update/__init__.py +0 -0
  413. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_update/hooks.py +0 -0
  414. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_update/models.py +0 -0
  415. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_update/prompt.py +0 -0
  416. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/task_update/tool.py +0 -0
  417. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/__init__.py +0 -0
  418. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/attachments.py +0 -0
  419. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/models.py +0 -0
  420. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/prompt.py +0 -0
  421. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/runtime_config.py +0 -0
  422. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/user_message/tool.py +0 -0
  423. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/__init__.py +0 -0
  424. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/limits.py +0 -0
  425. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/loader.py +0 -0
  426. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/models.py +0 -0
  427. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/preapproved.py +0 -0
  428. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/prompt.py +0 -0
  429. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/summary.py +0 -0
  430. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/webfetch/tool.py +0 -0
  431. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/__init__.py +0 -0
  432. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/backend.py +0 -0
  433. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/events.py +0 -0
  434. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/limits.py +0 -0
  435. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/loader.py +0 -0
  436. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/models.py +0 -0
  437. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/prompt.py +0 -0
  438. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/websearch/tool.py +0 -0
  439. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/__init__.py +0 -0
  440. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/backend.py +0 -0
  441. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/limits.py +0 -0
  442. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/models.py +0 -0
  443. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/prompt.py +0 -0
  444. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/tool.py +0 -0
  445. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/tools/write/validator.py +0 -0
  446. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/__init__.py +0 -0
  447. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/cwd.py +0 -0
  448. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/host_platform.py +0 -0
  449. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/path_hierarchy.py +0 -0
  450. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/path_user_input.py +0 -0
  451. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/rg_executable.py +0 -0
  452. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/subprocess_text.py +0 -0
  453. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/temp_paths.py +0 -0
  454. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/unc_path.py +0 -0
  455. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/utils/win_reserved_paths.py +0 -0
  456. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/__init__.py +0 -0
  457. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/base.py +0 -0
  458. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/batch.py +0 -0
  459. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/dag.py +0 -0
  460. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/__init__.py +0 -0
  461. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/adapter.py +0 -0
  462. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/depth_resolver.py +0 -0
  463. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/handlers/__init__.py +0 -0
  464. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/handlers/parallel_handler.py +0 -0
  465. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/handlers/route_handler.py +0 -0
  466. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/handlers/stage_handler.py +0 -0
  467. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/stack.py +0 -0
  468. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/event_adapter/types.py +0 -0
  469. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/node.py +0 -0
  470. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/__init__.py +0 -0
  471. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/chaining.py +0 -0
  472. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/evaluator_optimizer.py +0 -0
  473. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/orchestrator.py +0 -0
  474. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/parallelization.py +0 -0
  475. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/patterns/routing.py +0 -0
  476. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workflow/state.py +0 -0
  477. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/__init__.py +0 -0
  478. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/capabilities.py +0 -0
  479. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/config.py +0 -0
  480. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/path_key_normalizer.py +0 -0
  481. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/resolver.py +0 -0
  482. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx/workspace/validators.py +0 -0
  483. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/dependency_links.txt +0 -0
  484. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/not-zip-safe +0 -0
  485. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/langchain_agentx_python.egg-info/top_level.txt +0 -0
  486. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.1}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: langchain-agentx-python
3
- Version: 0.4.9
3
+ Version: 0.5.1
4
4
  Summary: LangChain/LangGraph-based agent utilities for CodeBaseX.
5
5
  Author-email: GoodMood2008 <GoodMood2008@users.noreply.github.com>
6
6
  License: Apache License
@@ -11,7 +11,7 @@ from langchain_agentx import create_loop_agent
11
11
  ```
12
12
  """
13
13
 
14
- __version__ = "0.4.9"
14
+ __version__ = "0.5.1"
15
15
 
16
16
  from .loop import ( # noqa: F401
17
17
  create_loop_agent,
@@ -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=getattr(tool_runtime, "tool_call_id", None),
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
- return AuthorizationDecision(
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"auto_mode_{self.layer}_{self.reason.value}",
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,267 @@
1
+ """
2
+ tool_runtime/override.py — deny 决策覆盖(L4 UX seam)
3
+
4
+ 职责:
5
+ 记录 policy deny 的 tool_call,供 UI/CLI 展示覆盖横幅;
6
+ apply_override 更新会话态;grant_replay / consume_replay 支持新 id 一次性放行。
7
+
8
+ 链路位置:
9
+ pipeline Step 4 → consume_replay → allow 短路
10
+ pipeline deny → enrich_blocked_deny_envelope → request_override
11
+
12
+ CC 对照:
13
+ 不复用同一 toolUseID 重放(避免 transcript 双 ToolMessage 同 id);
14
+ 宿主废掉原 deny 行后以新 tool 调用派发,与本仓 new-id replay grant 一致。
15
+ """
16
+
17
+ from __future__ import annotations
18
+
19
+ import logging
20
+ import time
21
+ from dataclasses import dataclass, field
22
+ from typing import TYPE_CHECKING, Any, Literal
23
+
24
+ from .models import AuthorizationDecision, ToolExecutionContext, ToolResultEnvelope
25
+ from .permission_decision import (
26
+ POLICY_ID_DENY_OVERRIDE_CONSUMED,
27
+ PermissionDecisionType,
28
+ attach_decision_reason,
29
+ make_decision_reason,
30
+ )
31
+
32
+ if TYPE_CHECKING:
33
+ from .base import RuntimeTool
34
+ from .session_store import AgentSessionStore
35
+
36
+ logger = logging.getLogger(__name__)
37
+
38
+ OverrideDecision = Literal["allow", "confirm_deny"]
39
+ OverrideActor = Literal["user", "admin"]
40
+ RecordStatus = Literal["pending", "allow", "confirm_deny"]
41
+
42
+
43
+ @dataclass
44
+ class DenyOverrideRecord:
45
+ """单次 deny 的覆盖记录。"""
46
+
47
+ tool_call_id: str
48
+ tool_name: str
49
+ original_decision: AuthorizationDecision
50
+ original_input: dict[str, Any] = field(default_factory=dict)
51
+ override_decision: RecordStatus = "pending"
52
+ override_at: float | None = None
53
+ override_by: OverrideActor | None = None
54
+
55
+ def to_dict(self) -> dict[str, Any]:
56
+ orig = self.original_decision
57
+ return {
58
+ "tool_call_id": self.tool_call_id,
59
+ "tool_name": self.tool_name,
60
+ "original_decision": {
61
+ "behavior": orig.behavior,
62
+ "message": orig.message,
63
+ "policy_id": orig.policy_id,
64
+ "metadata": orig.metadata,
65
+ },
66
+ "original_input": dict(self.original_input),
67
+ "override_decision": self.override_decision,
68
+ "override_at": self.override_at,
69
+ "override_by": self.override_by,
70
+ }
71
+
72
+
73
+ class DenyOverrideManager:
74
+ """deny 覆盖管理器,绑定 AgentSessionStore。"""
75
+
76
+ _STORE_KEY = "_deny_overrides"
77
+ _GRANTS_KEY = "_deny_override_replay_grants"
78
+
79
+ def __init__(self, session_store: AgentSessionStore) -> None:
80
+ self._store = session_store
81
+ if not hasattr(session_store, self._STORE_KEY):
82
+ setattr(session_store, self._STORE_KEY, {})
83
+ if not hasattr(session_store, self._GRANTS_KEY):
84
+ setattr(session_store, self._GRANTS_KEY, {})
85
+
86
+ def _records(self) -> dict[str, DenyOverrideRecord]:
87
+ raw = getattr(self._store, self._STORE_KEY)
88
+ return raw if isinstance(raw, dict) else {}
89
+
90
+ def _grants(self) -> dict[str, str]:
91
+ raw = getattr(self._store, self._GRANTS_KEY)
92
+ return raw if isinstance(raw, dict) else {}
93
+
94
+ def request_override(
95
+ self,
96
+ tool_call_id: str,
97
+ tool_name: str,
98
+ original_decision: AuthorizationDecision,
99
+ *,
100
+ override_by: OverrideActor = "user",
101
+ original_input: dict[str, Any] | None = None,
102
+ ) -> DenyOverrideRecord:
103
+ """标记某次 deny 为待覆盖状态,返回记录供 UI 展示。"""
104
+ if not tool_call_id:
105
+ raise ValueError("tool_call_id is required for deny override")
106
+
107
+ record = DenyOverrideRecord(
108
+ tool_call_id=tool_call_id,
109
+ tool_name=tool_name,
110
+ original_decision=original_decision,
111
+ original_input=dict(original_input or {}),
112
+ override_decision="pending",
113
+ override_by=override_by,
114
+ )
115
+ self._records()[tool_call_id] = record
116
+ self._store.append_audit(
117
+ {
118
+ "event": "deny_override_requested",
119
+ "ts": time.time(),
120
+ **record.to_dict(),
121
+ }
122
+ )
123
+ return record
124
+
125
+ def get(self, tool_call_id: str) -> DenyOverrideRecord | None:
126
+ return self._records().get(tool_call_id)
127
+
128
+ def apply_override(self, tool_call_id: str, decision: OverrideDecision) -> bool:
129
+ """应用覆盖决策,更新会话状态。"""
130
+ records = self._records()
131
+ record = records.get(tool_call_id)
132
+ if record is None or record.override_decision != "pending":
133
+ return False
134
+
135
+ record.override_decision = decision
136
+ record.override_at = time.time()
137
+ self._store.append_audit(
138
+ {
139
+ "event": "deny_override_applied",
140
+ "ts": record.override_at,
141
+ "tool_call_id": tool_call_id,
142
+ "override_decision": decision,
143
+ "override_by": record.override_by,
144
+ }
145
+ )
146
+ return True
147
+
148
+ def grant_replay(self, original_tool_call_id: str, replay_tool_call_id: str) -> bool:
149
+ """在 apply_override(original, \"allow\") 之后颁发一次性 replay grant。"""
150
+ record = self._records().get(original_tool_call_id)
151
+ if record is None or record.override_decision != "allow":
152
+ return False
153
+ self._grants()[replay_tool_call_id] = original_tool_call_id
154
+ self._store.append_audit(
155
+ {
156
+ "event": "deny_override_replay_granted",
157
+ "ts": time.time(),
158
+ "original_tool_call_id": original_tool_call_id,
159
+ "replay_tool_call_id": replay_tool_call_id,
160
+ }
161
+ )
162
+ return True
163
+
164
+ def consume_replay(self, tool_call_id: str) -> str | None:
165
+ """Pipeline 调用:命中 replay grant 时弹出并返回原 tool_call_id。"""
166
+ original = self._grants().pop(tool_call_id, None)
167
+ if original is not None:
168
+ self._store.append_audit(
169
+ {
170
+ "event": "deny_override_replay_consumed",
171
+ "ts": time.time(),
172
+ "original_tool_call_id": original,
173
+ "replay_tool_call_id": tool_call_id,
174
+ }
175
+ )
176
+ return original
177
+
178
+ def list_pending(self) -> list[DenyOverrideRecord]:
179
+ return [r for r in self._records().values() if r.override_decision == "pending"]
180
+
181
+
182
+ def authorization_from_replay_grant(ctx: ToolExecutionContext) -> AuthorizationDecision | None:
183
+ """Step 4 前消费 replay grant;命中则返回 allow,否则 None。"""
184
+ if ctx.session_store is None or not ctx.tool_call_id:
185
+ return None
186
+ replay_origin = ctx.session_store.deny_overrides.consume_replay(ctx.tool_call_id)
187
+ if replay_origin is None:
188
+ return None
189
+ logger.info(
190
+ "tool deny override consumed tool=%s replay=%s origin=%s",
191
+ ctx.tool_name,
192
+ ctx.tool_call_id,
193
+ replay_origin,
194
+ )
195
+ return attach_decision_reason(
196
+ AuthorizationDecision(
197
+ behavior="allow",
198
+ policy_id=POLICY_ID_DENY_OVERRIDE_CONSUMED,
199
+ ),
200
+ make_decision_reason(
201
+ PermissionDecisionType.OVERRIDE,
202
+ replayed_from=replay_origin,
203
+ ),
204
+ )
205
+
206
+
207
+ def resolve_step4_authorization(
208
+ tool: RuntimeTool,
209
+ parsed_data: dict[str, Any],
210
+ ctx: ToolExecutionContext,
211
+ ) -> AuthorizationDecision:
212
+ """同步 Step 4:replay grant 优先,否则 tool.check_permissions。"""
213
+ granted = authorization_from_replay_grant(ctx)
214
+ if granted is not None:
215
+ return granted
216
+ return tool.check_permissions(parsed_data, ctx)
217
+
218
+
219
+ async def resolve_step4_aauthorization(
220
+ tool: RuntimeTool,
221
+ parsed_data: dict[str, Any],
222
+ ctx: ToolExecutionContext,
223
+ ) -> AuthorizationDecision:
224
+ """异步 Step 4:replay grant 优先,否则 aauthorize / check_permissions。"""
225
+ granted = authorization_from_replay_grant(ctx)
226
+ if granted is not None:
227
+ return granted
228
+ policy = getattr(tool, "_policy", None)
229
+ if policy is not None and hasattr(policy, "aauthorize"):
230
+ return await policy.aauthorize(
231
+ tool_name=tool.name,
232
+ input_data=parsed_data,
233
+ ctx=ctx,
234
+ )
235
+ return tool.check_permissions(parsed_data, ctx)
236
+
237
+
238
+ def enrich_blocked_deny_envelope(
239
+ envelope: ToolResultEnvelope,
240
+ *,
241
+ ctx: ToolExecutionContext,
242
+ auth: AuthorizationDecision,
243
+ input_data: dict[str, Any] | None = None,
244
+ ) -> ToolResultEnvelope:
245
+ """在 blocked deny envelope 上附加 can_override 并登记待覆盖记录。"""
246
+ tool_call_id = ctx.tool_call_id
247
+ if not tool_call_id or auth.behavior != "deny":
248
+ return envelope
249
+
250
+ meta = dict(envelope.meta or {})
251
+ meta["can_override"] = True
252
+ meta.setdefault("tool_call_id", tool_call_id)
253
+ meta.setdefault("policy_id", auth.policy_id)
254
+
255
+ store = ctx.session_store
256
+ if store is not None:
257
+ mgr = DenyOverrideManager(store)
258
+ record = mgr.request_override(
259
+ tool_call_id,
260
+ ctx.tool_name,
261
+ auth,
262
+ original_input=input_data or {},
263
+ )
264
+ meta["deny_override"] = record.to_dict()
265
+
266
+ envelope.meta = meta
267
+ return envelope