aip-agents-binary 0.6.2__py3-none-any.whl → 0.6.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (305) hide show
  1. aip_agents/__init__.pyi +19 -0
  2. aip_agents/a2a/__init__.pyi +3 -0
  3. aip_agents/a2a/server/__init__.pyi +4 -0
  4. aip_agents/a2a/server/base_executor.pyi +73 -0
  5. aip_agents/a2a/server/google_adk_executor.pyi +51 -0
  6. aip_agents/a2a/server/langflow_executor.pyi +43 -0
  7. aip_agents/a2a/server/langgraph_executor.pyi +47 -0
  8. aip_agents/a2a/types.pyi +132 -0
  9. aip_agents/agent/__init__.pyi +9 -0
  10. aip_agents/agent/base_agent.pyi +221 -0
  11. aip_agents/agent/base_langgraph_agent.pyi +233 -0
  12. aip_agents/agent/google_adk_agent.pyi +141 -0
  13. aip_agents/agent/google_adk_constants.pyi +3 -0
  14. aip_agents/agent/hitl/__init__.pyi +6 -0
  15. aip_agents/agent/hitl/config.pyi +15 -0
  16. aip_agents/agent/hitl/langgraph_hitl_mixin.pyi +42 -0
  17. aip_agents/agent/hitl/manager.pyi +200 -0
  18. aip_agents/agent/hitl/models.pyi +3 -0
  19. aip_agents/agent/hitl/prompt/__init__.pyi +4 -0
  20. aip_agents/agent/hitl/prompt/base.pyi +24 -0
  21. aip_agents/agent/hitl/prompt/deferred.pyi +30 -0
  22. aip_agents/agent/hitl/registry.pyi +101 -0
  23. aip_agents/agent/interface.pyi +81 -0
  24. aip_agents/agent/interfaces.pyi +44 -0
  25. aip_agents/agent/langflow_agent.pyi +133 -0
  26. aip_agents/agent/langgraph_memory_enhancer_agent.pyi +49 -0
  27. aip_agents/agent/langgraph_react_agent.pyi +170 -0
  28. aip_agents/agent/system_instruction_context.pyi +13 -0
  29. aip_agents/clients/__init__.pyi +4 -0
  30. aip_agents/clients/langflow/__init__.pyi +4 -0
  31. aip_agents/clients/langflow/client.pyi +140 -0
  32. aip_agents/clients/langflow/types.pyi +7 -0
  33. aip_agents/constants.pyi +7 -0
  34. aip_agents/examples/__init__.pyi +0 -0
  35. aip_agents/examples/compare_streaming_client.pyi +48 -0
  36. aip_agents/examples/compare_streaming_server.pyi +18 -0
  37. aip_agents/examples/demo_memory_recall.pyi +58 -0
  38. aip_agents/examples/hello_world_a2a_google_adk_client.pyi +9 -0
  39. aip_agents/examples/hello_world_a2a_google_adk_client_agent.pyi +9 -0
  40. aip_agents/examples/hello_world_a2a_google_adk_client_streaming.pyi +9 -0
  41. aip_agents/examples/hello_world_a2a_google_adk_server.pyi +15 -0
  42. aip_agents/examples/hello_world_a2a_langchain_client.pyi +5 -0
  43. aip_agents/examples/hello_world_a2a_langchain_client_agent.pyi +5 -0
  44. aip_agents/examples/hello_world_a2a_langchain_client_lm_invoker.pyi +5 -0
  45. aip_agents/examples/hello_world_a2a_langchain_client_streaming.pyi +5 -0
  46. aip_agents/examples/hello_world_a2a_langchain_reference_client_streaming.pyi +5 -0
  47. aip_agents/examples/hello_world_a2a_langchain_reference_server.pyi +15 -0
  48. aip_agents/examples/hello_world_a2a_langchain_server.pyi +15 -0
  49. aip_agents/examples/hello_world_a2a_langchain_server_lm_invoker.pyi +15 -0
  50. aip_agents/examples/hello_world_a2a_langflow_client.pyi +9 -0
  51. aip_agents/examples/hello_world_a2a_langflow_server.pyi +14 -0
  52. aip_agents/examples/hello_world_a2a_langgraph_artifact_client.pyi +5 -0
  53. aip_agents/examples/hello_world_a2a_langgraph_artifact_client_streaming.pyi +5 -0
  54. aip_agents/examples/hello_world_a2a_langgraph_artifact_server.pyi +16 -0
  55. aip_agents/examples/hello_world_a2a_langgraph_client.pyi +9 -0
  56. aip_agents/examples/hello_world_a2a_langgraph_client_agent.pyi +9 -0
  57. aip_agents/examples/hello_world_a2a_langgraph_client_agent_lm_invoker.pyi +2 -0
  58. aip_agents/examples/hello_world_a2a_langgraph_client_streaming.pyi +9 -0
  59. aip_agents/examples/hello_world_a2a_langgraph_client_streaming_lm_invoker.pyi +5 -0
  60. aip_agents/examples/hello_world_a2a_langgraph_client_streaming_tool_streaming.pyi +5 -0
  61. aip_agents/examples/hello_world_a2a_langgraph_server.pyi +14 -0
  62. aip_agents/examples/hello_world_a2a_langgraph_server_lm_invoker.pyi +15 -0
  63. aip_agents/examples/hello_world_a2a_langgraph_server_tool_streaming.pyi +15 -0
  64. aip_agents/examples/hello_world_a2a_mcp_langgraph.pyi +48 -0
  65. aip_agents/examples/hello_world_a2a_three_level_agent_hierarchy_client.pyi +48 -0
  66. aip_agents/examples/hello_world_a2a_three_level_agent_hierarchy_server.pyi +45 -0
  67. aip_agents/examples/hello_world_a2a_with_metadata_langchain_client.pyi +5 -0
  68. aip_agents/examples/hello_world_a2a_with_metadata_langchain_server_lm_invoker.pyi +15 -0
  69. aip_agents/examples/hello_world_google_adk.pyi +5 -0
  70. aip_agents/examples/hello_world_google_adk_mcp_http.pyi +5 -0
  71. aip_agents/examples/hello_world_google_adk_mcp_http_stream.pyi +5 -0
  72. aip_agents/examples/hello_world_google_adk_mcp_sse.pyi +5 -0
  73. aip_agents/examples/hello_world_google_adk_mcp_sse_stream.pyi +5 -0
  74. aip_agents/examples/hello_world_google_adk_mcp_stdio.pyi +5 -0
  75. aip_agents/examples/hello_world_google_adk_mcp_stdio_stream.pyi +5 -0
  76. aip_agents/examples/hello_world_google_adk_stream.pyi +5 -0
  77. aip_agents/examples/hello_world_langchain.pyi +5 -0
  78. aip_agents/examples/hello_world_langchain_lm_invoker.pyi +2 -0
  79. aip_agents/examples/hello_world_langchain_mcp_http.pyi +5 -0
  80. aip_agents/examples/hello_world_langchain_mcp_http_interactive.pyi +16 -0
  81. aip_agents/examples/hello_world_langchain_mcp_http_stream.pyi +5 -0
  82. aip_agents/examples/hello_world_langchain_mcp_multi_server.pyi +18 -0
  83. aip_agents/examples/hello_world_langchain_mcp_sse.pyi +5 -0
  84. aip_agents/examples/hello_world_langchain_mcp_sse_stream.pyi +5 -0
  85. aip_agents/examples/hello_world_langchain_mcp_stdio.pyi +5 -0
  86. aip_agents/examples/hello_world_langchain_mcp_stdio_stream.pyi +5 -0
  87. aip_agents/examples/hello_world_langchain_stream.pyi +5 -0
  88. aip_agents/examples/hello_world_langchain_stream_lm_invoker.pyi +5 -0
  89. aip_agents/examples/hello_world_langflow_agent.pyi +35 -0
  90. aip_agents/examples/hello_world_langgraph.pyi +5 -0
  91. aip_agents/examples/hello_world_langgraph_gl_connector_twitter.pyi +5 -0
  92. aip_agents/examples/hello_world_langgraph_mcp_http.pyi +5 -0
  93. aip_agents/examples/hello_world_langgraph_mcp_http_stream.pyi +5 -0
  94. aip_agents/examples/hello_world_langgraph_mcp_sse.pyi +5 -0
  95. aip_agents/examples/hello_world_langgraph_mcp_sse_stream.pyi +5 -0
  96. aip_agents/examples/hello_world_langgraph_mcp_stdio.pyi +5 -0
  97. aip_agents/examples/hello_world_langgraph_mcp_stdio_stream.pyi +5 -0
  98. aip_agents/examples/hello_world_langgraph_stream.pyi +5 -0
  99. aip_agents/examples/hello_world_langgraph_stream_lm_invoker.pyi +5 -0
  100. aip_agents/examples/hello_world_model_switch_cli.pyi +30 -0
  101. aip_agents/examples/hello_world_multi_agent_adk.pyi +6 -0
  102. aip_agents/examples/hello_world_multi_agent_langchain.pyi +5 -0
  103. aip_agents/examples/hello_world_multi_agent_langgraph.pyi +5 -0
  104. aip_agents/examples/hello_world_multi_agent_langgraph_lm_invoker.pyi +5 -0
  105. aip_agents/examples/hello_world_pii_logger.pyi +5 -0
  106. aip_agents/examples/hello_world_ptc.pyi +5 -0
  107. aip_agents/examples/hello_world_sentry.pyi +21 -0
  108. aip_agents/examples/hello_world_step_limits.pyi +17 -0
  109. aip_agents/examples/hello_world_stock_a2a_server.pyi +17 -0
  110. aip_agents/examples/hello_world_tool_output_client.pyi +5 -0
  111. aip_agents/examples/hello_world_tool_output_server.pyi +19 -0
  112. aip_agents/examples/hitl_demo.pyi +67 -0
  113. aip_agents/examples/pii_demo_langgraph_client.pyi +5 -0
  114. aip_agents/examples/pii_demo_langgraph_server.pyi +20 -0
  115. aip_agents/examples/pii_demo_multi_agent_client.pyi +5 -0
  116. aip_agents/examples/pii_demo_multi_agent_server.pyi +40 -0
  117. aip_agents/examples/todolist_planning_a2a_langchain_client.pyi +5 -0
  118. aip_agents/examples/todolist_planning_a2a_langgraph_server.pyi +19 -0
  119. aip_agents/examples/tools/__init__.pyi +9 -0
  120. aip_agents/examples/tools/adk_arithmetic_tools.pyi +24 -0
  121. aip_agents/examples/tools/adk_weather_tool.pyi +18 -0
  122. aip_agents/examples/tools/data_generator_tool.pyi +15 -0
  123. aip_agents/examples/tools/data_visualization_tool.pyi +19 -0
  124. aip_agents/examples/tools/image_artifact_tool.pyi +26 -0
  125. aip_agents/examples/tools/langchain_arithmetic_tools.pyi +17 -0
  126. aip_agents/examples/tools/langchain_currency_exchange_tool.pyi +20 -0
  127. aip_agents/examples/tools/langchain_graph_artifact_tool.pyi +25 -0
  128. aip_agents/examples/tools/langchain_weather_tool.pyi +19 -0
  129. aip_agents/examples/tools/langgraph_streaming_tool.pyi +43 -0
  130. aip_agents/examples/tools/mock_retrieval_tool.pyi +13 -0
  131. aip_agents/examples/tools/pii_demo_tools.pyi +54 -0
  132. aip_agents/examples/tools/random_chart_tool.pyi +20 -0
  133. aip_agents/examples/tools/serper_tool.pyi +16 -0
  134. aip_agents/examples/tools/stock_tools.pyi +36 -0
  135. aip_agents/examples/tools/table_generator_tool.pyi +22 -0
  136. aip_agents/examples/tools/time_tool.pyi +15 -0
  137. aip_agents/examples/tools/weather_forecast_tool.pyi +14 -0
  138. aip_agents/guardrails/__init__.pyi +6 -0
  139. aip_agents/guardrails/engines/__init__.pyi +4 -0
  140. aip_agents/guardrails/engines/base.pyi +61 -0
  141. aip_agents/guardrails/engines/nemo.pyi +46 -0
  142. aip_agents/guardrails/engines/phrase_matcher.pyi +48 -0
  143. aip_agents/guardrails/exceptions.pyi +23 -0
  144. aip_agents/guardrails/manager.pyi +42 -0
  145. aip_agents/guardrails/middleware.pyi +87 -0
  146. aip_agents/guardrails/schemas.pyi +43 -0
  147. aip_agents/guardrails/utils.pyi +19 -0
  148. aip_agents/mcp/__init__.pyi +0 -0
  149. aip_agents/mcp/client/__init__.pyi +5 -0
  150. aip_agents/mcp/client/base_mcp_client.pyi +148 -0
  151. aip_agents/mcp/client/connection_manager.pyi +51 -0
  152. aip_agents/mcp/client/google_adk/__init__.pyi +3 -0
  153. aip_agents/mcp/client/google_adk/client.pyi +75 -0
  154. aip_agents/mcp/client/langchain/__init__.pyi +3 -0
  155. aip_agents/mcp/client/langchain/client.pyi +48 -0
  156. aip_agents/mcp/client/persistent_session.pyi +122 -0
  157. aip_agents/mcp/client/session_pool.pyi +101 -0
  158. aip_agents/mcp/client/transports.pyi +132 -0
  159. aip_agents/mcp/utils/__init__.pyi +0 -0
  160. aip_agents/mcp/utils/config_validator.pyi +82 -0
  161. aip_agents/memory/__init__.pyi +5 -0
  162. aip_agents/memory/adapters/__init__.pyi +4 -0
  163. aip_agents/memory/adapters/base_adapter.pyi +150 -0
  164. aip_agents/memory/adapters/mem0.pyi +22 -0
  165. aip_agents/memory/base.pyi +60 -0
  166. aip_agents/memory/constants.pyi +25 -0
  167. aip_agents/memory/factory.pyi +24 -0
  168. aip_agents/memory/guidance.pyi +3 -0
  169. aip_agents/memory/simple_memory.pyi +23 -0
  170. aip_agents/middleware/__init__.pyi +5 -0
  171. aip_agents/middleware/base.pyi +75 -0
  172. aip_agents/middleware/manager.pyi +84 -0
  173. aip_agents/middleware/todolist.pyi +125 -0
  174. aip_agents/ptc/__init__.pyi +10 -0
  175. aip_agents/ptc/doc_gen.pyi +40 -0
  176. aip_agents/ptc/exceptions.pyi +22 -0
  177. aip_agents/ptc/executor.pyi +73 -0
  178. aip_agents/ptc/mcp/__init__.pyi +7 -0
  179. aip_agents/ptc/mcp/sandbox_bridge.pyi +47 -0
  180. aip_agents/ptc/mcp/templates/__init__.pyi +0 -0
  181. aip_agents/ptc/naming.pyi +76 -0
  182. aip_agents/ptc/payload.pyi +15 -0
  183. aip_agents/ptc/prompt_builder.pyi +55 -0
  184. aip_agents/ptc/ptc_helper.pyi +1 -0
  185. aip_agents/ptc/sandbox_bridge.pyi +25 -0
  186. aip_agents/ptc/template_utils.pyi +13 -0
  187. aip_agents/ptc/templates/__init__.pyi +0 -0
  188. aip_agents/sandbox/__init__.pyi +5 -0
  189. aip_agents/sandbox/defaults.pyi +2 -0
  190. aip_agents/sandbox/e2b_runtime.pyi +51 -0
  191. aip_agents/sandbox/template_builder.pyi +36 -0
  192. aip_agents/sandbox/types.pyi +14 -0
  193. aip_agents/sandbox/validation.pyi +20 -0
  194. aip_agents/schema/__init__.pyi +9 -0
  195. aip_agents/schema/a2a.pyi +40 -0
  196. aip_agents/schema/agent.pyi +65 -0
  197. aip_agents/schema/hitl.pyi +89 -0
  198. aip_agents/schema/langgraph.pyi +28 -0
  199. aip_agents/schema/model_id.pyi +54 -0
  200. aip_agents/schema/step_limit.pyi +63 -0
  201. aip_agents/schema/storage.pyi +21 -0
  202. aip_agents/sentry/__init__.pyi +3 -0
  203. aip_agents/sentry/sentry.pyi +48 -0
  204. aip_agents/storage/__init__.pyi +8 -0
  205. aip_agents/storage/base.pyi +58 -0
  206. aip_agents/storage/clients/__init__.pyi +3 -0
  207. aip_agents/storage/clients/minio_client.pyi +137 -0
  208. aip_agents/storage/config.pyi +29 -0
  209. aip_agents/storage/providers/__init__.pyi +5 -0
  210. aip_agents/storage/providers/base.pyi +88 -0
  211. aip_agents/storage/providers/memory.pyi +79 -0
  212. aip_agents/storage/providers/object_storage.pyi +98 -0
  213. aip_agents/tools/__init__.py +11 -2
  214. aip_agents/tools/__init__.pyi +11 -0
  215. aip_agents/tools/browser_use/__init__.pyi +14 -0
  216. aip_agents/tools/browser_use/action_parser.pyi +18 -0
  217. aip_agents/tools/browser_use/browser_use_tool.pyi +50 -0
  218. aip_agents/tools/browser_use/llm_config.pyi +52 -0
  219. aip_agents/tools/browser_use/minio_storage.pyi +109 -0
  220. aip_agents/tools/browser_use/schemas.pyi +32 -0
  221. aip_agents/tools/browser_use/session.pyi +4 -0
  222. aip_agents/tools/browser_use/session_errors.pyi +53 -0
  223. aip_agents/tools/browser_use/steel_session_recording.pyi +63 -0
  224. aip_agents/tools/browser_use/streaming.pyi +81 -0
  225. aip_agents/tools/browser_use/structured_data_parser.pyi +86 -0
  226. aip_agents/tools/browser_use/structured_data_recovery.pyi +43 -0
  227. aip_agents/tools/browser_use/types.pyi +45 -0
  228. aip_agents/tools/code_sandbox/__init__.pyi +3 -0
  229. aip_agents/tools/code_sandbox/constant.pyi +4 -0
  230. aip_agents/tools/code_sandbox/e2b_cloud_sandbox_extended.pyi +102 -0
  231. aip_agents/tools/code_sandbox/e2b_sandbox_tool.pyi +29 -0
  232. aip_agents/tools/constants.pyi +138 -0
  233. aip_agents/tools/date_range_tool.py +554 -0
  234. aip_agents/tools/date_range_tool.pyi +21 -0
  235. aip_agents/tools/document_loader/__init__.pyi +7 -0
  236. aip_agents/tools/document_loader/base_reader.pyi +75 -0
  237. aip_agents/tools/document_loader/docx_reader_tool.pyi +10 -0
  238. aip_agents/tools/document_loader/excel_reader_tool.pyi +26 -0
  239. aip_agents/tools/document_loader/pdf_reader_tool.pyi +11 -0
  240. aip_agents/tools/document_loader/pdf_splitter.pyi +18 -0
  241. aip_agents/tools/execute_ptc_code.pyi +90 -0
  242. aip_agents/tools/gl_connector/__init__.pyi +3 -0
  243. aip_agents/tools/gl_connector/tool.pyi +74 -0
  244. aip_agents/tools/gl_connector_tools.pyi +39 -0
  245. aip_agents/tools/memory_search/__init__.pyi +5 -0
  246. aip_agents/tools/memory_search/base.pyi +69 -0
  247. aip_agents/tools/memory_search/mem0.pyi +19 -0
  248. aip_agents/tools/memory_search/schema.pyi +15 -0
  249. aip_agents/tools/memory_search_tool.pyi +3 -0
  250. aip_agents/tools/time_tool.pyi +16 -0
  251. aip_agents/tools/tool_config_injector.pyi +26 -0
  252. aip_agents/tools/web_search/__init__.pyi +3 -0
  253. aip_agents/tools/web_search/serper_tool.pyi +19 -0
  254. aip_agents/types/__init__.pyi +36 -0
  255. aip_agents/types/a2a_events.pyi +3 -0
  256. aip_agents/utils/__init__.pyi +11 -0
  257. aip_agents/utils/a2a_connector.pyi +146 -0
  258. aip_agents/utils/artifact_helpers.pyi +203 -0
  259. aip_agents/utils/constants.pyi +10 -0
  260. aip_agents/utils/datetime/__init__.pyi +4 -0
  261. aip_agents/utils/datetime/normalization.pyi +95 -0
  262. aip_agents/utils/datetime/timezone.pyi +48 -0
  263. aip_agents/utils/env_loader.pyi +10 -0
  264. aip_agents/utils/event_handler_registry.pyi +23 -0
  265. aip_agents/utils/file_prompt_utils.pyi +21 -0
  266. aip_agents/utils/final_response_builder.pyi +34 -0
  267. aip_agents/utils/formatter_llm_client.pyi +71 -0
  268. aip_agents/utils/langgraph/__init__.pyi +3 -0
  269. aip_agents/utils/langgraph/converter.pyi +49 -0
  270. aip_agents/utils/langgraph/tool_managers/__init__.pyi +5 -0
  271. aip_agents/utils/langgraph/tool_managers/a2a_tool_manager.pyi +35 -0
  272. aip_agents/utils/langgraph/tool_managers/base_tool_manager.pyi +48 -0
  273. aip_agents/utils/langgraph/tool_managers/delegation_tool_manager.pyi +56 -0
  274. aip_agents/utils/langgraph/tool_output_management.pyi +329 -0
  275. aip_agents/utils/logger.pyi +60 -0
  276. aip_agents/utils/metadata/__init__.pyi +5 -0
  277. aip_agents/utils/metadata/activity_metadata_helper.pyi +25 -0
  278. aip_agents/utils/metadata/activity_narrative/__init__.pyi +7 -0
  279. aip_agents/utils/metadata/activity_narrative/builder.pyi +35 -0
  280. aip_agents/utils/metadata/activity_narrative/constants.pyi +10 -0
  281. aip_agents/utils/metadata/activity_narrative/context.pyi +32 -0
  282. aip_agents/utils/metadata/activity_narrative/formatters.pyi +48 -0
  283. aip_agents/utils/metadata/activity_narrative/utils.pyi +12 -0
  284. aip_agents/utils/metadata/schemas/__init__.pyi +4 -0
  285. aip_agents/utils/metadata/schemas/activity_schema.pyi +18 -0
  286. aip_agents/utils/metadata/schemas/thinking_schema.pyi +20 -0
  287. aip_agents/utils/metadata/thinking_metadata_helper.pyi +4 -0
  288. aip_agents/utils/metadata_helper.pyi +117 -0
  289. aip_agents/utils/name_preprocessor/__init__.pyi +6 -0
  290. aip_agents/utils/name_preprocessor/base_name_preprocessor.pyi +52 -0
  291. aip_agents/utils/name_preprocessor/google_name_preprocessor.pyi +38 -0
  292. aip_agents/utils/name_preprocessor/name_preprocessor.pyi +41 -0
  293. aip_agents/utils/name_preprocessor/openai_name_preprocessor.pyi +34 -0
  294. aip_agents/utils/pii/__init__.pyi +5 -0
  295. aip_agents/utils/pii/pii_handler.pyi +96 -0
  296. aip_agents/utils/pii/pii_helper.pyi +78 -0
  297. aip_agents/utils/pii/uuid_deanonymizer_mapping.pyi +73 -0
  298. aip_agents/utils/reference_helper.pyi +81 -0
  299. aip_agents/utils/sse_chunk_transformer.pyi +166 -0
  300. aip_agents/utils/step_limit_manager.pyi +112 -0
  301. aip_agents/utils/token_usage_helper.pyi +60 -0
  302. {aip_agents_binary-0.6.2.dist-info → aip_agents_binary-0.6.3.dist-info}/METADATA +2 -1
  303. {aip_agents_binary-0.6.2.dist-info → aip_agents_binary-0.6.3.dist-info}/RECORD +305 -5
  304. {aip_agents_binary-0.6.2.dist-info → aip_agents_binary-0.6.3.dist-info}/WHEEL +0 -0
  305. {aip_agents_binary-0.6.2.dist-info → aip_agents_binary-0.6.3.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,48 @@
1
+ from _typeshed import Incomplete
2
+ from abc import ABC, abstractmethod
3
+ from aip_agents.utils.logger import get_logger as get_logger
4
+ from langchain_core.tools import BaseTool as BaseTool
5
+ from typing import Any
6
+
7
+ logger: Incomplete
8
+
9
+ class BaseLangGraphToolManager(ABC):
10
+ """Base class for managing specialized tools in LangGraph agents.
11
+
12
+ This abstract base class provides a common interface for tool managers
13
+ that convert different types of capabilities into LangChain tools for
14
+ use in LangGraph agents.
15
+
16
+ The design follows a simple pattern:
17
+ 1. Register resources (agents, cards, etc.)
18
+ 2. Convert resources to LangChain tools
19
+ 3. Provide access to created tools
20
+ """
21
+ created_tools: list[BaseTool]
22
+ def __init__(self) -> None:
23
+ """Initialize the tool manager."""
24
+ @abstractmethod
25
+ def register_resources(self, resources: list[Any]) -> list[BaseTool]:
26
+ """Register resources and convert them to LangChain tools.
27
+
28
+ Args:
29
+ resources: List of resources to convert to tools.
30
+
31
+ Returns:
32
+ List of created tools.
33
+ """
34
+ def get_tools(self) -> list[BaseTool]:
35
+ """Get all created tools.
36
+
37
+ Returns:
38
+ Copy of created tools list.
39
+ """
40
+ def clear_tools(self) -> None:
41
+ """Clear all created tools."""
42
+ @abstractmethod
43
+ def get_resource_names(self) -> list[str]:
44
+ """Get names of all registered resources.
45
+
46
+ Returns:
47
+ List of resource names.
48
+ """
@@ -0,0 +1,56 @@
1
+ from _typeshed import Incomplete
2
+ from aip_agents.agent.base_agent import BaseAgent as BaseAgent
3
+ from aip_agents.schema.step_limit import MaxDelegationDepthExceededError as MaxDelegationDepthExceededError
4
+ from aip_agents.types import A2AEvent as A2AEvent, A2AStreamEventType as A2AStreamEventType
5
+ from aip_agents.utils.artifact_helpers import extract_artifacts_from_agent_response as extract_artifacts_from_agent_response
6
+ from aip_agents.utils.langgraph.tool_managers.base_tool_manager import BaseLangGraphToolManager as BaseLangGraphToolManager
7
+ from aip_agents.utils.logger import get_logger as get_logger
8
+ from aip_agents.utils.metadata_helper import MetadataFieldKeys as MetadataFieldKeys, get_next_step_number as get_next_step_number
9
+ from aip_agents.utils.pii.pii_helper import anonymize_final_response_content as anonymize_final_response_content, extract_pii_mapping_from_agent_response as extract_pii_mapping_from_agent_response
10
+ from aip_agents.utils.reference_helper import extract_references_from_agent_response as extract_references_from_agent_response
11
+ from aip_agents.utils.step_limit_manager import StepLimitManager as StepLimitManager
12
+ from aip_agents.utils.token_usage_helper import STEP_USAGE_KEY as STEP_USAGE_KEY, TOTAL_USAGE_KEY as TOTAL_USAGE_KEY, USAGE_METADATA_KEY as USAGE_METADATA_KEY, extract_token_usage_from_agent_response as extract_token_usage_from_agent_response
13
+ from langchain_core.tools import BaseTool
14
+
15
+ logger: Incomplete
16
+ OUTPUT_KEY: str
17
+ RESULT_KEY: str
18
+ ARTIFACTS_KEY: str
19
+ METADATA_KEY: str
20
+ METADATA_INTERNAL_PREFIXES: Incomplete
21
+ METADATA_INTERNAL_KEYS: Incomplete
22
+ AGENT_RUN_A2A_STREAMING_METHOD: str
23
+
24
+ class DelegationToolManager(BaseLangGraphToolManager):
25
+ """Manages internal agent delegation tools for LangGraph agents.
26
+
27
+ This tool manager converts internal agent instances into LangChain tools
28
+ that can be used for task delegation within a unified ToolNode. Each
29
+ delegated agent becomes a tool that the coordinator can call.
30
+
31
+ Simplified version following legacy BaseLangChainAgent patterns.
32
+ """
33
+ registered_agents: list[BaseAgent]
34
+ parent_agent: Incomplete
35
+ def __init__(self, parent_agent: BaseAgent | None = None) -> None:
36
+ """Initialize the delegation tool manager.
37
+
38
+ Args:
39
+ parent_agent: The parent agent that creates delegation tools, used for parent step lookup.
40
+ """
41
+ created_tools: Incomplete
42
+ def register_resources(self, agents: list[BaseAgent]) -> list[BaseTool]:
43
+ """Register internal agents for delegation and convert them to tools.
44
+
45
+ Args:
46
+ agents: List of BaseAgent instances for internal task delegation.
47
+
48
+ Returns:
49
+ List of created delegation tools.
50
+ """
51
+ def get_resource_names(self) -> list[str]:
52
+ """Get names of all registered delegation agents.
53
+
54
+ Returns:
55
+ list[str]: A list of names of all registered delegation agents.
56
+ """
@@ -0,0 +1,329 @@
1
+ from _typeshed import Incomplete
2
+ from aip_agents.storage.providers.base import BaseStorageProvider as BaseStorageProvider, StorageError as StorageError
3
+ from aip_agents.storage.providers.memory import InMemoryStorageProvider as InMemoryStorageProvider
4
+ from aip_agents.utils.logger import get_logger as get_logger
5
+ from dataclasses import dataclass
6
+ from datetime import datetime, timedelta
7
+ from typing import Any
8
+
9
+ logger: Incomplete
10
+ STRING_TRUNCATION_LENGTH: int
11
+ MAX_TOOL_ARGS_DISPLAY: int
12
+ DATA_PREVIEW_TRUNCATION_LENGTH: int
13
+ TOOL_OUTPUT_REFERENCE_PREFIX: str
14
+
15
+ class ToolReferenceError(Exception):
16
+ """Specialized exception for tool output reference resolution errors.
17
+
18
+ This exception is raised when there are issues with resolving tool output references,
19
+ such as invalid reference syntax, missing outputs, or security violations.
20
+
21
+ Attributes:
22
+ reference: The original reference string that caused the error.
23
+ call_id: The call ID that was attempted to be resolved, if applicable.
24
+ details: Additional error details for debugging.
25
+ """
26
+ reference: Incomplete
27
+ call_id: Incomplete
28
+ details: Incomplete
29
+ def __init__(self, message: str, reference: str | None = None, call_id: str | None = None, details: dict[str, Any] | None = None) -> None:
30
+ """Initialize a ToolReferenceError.
31
+
32
+ Args:
33
+ message: Human-readable error message describing what went wrong.
34
+ reference: The original reference string that caused the error, if applicable.
35
+ call_id: The call ID that was attempted to be resolved, if applicable.
36
+ details: Additional error details for debugging, if applicable.
37
+ """
38
+
39
+ @dataclass
40
+ class ToolOutputConfig:
41
+ """Configuration for tool output management system.
42
+
43
+ This class defines the operational parameters for the tool output management
44
+ system, including storage limits, cleanup intervals, and lifecycle policies.
45
+
46
+ Attributes:
47
+ max_stored_outputs: Maximum number of tool outputs to store simultaneously.
48
+ When this limit is reached, oldest outputs are evicted. Defaults to 100.
49
+ max_age_minutes: Maximum age in minutes for stored outputs before they
50
+ become eligible for cleanup. Defaults to 60 minutes.
51
+ cleanup_interval: Number of tool calls between automatic cleanup operations.
52
+ Set to 0 to disable automatic cleanup. Defaults to 20.
53
+ storage_provider: Optional storage provider for persistent storage.
54
+ If None, uses in-memory storage (backward compatible). Defaults to None.
55
+ """
56
+ max_stored_outputs: int = ...
57
+ max_age_minutes: int = ...
58
+ cleanup_interval: int = ...
59
+ storage_provider: BaseStorageProvider | None = ...
60
+
61
+ @dataclass
62
+ class ToolOutput:
63
+ """Container for tool outputs with optional data payload.
64
+
65
+ This class represents tool output metadata and optionally the actual data.
66
+ When used as metadata only, the data field is None and must be retrieved
67
+ from storage. When loaded with data, it contains the complete output.
68
+
69
+ Attributes:
70
+ call_id: Unique identifier for this tool call, used for reference resolution.
71
+ tool_name: Name of the tool that produced this output.
72
+ timestamp: When this output was created and stored.
73
+ size_bytes: Approximate size of the stored data in bytes for memory management.
74
+ tool_args: Input arguments that were passed to the tool for this call.
75
+ data: Optional actual output data. None when used as metadata only.
76
+ data_description: Optional human-readable description of the data content,
77
+ typically provided by the tool itself.
78
+ tags: Optional list of tags for categorization and filtering.
79
+ agent_name: Name of the agent that created this output, for multi-agent context.
80
+ """
81
+ call_id: str
82
+ tool_name: str
83
+ timestamp: datetime
84
+ size_bytes: int
85
+ tool_args: dict[str, Any]
86
+ data: Any | None = ...
87
+ data_description: str | None = ...
88
+ tags: list[str] | None = ...
89
+ agent_name: str | None = ...
90
+ @property
91
+ def is_metadata_only(self) -> bool:
92
+ """Check if this instance contains only metadata without data."""
93
+ def is_expired(self, max_age: timedelta) -> bool:
94
+ """Check if this output has expired based on the given maximum age.
95
+
96
+ Args:
97
+ max_age (timedelta): The maximum age allowed before expiration.
98
+
99
+ Returns:
100
+ bool: True if the output has expired, False otherwise.
101
+ """
102
+ def get_data_preview(self, max_length: int = 200, storage_provider: BaseStorageProvider | None = None, thread_id: str | None = None) -> str | None:
103
+ """Get a truncated string representation of the stored data.
104
+
105
+ Args:
106
+ max_length: Maximum length of the preview string.
107
+ storage_provider: Required only if data is not loaded.
108
+ thread_id: Thread ID required for proper storage key generation.
109
+
110
+ Returns:
111
+ A string representation of the data, truncated if necessary. None if data is not found.
112
+ """
113
+ def with_data(self, data: Any) -> ToolOutput:
114
+ """Create a new instance with data populated.
115
+
116
+ Returns a new ToolOutput instance with the same metadata but with
117
+ data field populated. Useful for converting metadata-only instances
118
+ to complete instances.
119
+
120
+ Args:
121
+ data (Any): The actual output data to populate.
122
+
123
+ Returns:
124
+ ToolOutput: A new instance with data populated.
125
+ """
126
+
127
+ @dataclass
128
+ class StoreOutputParams:
129
+ """Parameters for storing tool outputs.
130
+
131
+ Reduces the number of arguments passed to store_output method.
132
+
133
+ Attributes:
134
+ call_id: Unique identifier for this tool call.
135
+ tool_name: Name of the tool that produced the output.
136
+ data: The actual output data to store.
137
+ tool_args: Input arguments used for the tool call.
138
+ thread_id: Thread/conversation ID to organize outputs by conversation.
139
+ description: Optional human-readable description of the output.
140
+ tags: Optional list of tags for categorization.
141
+ agent_name: Name of the agent that created this output.
142
+ """
143
+ call_id: str
144
+ tool_name: str
145
+ data: Any
146
+ tool_args: dict[str, Any]
147
+ thread_id: str
148
+ description: str | None = ...
149
+ tags: list[str] | None = ...
150
+ agent_name: str | None = ...
151
+
152
+ class ToolOutputManager:
153
+ """Production-ready tool output manager with comprehensive lifecycle management.
154
+
155
+ This class provides centralized management of tool outputs including storage,
156
+ retrieval, lifecycle management, and LLM-friendly summarization. It handles
157
+ memory management through configurable cleanup policies and provides secure
158
+ access to stored outputs.
159
+
160
+ Key Features:
161
+ - Automatic and manual storage of tool outputs with metadata
162
+ - Configurable lifecycle management with age and size-based eviction
163
+ - LLM-friendly summary generation with data previews and context
164
+ - Memory management with size tracking and cleanup
165
+ - Thread-safe operations with proper error handling and locking
166
+ - Concurrent access support for multi-agent and parallel processing scenarios
167
+
168
+ Attributes:
169
+ config: Configuration object defining operational parameters.
170
+ """
171
+ config: Incomplete
172
+ def __init__(self, config: ToolOutputConfig) -> None:
173
+ """Initialize the ToolOutputManager with the given configuration.
174
+
175
+ Args:
176
+ config: Configuration object defining storage limits and cleanup policies.
177
+ """
178
+ def store_output(self, params: StoreOutputParams) -> None:
179
+ """Store a tool output with automatic cleanup and size management.
180
+
181
+ This method stores a tool output along with its metadata, automatically
182
+ handling size limits, cleanup, and memory management. If the same call_id
183
+ is used multiple times within the same thread, the previous output will be overwritten.
184
+
185
+ Thread-safe: This method uses internal locking to ensure safe concurrent access.
186
+
187
+ Args:
188
+ params: StoreOutputParams containing all necessary parameters including thread_id.
189
+
190
+ Raises:
191
+ Exception: If storage operation fails for any reason.
192
+ """
193
+ def get_output(self, call_id: str, thread_id: str) -> ToolOutput | None:
194
+ """Retrieve a stored tool output by its call ID and thread ID.
195
+
196
+ Thread-safe: This method uses internal locking to ensure safe concurrent access.
197
+
198
+ Args:
199
+ call_id: The unique identifier for the tool call.
200
+ thread_id: The thread/conversation ID to search in.
201
+
202
+ Returns:
203
+ The ToolOutput object with data if found, None otherwise.
204
+ """
205
+ def has_outputs(self, thread_id: str | None = None) -> bool:
206
+ """Check if any outputs are currently stored.
207
+
208
+ Thread-safe: This method uses internal locking to ensure safe concurrent access.
209
+
210
+ Args:
211
+ thread_id: Optional thread ID to check for outputs in a specific thread.
212
+ If None, checks across all threads.
213
+
214
+ Returns:
215
+ True if there are stored outputs, False otherwise.
216
+ """
217
+ def generate_summary(self, thread_id: str, max_entries: int = 10) -> str:
218
+ """Generate an LLM-friendly structured summary as JSON.
219
+
220
+ This method creates a comprehensive, structured summary of stored outputs that
221
+ can be easily parsed by LLMs and other systems. The JSON format provides rich
222
+ metadata and context about each tool output.
223
+
224
+ Thread-safe: This method uses internal locking to ensure safe concurrent access.
225
+
226
+ Args:
227
+ thread_id: Thread ID to generate summary for.
228
+ max_entries: Maximum number of entries to include in the summary.
229
+ Defaults to 10.
230
+
231
+ Returns:
232
+ A JSON string containing structured data about tool outputs. Always returns
233
+ valid JSON, even when no outputs are stored (empty entries list).
234
+ """
235
+ def get_latest_reference(self, thread_id: str) -> str | None:
236
+ """Return the most recent tool output reference for a thread.
237
+
238
+ Args:
239
+ thread_id: Thread ID to retrieve the latest output reference for.
240
+
241
+ Returns:
242
+ Latest tool output reference string or None when unavailable.
243
+ """
244
+ def has_reference(self, value: Any) -> bool:
245
+ """Check whether a value contains a tool output reference.
246
+
247
+ Args:
248
+ value: Value to inspect for tool output references.
249
+
250
+ Returns:
251
+ True if any tool output reference is present.
252
+ """
253
+ def should_replace_with_reference(self, value: Any) -> bool:
254
+ """Check whether a tool argument value should use a tool output reference.
255
+
256
+ Args:
257
+ value: Value to evaluate for replacement.
258
+
259
+ Returns:
260
+ True if the value should be replaced with a reference.
261
+ """
262
+ def rewrite_args_with_latest_reference(self, args: dict[str, Any], thread_id: str) -> dict[str, Any]:
263
+ """Rewrite tool args to use the latest tool output reference when appropriate.
264
+
265
+ Args:
266
+ args: Tool arguments to rewrite.
267
+ thread_id: Thread ID used for resolving stored outputs.
268
+
269
+ Returns:
270
+ Updated args dictionary with references substituted when needed.
271
+ """
272
+ def clear_all(self) -> None:
273
+ """Clear all stored outputs from both metadata and storage.
274
+
275
+ Warning:
276
+ This operation is irreversible and will remove all stored tool outputs.
277
+ """
278
+ def get_storage_stats(self) -> dict[str, Any]:
279
+ """Get storage statistics for monitoring and debugging.
280
+
281
+ Returns:
282
+ Dictionary containing storage statistics.
283
+ """
284
+
285
+ class ToolReferenceResolver:
286
+ """Secure and efficient tool output reference resolution system.
287
+
288
+ This class handles the resolution of tool output references in a secure manner,
289
+ preventing injection attacks while providing simple and reliable access to
290
+ stored tool outputs. It uses a whitelist approach with regex validation to
291
+ ensure only safe references are processed.
292
+
293
+ Security Features:
294
+ - Strict regex pattern matching for reference syntax
295
+ - Whitelist-based validation to prevent injection attacks
296
+ - Fail-fast error handling with detailed error messages
297
+ - Input sanitization and validation at multiple levels
298
+
299
+ Supported Reference Syntax:
300
+ - $tool_output.<call_id> - Direct reference to a tool output by call ID
301
+
302
+ Attributes:
303
+ config: Configuration object for operational parameters.
304
+ """
305
+ config: Incomplete
306
+ def __init__(self, config: ToolOutputConfig) -> None:
307
+ """Initialize the ToolReferenceResolver with security configuration.
308
+
309
+ Args:
310
+ config: Configuration object defining operational parameters.
311
+ """
312
+ def resolve_references(self, args: dict[str, Any], manager: ToolOutputManager, thread_id: str | None = None) -> dict[str, Any]:
313
+ """Resolve all tool output references in the given arguments dictionary.
314
+
315
+ This method recursively processes a dictionary of tool arguments, finding
316
+ and resolving any tool output references. It supports nested dictionaries
317
+ and lists, providing comprehensive reference resolution.
318
+
319
+ Args:
320
+ args: Dictionary of tool arguments that may contain references.
321
+ manager: ToolOutputManager instance to resolve references against.
322
+ thread_id: Optional thread ID for context-aware resolution.
323
+
324
+ Returns:
325
+ New dictionary with all references resolved to their actual values.
326
+
327
+ Raises:
328
+ ToolReferenceError: If any reference is invalid or cannot be resolved.
329
+ """
@@ -0,0 +1,60 @@
1
+ import logging
2
+ from _typeshed import Incomplete
3
+
4
+ LOGGER_NAME: str
5
+ LOG_LEVEL: Incomplete
6
+
7
+ class _GoogleAdkLogFilter(logging.Filter):
8
+ """Suppress noisy Google ADK model registry logs.
9
+
10
+ Google ADK emits a burst of INFO logs when registering Gemini model patterns.
11
+ They are redundant (class is unchanged) and clutter our startup output, so we
12
+ drop them at the logging infrastructure level instead of touching ADK internals.
13
+ """
14
+ SUPPRESSED_PREFIX: str
15
+ def filter(self, record: logging.LogRecord) -> bool:
16
+ """Return False when the log should be discarded.
17
+
18
+ Args:
19
+ record (logging.LogRecord): The log record to filter.
20
+
21
+ Returns:
22
+ bool: True if the log should be processed, False if it should be discarded.
23
+ """
24
+
25
+ LOG_FILTERS: Incomplete
26
+ logger_manager: Incomplete
27
+ root_logger: Incomplete
28
+
29
+ def get_logger(name: str = ..., level: int = ...) -> logging.Logger:
30
+ """Get a logger instance.
31
+
32
+ Args:
33
+ name (str): The name of the logger. Defaults to AIPAgentsLogger.
34
+ level (int): The level of the logger. Defaults to INFO.
35
+
36
+ Returns:
37
+ logging.Logger: The logger instance.
38
+ """
39
+
40
+ logger: Incomplete
41
+ THIRD_PARTY_LOGGER_NAMES: Incomplete
42
+
43
+ class LoggerManager:
44
+ """A singleton class to manage logging configuration.
45
+
46
+ This class is deprecated and will be removed in a future version.
47
+ Use get_logger() function directly instead.
48
+ """
49
+ def __new__(cls):
50
+ """Initialize the singleton instance."""
51
+ def get_logger(self, name: str = ..., level: int = ...) -> logging.Logger:
52
+ """Get a logger instance.
53
+
54
+ Args:
55
+ name (str): The name of the logger. Defaults to AIPAgentsLogger.
56
+ level (int): The level of the logger. Defaults to INFO.
57
+
58
+ Returns:
59
+ logging.Logger: The logger instance.
60
+ """
@@ -0,0 +1,5 @@
1
+ from aip_agents.utils.metadata.activity_metadata_helper import DEFAULT_ACTIVITY_INFO as DEFAULT_ACTIVITY_INFO, _format_tool_or_subagent_name as _format_tool_or_subagent_name, create_tool_activity_info as create_tool_activity_info
2
+ from aip_agents.utils.metadata.schemas import Activity as Activity, ActivityDataType as ActivityDataType, Thinking as Thinking
3
+ from aip_agents.utils.metadata.thinking_metadata_helper import FINAL_THINKING_INFO as FINAL_THINKING_INFO
4
+
5
+ __all__ = ['Activity', 'ActivityDataType', 'Thinking', 'create_tool_activity_info', 'DEFAULT_ACTIVITY_INFO', '_format_tool_or_subagent_name', 'FINAL_THINKING_INFO']
@@ -0,0 +1,25 @@
1
+ from _typeshed import Incomplete
2
+ from aip_agents.schema.hitl import ApprovalDecisionType as ApprovalDecisionType
3
+ from aip_agents.utils.logger import get_logger as get_logger
4
+ from aip_agents.utils.metadata.activity_narrative import ActivityNarrativeBuilder as ActivityNarrativeBuilder, DELEGATE_PREFIX as DELEGATE_PREFIX, HITL_DECISION_MESSAGES as HITL_DECISION_MESSAGES, HITL_PENDING_DESCRIPTION as HITL_PENDING_DESCRIPTION, HITL_PENDING_TITLE as HITL_PENDING_TITLE
5
+ from aip_agents.utils.metadata.schemas.activity_schema import Activity as Activity
6
+ from typing import Any
7
+
8
+ logger: Incomplete
9
+ DEFAULT_ACTIVITY_MESSAGE: str
10
+ TOOL_EXECUTION_RUNNING_TEMPLATE: str
11
+ TOOL_EXECUTION_COMPLETE_TEMPLATE: str
12
+ SUBAGENT_DELEGATION_TEMPLATE: str
13
+ SUBAGENT_COMPLETE_TEMPLATE: str
14
+ MIXED_EXECUTION_TEMPLATE: str
15
+ DEFAULT_ACTIVITY_INFO: Incomplete
16
+
17
+ def create_tool_activity_info(original_metadata: dict[str, Any] | None) -> dict[str, str]:
18
+ '''Create activity info payload with optional LLM narrative overrides.
19
+
20
+ Args:
21
+ original_metadata: The original metadata dictionary containing tool_info and hitl data.
22
+
23
+ Returns:
24
+ A dict with data_type="activity" and data_value as a JSON string.
25
+ '''
@@ -0,0 +1,7 @@
1
+ from aip_agents.utils.metadata.activity_narrative.builder import ActivityNarrativeBuilder as ActivityNarrativeBuilder, _formatter_llm_client as _formatter_llm_client
2
+ from aip_agents.utils.metadata.activity_narrative.constants import DELEGATE_PREFIX as DELEGATE_PREFIX, HITL_DECISION_MESSAGES as HITL_DECISION_MESSAGES, HITL_PENDING_DESCRIPTION as HITL_PENDING_DESCRIPTION, HITL_PENDING_TITLE as HITL_PENDING_TITLE, OUTPUT_EXCERPT_MAX_CHARS as OUTPUT_EXCERPT_MAX_CHARS, SYSTEM_PROMPT as SYSTEM_PROMPT
3
+ from aip_agents.utils.metadata.activity_narrative.context import ActivityContext as ActivityContext, ActivityPhase as ActivityPhase
4
+ from aip_agents.utils.metadata.activity_narrative.formatters import ArgsFormatter as ArgsFormatter, OutputFormatter as OutputFormatter, SensitiveInfoFilter as SensitiveInfoFilter
5
+ from aip_agents.utils.metadata.activity_narrative.utils import _format_tool_or_subagent_name as _format_tool_or_subagent_name
6
+
7
+ __all__ = ['ActivityNarrativeBuilder', 'ActivityContext', 'ActivityPhase', 'ArgsFormatter', 'OutputFormatter', 'SensitiveInfoFilter', 'DELEGATE_PREFIX', 'HITL_DECISION_MESSAGES', 'HITL_PENDING_DESCRIPTION', 'HITL_PENDING_TITLE', 'OUTPUT_EXCERPT_MAX_CHARS', 'SYSTEM_PROMPT', '_format_tool_or_subagent_name', '_formatter_llm_client']
@@ -0,0 +1,35 @@
1
+ from _typeshed import Incomplete
2
+ from aip_agents.schema.hitl import ApprovalDecisionType as ApprovalDecisionType, HitlMetadata as HitlMetadata
3
+ from aip_agents.utils.formatter_llm_client import FormatterInvocationError as FormatterInvocationError, FormatterInvokerUnavailableError as FormatterInvokerUnavailableError, get_formatter_llm_client as get_formatter_llm_client
4
+ from aip_agents.utils.logger import get_logger as get_logger
5
+ from aip_agents.utils.metadata.activity_narrative.constants import DELEGATE_PREFIX as DELEGATE_PREFIX, HITL_DECISION_MESSAGES as HITL_DECISION_MESSAGES, HITL_PENDING_DESCRIPTION as HITL_PENDING_DESCRIPTION, HITL_PENDING_TITLE as HITL_PENDING_TITLE, OUTPUT_EXCERPT_MAX_CHARS as OUTPUT_EXCERPT_MAX_CHARS, SYSTEM_PROMPT as SYSTEM_PROMPT
6
+ from aip_agents.utils.metadata.activity_narrative.context import ActivityContext as ActivityContext, ActivityPhase as ActivityPhase
7
+ from aip_agents.utils.metadata.activity_narrative.formatters import ArgsFormatter as ArgsFormatter, OutputFormatter as OutputFormatter, SensitiveInfoFilter as SensitiveInfoFilter
8
+ from typing import Any
9
+
10
+ logger: Incomplete
11
+
12
+ class ActivityNarrativeBuilder:
13
+ """Generate structured activity payloads via formatter LLM.
14
+
15
+ High-level flow:
16
+ 1. Gather raw metadata about a tool/delegate event and normalize it into an ``ActivityContext``.
17
+ 2. Sanitize arguments and outputs so no sensitive values reach downstream renderers or the formatter model.
18
+ 3. Prompt the shared formatter with phase-specific instructions (e.g., describe intent on start, summarize results on end).
19
+ 4. If the formatter responds with usable heading/body text, surface it; otherwise fall back to deterministic templates
20
+ built from the sanitized context.
21
+
22
+ This approach keeps SSE activity cards readable when the formatter is healthy while still providing sensible copy when
23
+ the formatter is unavailable or returns low-quality text.
24
+ """
25
+ def __init__(self) -> None:
26
+ """Initialize the activity narrative builder."""
27
+ def build_payload(self, metadata: dict[str, Any] | None) -> dict[str, Any] | None:
28
+ """Build enriched payload for the provided metadata.
29
+
30
+ Args:
31
+ metadata: The metadata dictionary containing tool_info, hitl, and other context.
32
+
33
+ Returns:
34
+ Dictionary payload with a rendered message, or None when not available.
35
+ """
@@ -0,0 +1,10 @@
1
+ from aip_agents.schema.hitl import ApprovalDecisionType
2
+
3
+ __all__ = ['SYSTEM_PROMPT', 'DELEGATE_PREFIX', 'OUTPUT_EXCERPT_MAX_CHARS', 'HITL_PENDING_TITLE', 'HITL_PENDING_DESCRIPTION', 'HITL_DECISION_MESSAGES']
4
+
5
+ SYSTEM_PROMPT: str
6
+ DELEGATE_PREFIX: str
7
+ OUTPUT_EXCERPT_MAX_CHARS: int
8
+ HITL_PENDING_TITLE: str
9
+ HITL_PENDING_DESCRIPTION: str
10
+ HITL_DECISION_MESSAGES: dict[ApprovalDecisionType, tuple[str, str]]
@@ -0,0 +1,32 @@
1
+ from aip_agents.schema.hitl import ApprovalDecisionType, HitlMetadata
2
+ from dataclasses import dataclass
3
+ from enum import StrEnum
4
+
5
+ __all__ = ['ActivityContext', 'ActivityPhase']
6
+
7
+ class ActivityPhase(StrEnum):
8
+ """Lifecycle phases for tool, delegate, and HITL events."""
9
+ TOOL_START: str
10
+ TOOL_END: str
11
+ DELEGATE_START: str
12
+ DELEGATE_END: str
13
+ HITL_PENDING: str
14
+ HITL_RESOLVED: str
15
+ JSONScalar = str | int | float | bool | None
16
+
17
+ @dataclass
18
+ class ActivityContext:
19
+ """Structured representation of an activity event."""
20
+ phase: ActivityPhase
21
+ agent_name: str | None
22
+ subject_name: str | None
23
+ sanitized_args: dict[str, JSONValue] | None
24
+ sanitized_output: JSONValue | None
25
+ arguments_excerpt: str | None
26
+ output_excerpt: str | None
27
+ error_excerpt: str | None
28
+ step_id: str | None = ...
29
+ is_delegate: bool = ...
30
+ hitl_metadata: HitlMetadata | None = ...
31
+ hitl_decision: ApprovalDecisionType | None = ...
32
+ default_heading: str | None = ...
@@ -0,0 +1,48 @@
1
+ from _typeshed import Incomplete
2
+ from collections.abc import Callable
3
+
4
+ __all__ = ['ArgsFormatter', 'OutputFormatter', 'SensitiveInfoFilter']
5
+
6
+ JSONScalar = str | int | float | bool | None
7
+
8
+ class SensitiveInfoFilter:
9
+ """Redact sensitive argument/output values before rendering or sending to LLMs."""
10
+ REDACTED: str
11
+ SENSITIVE_KEY_PATTERNS: Incomplete
12
+ def __init__(self) -> None:
13
+ """Initialize the sensitive info filter."""
14
+ def sanitize(self, args: dict[str, JSONValue] | None, output: JSONValue | None, tool_sanitizer: Callable[[dict[str, JSONValue] | None, JSONValue | None], dict[str, JSONValue]] | None = None) -> tuple[dict[str, JSONValue] | None, JSONValue | None]:
15
+ """Return sanitized arguments/output with optional tool overrides.
16
+
17
+ Args:
18
+ args: Raw arguments dictionary emitted by the tool.
19
+ output: Raw tool output which may be nested JSON.
20
+ tool_sanitizer: Optional callable that can override sanitized values.
21
+
22
+ Returns:
23
+ tuple: Sanitized args and output payloads.
24
+ """
25
+
26
+ class ArgsFormatter:
27
+ """Simple formatter that surfaces at most two argument key/value pairs."""
28
+ def format(self, args: dict[str, JSONValue] | None) -> str | None:
29
+ """Format tool arguments into a short excerpt.
30
+
31
+ Args:
32
+ args: Tool arguments dictionary.
33
+
34
+ Returns:
35
+ str | None: Concise representation of up to two key/value pairs.
36
+ """
37
+
38
+ class OutputFormatter:
39
+ """Lightweight formatter that truncates serialized output."""
40
+ def format(self, output: JSONValue | None) -> str | None:
41
+ """Format tool output into a readable excerpt.
42
+
43
+ Args:
44
+ output: Raw tool output.
45
+
46
+ Returns:
47
+ str | None: Truncated representation suitable for logs.
48
+ """