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.
Files changed (486) hide show
  1. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/PKG-INFO +1 -1
  2. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/__init__.py +1 -1
  3. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/__init__.py +5 -0
  4. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/adapter.py +40 -1
  5. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/__init__.py +5 -0
  6. langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/auto_mode/config_update.py +59 -0
  7. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/decision.py +22 -2
  8. langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/auto_mode/feedback.py +103 -0
  9. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/hook.py +4 -0
  10. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/loader.py +63 -0
  11. langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/override.py +153 -0
  12. langchain-agentx-python-0.5.0/langchain_agentx/tool_runtime/permission_decision.py +99 -0
  13. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/pipeline.py +17 -8
  14. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/policy.py +65 -14
  15. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/session_store.py +19 -0
  16. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/backend.py +139 -32
  17. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/PKG-INFO +1 -1
  18. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/SOURCES.txt +4 -0
  19. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/requires.txt +1 -0
  20. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/pyproject.toml +2 -1
  21. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/LICENSE +0 -0
  22. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/README.md +0 -0
  23. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/__init__.py +0 -0
  24. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/__init__.py +0 -0
  25. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/clear.py +0 -0
  26. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/compact.py +0 -0
  27. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/memory.py +0 -0
  28. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/builtin/reload_plugins.py +0 -0
  29. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/context.py +0 -0
  30. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/dispatcher.py +0 -0
  31. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/registry.py +0 -0
  32. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/result.py +0 -0
  33. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/command/types.py +0 -0
  34. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/__init__.py +0 -0
  35. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/model_profiles.yaml +0 -0
  36. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/config/model_profiles.yaml.example +0 -0
  37. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/__init__.py +0 -0
  38. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/__init__.py +0 -0
  39. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/agent_config.py +0 -0
  40. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/agent_loop_config.py +0 -0
  41. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/model_context_resolver.py +0 -0
  42. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/runtime_settings.py +0 -0
  43. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/config/token_estimator.py +0 -0
  44. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/__init__.py +0 -0
  45. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/blocking_guard.py +0 -0
  46. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/compaction_service.py +0 -0
  47. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/message_utils.py +0 -0
  48. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/pipeline.py +0 -0
  49. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/settings.py +0 -0
  50. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/__init__.py +0 -0
  51. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/autocompact.py +0 -0
  52. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/base.py +0 -0
  53. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/collapse.py +0 -0
  54. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/microcompact.py +0 -0
  55. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/noop.py +0 -0
  56. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/snip.py +0 -0
  57. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/stages/tool_result_budget.py +0 -0
  58. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/context/types.py +0 -0
  59. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/__init__.py +0 -0
  60. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/exit_logic.py +0 -0
  61. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/exit/reason_codes.py +0 -0
  62. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/__init__.py +0 -0
  63. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/builtin_loop_control.py +0 -0
  64. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/factory.py +0 -0
  65. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/graph/graph_edges.py +0 -0
  66. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/__init__.py +0 -0
  67. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/async_hook_runner.py +0 -0
  68. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/config.py +0 -0
  69. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/engine.py +0 -0
  70. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/__init__.py +0 -0
  71. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/agent.py +0 -0
  72. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/command.py +0 -0
  73. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/http.py +0 -0
  74. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/executors/prompt.py +0 -0
  75. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/graph_wiring.py +0 -0
  76. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/registry.py +0 -0
  77. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/trust.py +0 -0
  78. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/hook/types.py +0 -0
  79. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/injection/__init__.py +0 -0
  80. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/injection/dedup.py +0 -0
  81. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/loop_abort.py +0 -0
  82. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/__init__.py +0 -0
  83. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/model_node.py +0 -0
  84. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/model_nodes.py +0 -0
  85. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/orphan_tool_results.py +0 -0
  86. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retrier.py +0 -0
  87. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_bridge.py +0 -0
  88. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_events.py +0 -0
  89. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/retry_policy.py +0 -0
  90. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/schema_and_format.py +0 -0
  91. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_and_model_binding.py +0 -0
  92. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_call_degradation_corrector.py +0 -0
  93. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/model/tool_transcript_guard.py +0 -0
  94. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/__init__.py +0 -0
  95. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/builder.py +0 -0
  96. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/builtin.py +0 -0
  97. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/compact.py +0 -0
  98. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/sections.py +0 -0
  99. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/prompt/session_context.py +0 -0
  100. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/__init__.py +0 -0
  101. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/context.py +0 -0
  102. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/context_factory.py +0 -0
  103. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/runtime/subagent_execution_paths.py +0 -0
  104. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/__init__.py +0 -0
  105. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/async_runner.py +0 -0
  106. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/context.py +0 -0
  107. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/fork_worktree_notice.py +0 -0
  108. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/graph.py +0 -0
  109. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/orchestrator.py +0 -0
  110. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/progress.py +0 -0
  111. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/prompt.py +0 -0
  112. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/runner.py +0 -0
  113. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/loop/subagent/transcript.py +0 -0
  114. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/__init__.py +0 -0
  115. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/__init__.py +0 -0
  116. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/loader.py +0 -0
  117. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/resolver.py +0 -0
  118. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/runtime.py +0 -0
  119. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/sections.py +0 -0
  120. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/instruction/types.py +0 -0
  121. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/__init__.py +0 -0
  122. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/age.py +0 -0
  123. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/agent_memory.py +0 -0
  124. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/extractor.py +0 -0
  125. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/loader.py +0 -0
  126. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/paths.py +0 -0
  127. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/recall.py +0 -0
  128. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/runtime.py +0 -0
  129. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/scan.py +0 -0
  130. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/memdir/types.py +0 -0
  131. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/__init__.py +0 -0
  132. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/compact_bridge.py +0 -0
  133. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/prompts.py +0 -0
  134. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/memory/session/session_memory.py +0 -0
  135. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/__init__.py +0 -0
  136. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/__init__.py +0 -0
  137. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/__init__.py +0 -0
  138. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/base.py +0 -0
  139. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/compaction.py +0 -0
  140. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/degradation.py +0 -0
  141. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/exit_quality.py +0 -0
  142. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/session_memory.py +0 -0
  143. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/checkers/tool_behavior.py +0 -0
  144. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/retention_scheduler.py +0 -0
  145. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/service.py +0 -0
  146. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/state.py +0 -0
  147. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/evaluation/store.py +0 -0
  148. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/events/__init__.py +0 -0
  149. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/events/langchain_agentx_event_adapter.py +0 -0
  150. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/__init__.py +0 -0
  151. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/debug_burst.py +0 -0
  152. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/logging_config.py +0 -0
  153. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/logging/logging_contract.py +0 -0
  154. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/__init__.py +0 -0
  155. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/cli.py +0 -0
  156. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/service.py +0 -0
  157. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/store.py +0 -0
  158. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/replay/ui.py +0 -0
  159. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/__init__.py +0 -0
  160. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/collector.py +0 -0
  161. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/event_emitter.py +0 -0
  162. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/hook_event_emitter.py +0 -0
  163. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/models.py +0 -0
  164. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/sqlite_store.py +0 -0
  165. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/trace_callback.py +0 -0
  166. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/observability/trace/trace_lifecycle_collector.py +0 -0
  167. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/__init__.py +0 -0
  168. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/builtin.py +0 -0
  169. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/config.py +0 -0
  170. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/loader.py +0 -0
  171. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/manifest.py +0 -0
  172. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/registries.py +0 -0
  173. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/plugin/types.py +0 -0
  174. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/__init__.py +0 -0
  175. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/anthropic.py +0 -0
  176. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/compatible_chat_openai.py +0 -0
  177. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/env.py +0 -0
  178. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/model_profile.py +0 -0
  179. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/provider/openai.py +0 -0
  180. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/__init__.py +0 -0
  181. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/agent_session.py +0 -0
  182. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_factory.py +0 -0
  183. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_recovery.py +0 -0
  184. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/conversation_session.py +0 -0
  185. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/factory.py +0 -0
  186. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/session/protocol.py +0 -0
  187. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/__init__.py +0 -0
  188. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/__init__.py +0 -0
  189. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/ids.py +0 -0
  190. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/interfaces.py +0 -0
  191. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/notification_priority.py +0 -0
  192. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/core/types.py +0 -0
  193. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/__init__.py +0 -0
  194. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/loop_adapter.py +0 -0
  195. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/loop_integration.py +0 -0
  196. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/prefetch_providers.py +0 -0
  197. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/provider_factory.py +0 -0
  198. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/queued_command_provider.py +0 -0
  199. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/sqlite_queued_command_provider.py +0 -0
  200. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/integrations/tool_use_summary_provider.py +0 -0
  201. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/orchestrator/__init__.py +0 -0
  202. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/orchestrator/runtime.py +0 -0
  203. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/output/__init__.py +0 -0
  204. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/output/sink.py +0 -0
  205. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/policy/__init__.py +0 -0
  206. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/policy/withhold_visibility.py +0 -0
  207. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/queue/__init__.py +0 -0
  208. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/queue/in_memory.py +0 -0
  209. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/__init__.py +0 -0
  210. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/attachments.py +0 -0
  211. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/models.py +0 -0
  212. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/skill_prefetch/provider.py +0 -0
  213. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/__init__.py +0 -0
  214. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/in_memory.py +0 -0
  215. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/store/sqlite_store.py +0 -0
  216. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/__init__.py +0 -0
  217. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/high_water_mark.py +0 -0
  218. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/lock.py +0 -0
  219. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/models.py +0 -0
  220. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/path_resolver.py +0 -0
  221. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasklist/store.py +0 -0
  222. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/__init__.py +0 -0
  223. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/__init__.py +0 -0
  224. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/base.py +0 -0
  225. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/evaluation.py +0 -0
  226. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/registry.py +0 -0
  227. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/ai_analysis/scheduler.py +0 -0
  228. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/base/__init__.py +0 -0
  229. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/base/contracts.py +0 -0
  230. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/__init__.py +0 -0
  231. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/executor.py +0 -0
  232. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/notification.py +0 -0
  233. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/semantics.py +0 -0
  234. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/custom/spec.py +0 -0
  235. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/__init__.py +0 -0
  236. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/executor.py +0 -0
  237. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/notification.py +0 -0
  238. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/semantics.py +0 -0
  239. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/spec.py +0 -0
  240. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/dream_task/state.py +0 -0
  241. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/__init__.py +0 -0
  242. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/executor.py +0 -0
  243. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/notification.py +0 -0
  244. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/semantics.py +0 -0
  245. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/in_process_teammate/spec.py +0 -0
  246. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/__init__.py +0 -0
  247. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/executor.py +0 -0
  248. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/notification.py +0 -0
  249. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/runner.py +0 -0
  250. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/semantics.py +0 -0
  251. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_agent/spec.py +0 -0
  252. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/__init__.py +0 -0
  253. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/executor.py +0 -0
  254. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/notification.py +0 -0
  255. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/semantics.py +0 -0
  256. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/local_bash/spec.py +0 -0
  257. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/__init__.py +0 -0
  258. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/backend.py +0 -0
  259. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/executor.py +0 -0
  260. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/notification.py +0 -0
  261. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/semantics.py +0 -0
  262. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/remote_agent/spec.py +0 -0
  263. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/__init__.py +0 -0
  264. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/bootstrap.py +0 -0
  265. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/executor.py +0 -0
  266. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/task_runtime/tasks/trace_cleanup/scheduler.py +0 -0
  267. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/allowlist.py +0 -0
  268. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/__init__.py +0 -0
  269. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/classifier.py +0 -0
  270. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/parser.py +0 -0
  271. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/prompt.py +0 -0
  272. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/schema.py +0 -0
  273. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/classifier/transcript.py +0 -0
  274. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/config.py +0 -0
  275. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/events.py +0 -0
  276. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/factory.py +0 -0
  277. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/rule_stripping.py +0 -0
  278. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/auto_mode/state.py +0 -0
  279. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/base.py +0 -0
  280. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/errors.py +0 -0
  281. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/identical_call_cache.py +0 -0
  282. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/models.py +0 -0
  283. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/permission_context.py +0 -0
  284. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/policy_decorator.py +0 -0
  285. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/__init__.py +0 -0
  286. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/_abort.py +0 -0
  287. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/cli_interactive.py +0 -0
  288. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/handler.py +0 -0
  289. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/headless.py +0 -0
  290. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/legacy_resolver_adapter.py +0 -0
  291. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/race.py +0 -0
  292. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/prompt/types.py +0 -0
  293. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/registry.py +0 -0
  294. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/__init__.py +0 -0
  295. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/agent_session.py +0 -0
  296. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/background.py +0 -0
  297. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/base.py +0 -0
  298. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/conversation.py +0 -0
  299. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/resolvers/workflow.py +0 -0
  300. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/smoke_test_runtime.py +0 -0
  301. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tool_runtime/state_bridge.py +0 -0
  302. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/__init__.py +0 -0
  303. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/__init__.py +0 -0
  304. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/backend.py +0 -0
  305. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/__init__.py +0 -0
  306. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/agentx_guide.py +0 -0
  307. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/explore.py +0 -0
  308. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/general.py +0 -0
  309. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/plan.py +0 -0
  310. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/statusline_setup.py +0 -0
  311. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/built_in/verification.py +0 -0
  312. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/builtin_subagent_loader.py +0 -0
  313. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/cwd_resolution.py +0 -0
  314. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/limits.py +0 -0
  315. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/loader.py +0 -0
  316. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/models.py +0 -0
  317. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/prompt.py +0 -0
  318. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/__init__.py +0 -0
  319. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/config.py +0 -0
  320. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/registry/registry.py +0 -0
  321. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/scope.py +0 -0
  322. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/agent/tool.py +0 -0
  323. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/__init__.py +0 -0
  324. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/constants.py +0 -0
  325. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/html_preview.py +0 -0
  326. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/models.py +0 -0
  327. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/prompt.py +0 -0
  328. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/tool.py +0 -0
  329. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ask_user_question/validators.py +0 -0
  330. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/__init__.py +0 -0
  331. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/ast_security.py +0 -0
  332. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/auto_mode_adapter.py +0 -0
  333. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/backend.py +0 -0
  334. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/bash_hardening.py +0 -0
  335. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/bash_runtime_contract.py +0 -0
  336. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/cwd_reporter.py +0 -0
  337. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/events.py +0 -0
  338. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/limits.py +0 -0
  339. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/mode_validation.py +0 -0
  340. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/models.py +0 -0
  341. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/observability.py +0 -0
  342. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/output_utils.py +0 -0
  343. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/path_security.py +0 -0
  344. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/prompt.py +0 -0
  345. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/read_only_validation.py +0 -0
  346. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/result_presenter.py +0 -0
  347. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sandbox_decision.py +0 -0
  348. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/security.py +0 -0
  349. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sed_edit_parser.py +0 -0
  350. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/sed_validation.py +0 -0
  351. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/semantics.py +0 -0
  352. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/session_manager.py +0 -0
  353. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/session_runtime.py +0 -0
  354. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/shell_locator.py +0 -0
  355. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/task_runtime.py +0 -0
  356. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/tool.py +0 -0
  357. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/bash/windows_shell_quoting.py +0 -0
  358. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/__init__.py +0 -0
  359. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/backend.py +0 -0
  360. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/diff_generator.py +0 -0
  361. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/git_diff_generator.py +0 -0
  362. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/limits.py +0 -0
  363. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/models.py +0 -0
  364. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/prompt.py +0 -0
  365. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/quote_match.py +0 -0
  366. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/quote_normalizer.py +0 -0
  367. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/settings_validator.py +0 -0
  368. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/staleness.py +0 -0
  369. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/tool.py +0 -0
  370. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/edit/validator.py +0 -0
  371. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/__init__.py +0 -0
  372. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/models.py +0 -0
  373. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/pagination.py +0 -0
  374. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/prompt.py +0 -0
  375. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/rg_list_backend.py +0 -0
  376. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/rg_pattern.py +0 -0
  377. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/glob/tool.py +0 -0
  378. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/__init__.py +0 -0
  379. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/backend.py +0 -0
  380. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/models.py +0 -0
  381. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/prompt.py +0 -0
  382. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/rg_subprocess_controller.py +0 -0
  383. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/grep/tool.py +0 -0
  384. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/__init__.py +0 -0
  385. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/backend.py +0 -0
  386. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/limits.py +0 -0
  387. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/models.py +0 -0
  388. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/prompt.py +0 -0
  389. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/read/tool.py +0 -0
  390. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/ripgrep_plugin_exclusions.py +0 -0
  391. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/__init__.py +0 -0
  392. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/argument_substitution.py +0 -0
  393. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/loader.py +0 -0
  394. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/models.py +0 -0
  395. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/policy.py +0 -0
  396. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/prompt.py +0 -0
  397. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/skill/tool.py +0 -0
  398. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/__init__.py +0 -0
  399. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/hooks.py +0 -0
  400. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/limits.py +0 -0
  401. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/models.py +0 -0
  402. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/prompt.py +0 -0
  403. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_create/tool.py +0 -0
  404. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/__init__.py +0 -0
  405. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/models.py +0 -0
  406. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/prompt.py +0 -0
  407. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_get/tool.py +0 -0
  408. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/__init__.py +0 -0
  409. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/models.py +0 -0
  410. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/prompt.py +0 -0
  411. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_list/tool.py +0 -0
  412. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/__init__.py +0 -0
  413. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/hooks.py +0 -0
  414. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/models.py +0 -0
  415. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/prompt.py +0 -0
  416. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/task_update/tool.py +0 -0
  417. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/__init__.py +0 -0
  418. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/attachments.py +0 -0
  419. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/models.py +0 -0
  420. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/prompt.py +0 -0
  421. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/runtime_config.py +0 -0
  422. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/user_message/tool.py +0 -0
  423. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/__init__.py +0 -0
  424. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/limits.py +0 -0
  425. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/loader.py +0 -0
  426. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/models.py +0 -0
  427. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/preapproved.py +0 -0
  428. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/prompt.py +0 -0
  429. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/summary.py +0 -0
  430. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/webfetch/tool.py +0 -0
  431. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/__init__.py +0 -0
  432. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/backend.py +0 -0
  433. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/events.py +0 -0
  434. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/limits.py +0 -0
  435. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/loader.py +0 -0
  436. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/models.py +0 -0
  437. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/prompt.py +0 -0
  438. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/websearch/tool.py +0 -0
  439. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/__init__.py +0 -0
  440. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/backend.py +0 -0
  441. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/limits.py +0 -0
  442. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/models.py +0 -0
  443. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/prompt.py +0 -0
  444. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/tool.py +0 -0
  445. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/tools/write/validator.py +0 -0
  446. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/__init__.py +0 -0
  447. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/cwd.py +0 -0
  448. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/host_platform.py +0 -0
  449. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/path_hierarchy.py +0 -0
  450. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/path_user_input.py +0 -0
  451. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/rg_executable.py +0 -0
  452. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/subprocess_text.py +0 -0
  453. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/temp_paths.py +0 -0
  454. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/unc_path.py +0 -0
  455. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/utils/win_reserved_paths.py +0 -0
  456. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/__init__.py +0 -0
  457. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/base.py +0 -0
  458. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/batch.py +0 -0
  459. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/dag.py +0 -0
  460. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/__init__.py +0 -0
  461. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/adapter.py +0 -0
  462. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/depth_resolver.py +0 -0
  463. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/__init__.py +0 -0
  464. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/parallel_handler.py +0 -0
  465. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/route_handler.py +0 -0
  466. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/handlers/stage_handler.py +0 -0
  467. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/stack.py +0 -0
  468. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/event_adapter/types.py +0 -0
  469. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/node.py +0 -0
  470. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/__init__.py +0 -0
  471. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/chaining.py +0 -0
  472. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/evaluator_optimizer.py +0 -0
  473. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/orchestrator.py +0 -0
  474. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/parallelization.py +0 -0
  475. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/patterns/routing.py +0 -0
  476. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workflow/state.py +0 -0
  477. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/__init__.py +0 -0
  478. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/capabilities.py +0 -0
  479. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/config.py +0 -0
  480. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/path_key_normalizer.py +0 -0
  481. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/resolver.py +0 -0
  482. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx/workspace/validators.py +0 -0
  483. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/dependency_links.txt +0 -0
  484. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/not-zip-safe +0 -0
  485. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/langchain_agentx_python.egg-info/top_level.txt +0 -0
  486. {langchain-agentx-python-0.4.9 → langchain-agentx-python-0.5.0}/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.0
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.0"
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,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