aip-agents-binary 0.6.4__py3-none-any.whl → 0.6.5__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.
- aip_agents/agent/__init__.py +44 -4
- aip_agents/mcp/client/__init__.py +38 -2
- aip_agents/sentry/sentry.py +29 -8
- {aip_agents_binary-0.6.4.dist-info → aip_agents_binary-0.6.5.dist-info}/METADATA +1 -1
- {aip_agents_binary-0.6.4.dist-info → aip_agents_binary-0.6.5.dist-info}/RECORD +7 -305
- aip_agents/__init__.pyi +0 -19
- aip_agents/a2a/__init__.pyi +0 -3
- aip_agents/a2a/server/__init__.pyi +0 -4
- aip_agents/a2a/server/base_executor.pyi +0 -73
- aip_agents/a2a/server/google_adk_executor.pyi +0 -51
- aip_agents/a2a/server/langflow_executor.pyi +0 -43
- aip_agents/a2a/server/langgraph_executor.pyi +0 -47
- aip_agents/a2a/types.pyi +0 -132
- aip_agents/agent/__init__.pyi +0 -9
- aip_agents/agent/base_agent.pyi +0 -221
- aip_agents/agent/base_langgraph_agent.pyi +0 -233
- aip_agents/agent/google_adk_agent.pyi +0 -141
- aip_agents/agent/google_adk_constants.pyi +0 -3
- aip_agents/agent/hitl/__init__.pyi +0 -6
- aip_agents/agent/hitl/config.pyi +0 -15
- aip_agents/agent/hitl/langgraph_hitl_mixin.pyi +0 -42
- aip_agents/agent/hitl/manager.pyi +0 -200
- aip_agents/agent/hitl/models.pyi +0 -3
- aip_agents/agent/hitl/prompt/__init__.pyi +0 -4
- aip_agents/agent/hitl/prompt/base.pyi +0 -24
- aip_agents/agent/hitl/prompt/deferred.pyi +0 -30
- aip_agents/agent/hitl/registry.pyi +0 -101
- aip_agents/agent/interface.pyi +0 -81
- aip_agents/agent/interfaces.pyi +0 -44
- aip_agents/agent/langflow_agent.pyi +0 -133
- aip_agents/agent/langgraph_memory_enhancer_agent.pyi +0 -50
- aip_agents/agent/langgraph_react_agent.pyi +0 -170
- aip_agents/agent/system_instruction_context.pyi +0 -13
- aip_agents/clients/__init__.pyi +0 -4
- aip_agents/clients/langflow/__init__.pyi +0 -4
- aip_agents/clients/langflow/client.pyi +0 -140
- aip_agents/clients/langflow/types.pyi +0 -7
- aip_agents/constants.pyi +0 -7
- aip_agents/examples/__init__.pyi +0 -0
- aip_agents/examples/compare_streaming_client.pyi +0 -48
- aip_agents/examples/compare_streaming_server.pyi +0 -18
- aip_agents/examples/hello_world_a2a_google_adk_client.pyi +0 -9
- aip_agents/examples/hello_world_a2a_google_adk_client_agent.pyi +0 -9
- aip_agents/examples/hello_world_a2a_google_adk_client_streaming.pyi +0 -9
- aip_agents/examples/hello_world_a2a_google_adk_server.pyi +0 -15
- aip_agents/examples/hello_world_a2a_langchain_client.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langchain_client_agent.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langchain_client_lm_invoker.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langchain_client_streaming.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langchain_reference_client_streaming.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langchain_reference_server.pyi +0 -15
- aip_agents/examples/hello_world_a2a_langchain_server.pyi +0 -15
- aip_agents/examples/hello_world_a2a_langchain_server_lm_invoker.pyi +0 -15
- aip_agents/examples/hello_world_a2a_langflow_client.pyi +0 -9
- aip_agents/examples/hello_world_a2a_langflow_server.pyi +0 -14
- aip_agents/examples/hello_world_a2a_langgraph_artifact_client.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langgraph_artifact_client_streaming.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langgraph_artifact_server.pyi +0 -16
- aip_agents/examples/hello_world_a2a_langgraph_client.pyi +0 -9
- aip_agents/examples/hello_world_a2a_langgraph_client_agent.pyi +0 -9
- aip_agents/examples/hello_world_a2a_langgraph_client_agent_lm_invoker.pyi +0 -2
- aip_agents/examples/hello_world_a2a_langgraph_client_streaming.pyi +0 -9
- aip_agents/examples/hello_world_a2a_langgraph_client_streaming_lm_invoker.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langgraph_client_streaming_tool_streaming.pyi +0 -5
- aip_agents/examples/hello_world_a2a_langgraph_server.pyi +0 -14
- aip_agents/examples/hello_world_a2a_langgraph_server_lm_invoker.pyi +0 -15
- aip_agents/examples/hello_world_a2a_langgraph_server_tool_streaming.pyi +0 -15
- aip_agents/examples/hello_world_a2a_mcp_langgraph.pyi +0 -48
- aip_agents/examples/hello_world_a2a_three_level_agent_hierarchy_client.pyi +0 -48
- aip_agents/examples/hello_world_a2a_three_level_agent_hierarchy_server.pyi +0 -45
- aip_agents/examples/hello_world_a2a_with_metadata_langchain_client.pyi +0 -5
- aip_agents/examples/hello_world_a2a_with_metadata_langchain_server_lm_invoker.pyi +0 -15
- aip_agents/examples/hello_world_google_adk.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_http.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_http_stream.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_sse.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_sse_stream.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_stdio.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_mcp_stdio_stream.pyi +0 -5
- aip_agents/examples/hello_world_google_adk_stream.pyi +0 -5
- aip_agents/examples/hello_world_langchain.pyi +0 -5
- aip_agents/examples/hello_world_langchain_lm_invoker.pyi +0 -2
- aip_agents/examples/hello_world_langchain_mcp_http.pyi +0 -5
- aip_agents/examples/hello_world_langchain_mcp_http_interactive.pyi +0 -16
- aip_agents/examples/hello_world_langchain_mcp_http_stream.pyi +0 -5
- aip_agents/examples/hello_world_langchain_mcp_multi_server.pyi +0 -18
- aip_agents/examples/hello_world_langchain_mcp_sse.pyi +0 -5
- aip_agents/examples/hello_world_langchain_mcp_sse_stream.pyi +0 -5
- aip_agents/examples/hello_world_langchain_mcp_stdio.pyi +0 -5
- aip_agents/examples/hello_world_langchain_mcp_stdio_stream.pyi +0 -5
- aip_agents/examples/hello_world_langchain_stream.pyi +0 -5
- aip_agents/examples/hello_world_langchain_stream_lm_invoker.pyi +0 -5
- aip_agents/examples/hello_world_langflow_agent.pyi +0 -35
- aip_agents/examples/hello_world_langgraph.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_gl_connector_twitter.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_http.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_http_stream.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_sse.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_sse_stream.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_stdio.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_mcp_stdio_stream.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_stream.pyi +0 -5
- aip_agents/examples/hello_world_langgraph_stream_lm_invoker.pyi +0 -5
- aip_agents/examples/hello_world_model_switch_cli.pyi +0 -30
- aip_agents/examples/hello_world_multi_agent_adk.pyi +0 -6
- aip_agents/examples/hello_world_multi_agent_langchain.pyi +0 -5
- aip_agents/examples/hello_world_multi_agent_langgraph.pyi +0 -5
- aip_agents/examples/hello_world_multi_agent_langgraph_lm_invoker.pyi +0 -5
- aip_agents/examples/hello_world_pii_logger.pyi +0 -5
- aip_agents/examples/hello_world_ptc.pyi +0 -5
- aip_agents/examples/hello_world_sentry.pyi +0 -21
- aip_agents/examples/hello_world_step_limits.pyi +0 -17
- aip_agents/examples/hello_world_stock_a2a_server.pyi +0 -17
- aip_agents/examples/hello_world_tool_output_client.pyi +0 -5
- aip_agents/examples/hello_world_tool_output_server.pyi +0 -19
- aip_agents/examples/hitl_demo.pyi +0 -67
- aip_agents/examples/pii_demo_langgraph_client.pyi +0 -5
- aip_agents/examples/pii_demo_langgraph_server.pyi +0 -20
- aip_agents/examples/pii_demo_multi_agent_client.pyi +0 -5
- aip_agents/examples/pii_demo_multi_agent_server.pyi +0 -40
- aip_agents/examples/todolist_planning_a2a_langchain_client.pyi +0 -5
- aip_agents/examples/todolist_planning_a2a_langgraph_server.pyi +0 -19
- aip_agents/examples/tools/__init__.pyi +0 -9
- aip_agents/examples/tools/adk_arithmetic_tools.pyi +0 -24
- aip_agents/examples/tools/adk_weather_tool.pyi +0 -18
- aip_agents/examples/tools/data_generator_tool.pyi +0 -15
- aip_agents/examples/tools/data_visualization_tool.pyi +0 -19
- aip_agents/examples/tools/image_artifact_tool.pyi +0 -26
- aip_agents/examples/tools/langchain_arithmetic_tools.pyi +0 -17
- aip_agents/examples/tools/langchain_currency_exchange_tool.pyi +0 -20
- aip_agents/examples/tools/langchain_graph_artifact_tool.pyi +0 -25
- aip_agents/examples/tools/langchain_weather_tool.pyi +0 -19
- aip_agents/examples/tools/langgraph_streaming_tool.pyi +0 -43
- aip_agents/examples/tools/mock_retrieval_tool.pyi +0 -13
- aip_agents/examples/tools/pii_demo_tools.pyi +0 -54
- aip_agents/examples/tools/random_chart_tool.pyi +0 -20
- aip_agents/examples/tools/serper_tool.pyi +0 -16
- aip_agents/examples/tools/stock_tools.pyi +0 -36
- aip_agents/examples/tools/table_generator_tool.pyi +0 -22
- aip_agents/examples/tools/time_tool.pyi +0 -15
- aip_agents/examples/tools/weather_forecast_tool.pyi +0 -14
- aip_agents/guardrails/__init__.pyi +0 -6
- aip_agents/guardrails/engines/__init__.pyi +0 -4
- aip_agents/guardrails/engines/base.pyi +0 -61
- aip_agents/guardrails/engines/nemo.pyi +0 -46
- aip_agents/guardrails/engines/phrase_matcher.pyi +0 -48
- aip_agents/guardrails/exceptions.pyi +0 -23
- aip_agents/guardrails/manager.pyi +0 -42
- aip_agents/guardrails/middleware.pyi +0 -87
- aip_agents/guardrails/schemas.pyi +0 -43
- aip_agents/guardrails/utils.pyi +0 -19
- aip_agents/mcp/__init__.pyi +0 -0
- aip_agents/mcp/client/__init__.pyi +0 -5
- aip_agents/mcp/client/base_mcp_client.pyi +0 -148
- aip_agents/mcp/client/connection_manager.pyi +0 -51
- aip_agents/mcp/client/google_adk/__init__.pyi +0 -3
- aip_agents/mcp/client/google_adk/client.pyi +0 -75
- aip_agents/mcp/client/langchain/__init__.pyi +0 -3
- aip_agents/mcp/client/langchain/client.pyi +0 -48
- aip_agents/mcp/client/persistent_session.pyi +0 -122
- aip_agents/mcp/client/session_pool.pyi +0 -101
- aip_agents/mcp/client/transports.pyi +0 -132
- aip_agents/mcp/utils/__init__.pyi +0 -0
- aip_agents/mcp/utils/config_validator.pyi +0 -82
- aip_agents/memory/__init__.pyi +0 -5
- aip_agents/memory/adapters/__init__.pyi +0 -4
- aip_agents/memory/adapters/base_adapter.pyi +0 -176
- aip_agents/memory/adapters/mem0.pyi +0 -22
- aip_agents/memory/base.pyi +0 -60
- aip_agents/memory/constants.pyi +0 -25
- aip_agents/memory/factory.pyi +0 -24
- aip_agents/memory/guidance.pyi +0 -3
- aip_agents/memory/simple_memory.pyi +0 -23
- aip_agents/middleware/__init__.pyi +0 -5
- aip_agents/middleware/base.pyi +0 -75
- aip_agents/middleware/manager.pyi +0 -84
- aip_agents/middleware/todolist.pyi +0 -125
- aip_agents/ptc/__init__.pyi +0 -10
- aip_agents/ptc/doc_gen.pyi +0 -40
- aip_agents/ptc/exceptions.pyi +0 -22
- aip_agents/ptc/executor.pyi +0 -73
- aip_agents/ptc/mcp/__init__.pyi +0 -7
- aip_agents/ptc/mcp/sandbox_bridge.pyi +0 -47
- aip_agents/ptc/mcp/templates/__init__.pyi +0 -0
- aip_agents/ptc/naming.pyi +0 -76
- aip_agents/ptc/payload.pyi +0 -15
- aip_agents/ptc/prompt_builder.pyi +0 -55
- aip_agents/ptc/ptc_helper.pyi +0 -1
- aip_agents/ptc/sandbox_bridge.pyi +0 -25
- aip_agents/ptc/template_utils.pyi +0 -13
- aip_agents/ptc/templates/__init__.pyi +0 -0
- aip_agents/sandbox/__init__.pyi +0 -5
- aip_agents/sandbox/defaults.pyi +0 -2
- aip_agents/sandbox/e2b_runtime.pyi +0 -51
- aip_agents/sandbox/template_builder.pyi +0 -36
- aip_agents/sandbox/types.pyi +0 -14
- aip_agents/sandbox/validation.pyi +0 -20
- aip_agents/schema/__init__.pyi +0 -9
- aip_agents/schema/a2a.pyi +0 -40
- aip_agents/schema/agent.pyi +0 -65
- aip_agents/schema/hitl.pyi +0 -89
- aip_agents/schema/langgraph.pyi +0 -28
- aip_agents/schema/model_id.pyi +0 -54
- aip_agents/schema/step_limit.pyi +0 -63
- aip_agents/schema/storage.pyi +0 -21
- aip_agents/sentry/__init__.pyi +0 -3
- aip_agents/sentry/sentry.pyi +0 -48
- aip_agents/storage/__init__.pyi +0 -8
- aip_agents/storage/base.pyi +0 -58
- aip_agents/storage/clients/__init__.pyi +0 -3
- aip_agents/storage/clients/minio_client.pyi +0 -137
- aip_agents/storage/config.pyi +0 -29
- aip_agents/storage/providers/__init__.pyi +0 -5
- aip_agents/storage/providers/base.pyi +0 -88
- aip_agents/storage/providers/memory.pyi +0 -79
- aip_agents/storage/providers/object_storage.pyi +0 -98
- aip_agents/tools/__init__.pyi +0 -11
- aip_agents/tools/browser_use/__init__.pyi +0 -14
- aip_agents/tools/browser_use/action_parser.pyi +0 -18
- aip_agents/tools/browser_use/browser_use_tool.pyi +0 -50
- aip_agents/tools/browser_use/llm_config.pyi +0 -52
- aip_agents/tools/browser_use/minio_storage.pyi +0 -109
- aip_agents/tools/browser_use/schemas.pyi +0 -32
- aip_agents/tools/browser_use/session.pyi +0 -4
- aip_agents/tools/browser_use/session_errors.pyi +0 -53
- aip_agents/tools/browser_use/steel_session_recording.pyi +0 -63
- aip_agents/tools/browser_use/streaming.pyi +0 -81
- aip_agents/tools/browser_use/structured_data_parser.pyi +0 -86
- aip_agents/tools/browser_use/structured_data_recovery.pyi +0 -43
- aip_agents/tools/browser_use/types.pyi +0 -45
- aip_agents/tools/code_sandbox/__init__.pyi +0 -3
- aip_agents/tools/code_sandbox/constant.pyi +0 -4
- aip_agents/tools/code_sandbox/e2b_cloud_sandbox_extended.pyi +0 -102
- aip_agents/tools/code_sandbox/e2b_sandbox_tool.pyi +0 -29
- aip_agents/tools/constants.pyi +0 -138
- aip_agents/tools/date_range_tool.pyi +0 -21
- aip_agents/tools/document_loader/__init__.pyi +0 -7
- aip_agents/tools/document_loader/base_reader.pyi +0 -75
- aip_agents/tools/document_loader/docx_reader_tool.pyi +0 -10
- aip_agents/tools/document_loader/excel_reader_tool.pyi +0 -26
- aip_agents/tools/document_loader/pdf_reader_tool.pyi +0 -11
- aip_agents/tools/document_loader/pdf_splitter.pyi +0 -18
- aip_agents/tools/execute_ptc_code.pyi +0 -90
- aip_agents/tools/gl_connector/__init__.pyi +0 -3
- aip_agents/tools/gl_connector/tool.pyi +0 -74
- aip_agents/tools/gl_connector_tools.pyi +0 -39
- aip_agents/tools/memory_search/__init__.pyi +0 -5
- aip_agents/tools/memory_search/base.pyi +0 -69
- aip_agents/tools/memory_search/mem0.pyi +0 -29
- aip_agents/tools/memory_search/schema.pyi +0 -25
- aip_agents/tools/memory_search_tool.pyi +0 -3
- aip_agents/tools/time_tool.pyi +0 -16
- aip_agents/tools/tool_config_injector.pyi +0 -26
- aip_agents/tools/web_search/__init__.pyi +0 -3
- aip_agents/tools/web_search/serper_tool.pyi +0 -19
- aip_agents/types/__init__.pyi +0 -36
- aip_agents/types/a2a_events.pyi +0 -3
- aip_agents/utils/__init__.pyi +0 -11
- aip_agents/utils/a2a_connector.pyi +0 -146
- aip_agents/utils/artifact_helpers.pyi +0 -203
- aip_agents/utils/constants.pyi +0 -10
- aip_agents/utils/datetime/__init__.pyi +0 -4
- aip_agents/utils/datetime/normalization.pyi +0 -95
- aip_agents/utils/datetime/timezone.pyi +0 -48
- aip_agents/utils/env_loader.pyi +0 -10
- aip_agents/utils/event_handler_registry.pyi +0 -23
- aip_agents/utils/file_prompt_utils.pyi +0 -21
- aip_agents/utils/final_response_builder.pyi +0 -34
- aip_agents/utils/formatter_llm_client.pyi +0 -71
- aip_agents/utils/langgraph/__init__.pyi +0 -3
- aip_agents/utils/langgraph/converter.pyi +0 -49
- aip_agents/utils/langgraph/tool_managers/__init__.pyi +0 -5
- aip_agents/utils/langgraph/tool_managers/a2a_tool_manager.pyi +0 -35
- aip_agents/utils/langgraph/tool_managers/base_tool_manager.pyi +0 -48
- aip_agents/utils/langgraph/tool_managers/delegation_tool_manager.pyi +0 -56
- aip_agents/utils/langgraph/tool_output_management.pyi +0 -329
- aip_agents/utils/logger.pyi +0 -60
- aip_agents/utils/metadata/__init__.pyi +0 -5
- aip_agents/utils/metadata/activity_metadata_helper.pyi +0 -25
- aip_agents/utils/metadata/activity_narrative/__init__.pyi +0 -7
- aip_agents/utils/metadata/activity_narrative/builder.pyi +0 -35
- aip_agents/utils/metadata/activity_narrative/constants.pyi +0 -10
- aip_agents/utils/metadata/activity_narrative/context.pyi +0 -32
- aip_agents/utils/metadata/activity_narrative/formatters.pyi +0 -48
- aip_agents/utils/metadata/activity_narrative/utils.pyi +0 -12
- aip_agents/utils/metadata/schemas/__init__.pyi +0 -4
- aip_agents/utils/metadata/schemas/activity_schema.pyi +0 -18
- aip_agents/utils/metadata/schemas/thinking_schema.pyi +0 -20
- aip_agents/utils/metadata/thinking_metadata_helper.pyi +0 -4
- aip_agents/utils/metadata_helper.pyi +0 -117
- aip_agents/utils/name_preprocessor/__init__.pyi +0 -6
- aip_agents/utils/name_preprocessor/base_name_preprocessor.pyi +0 -52
- aip_agents/utils/name_preprocessor/google_name_preprocessor.pyi +0 -38
- aip_agents/utils/name_preprocessor/name_preprocessor.pyi +0 -41
- aip_agents/utils/name_preprocessor/openai_name_preprocessor.pyi +0 -34
- aip_agents/utils/pii/__init__.pyi +0 -5
- aip_agents/utils/pii/pii_handler.pyi +0 -96
- aip_agents/utils/pii/pii_helper.pyi +0 -78
- aip_agents/utils/pii/uuid_deanonymizer_mapping.pyi +0 -73
- aip_agents/utils/reference_helper.pyi +0 -81
- aip_agents/utils/sse_chunk_transformer.pyi +0 -166
- aip_agents/utils/step_limit_manager.pyi +0 -112
- aip_agents/utils/token_usage_helper.pyi +0 -60
- {aip_agents_binary-0.6.4.dist-info → aip_agents_binary-0.6.5.dist-info}/WHEEL +0 -0
- {aip_agents_binary-0.6.4.dist-info → aip_agents_binary-0.6.5.dist-info}/top_level.txt +0 -0
|
@@ -1,329 +0,0 @@
|
|
|
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
|
-
"""
|
aip_agents/utils/logger.pyi
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
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
|
-
"""
|
|
@@ -1,5 +0,0 @@
|
|
|
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']
|
|
@@ -1,25 +0,0 @@
|
|
|
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
|
-
'''
|
|
@@ -1,7 +0,0 @@
|
|
|
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']
|
|
@@ -1,35 +0,0 @@
|
|
|
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
|
-
"""
|
|
@@ -1,10 +0,0 @@
|
|
|
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]]
|
|
@@ -1,32 +0,0 @@
|
|
|
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 = ...
|
|
@@ -1,48 +0,0 @@
|
|
|
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
|
-
"""
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
__all__ = ['_format_tool_or_subagent_name']
|
|
2
|
-
|
|
3
|
-
def _format_tool_or_subagent_name(name: str, remove_delegate_prefix: bool = False) -> str:
|
|
4
|
-
"""Format tool/agent names to 'Camel Case' consistently.
|
|
5
|
-
|
|
6
|
-
Args:
|
|
7
|
-
name: Raw tool or sub-agent identifier.
|
|
8
|
-
remove_delegate_prefix: Whether to strip the ``delegate::`` prefix before formatting.
|
|
9
|
-
|
|
10
|
-
Returns:
|
|
11
|
-
str: Display-friendly tool or agent name.
|
|
12
|
-
"""
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
from enum import StrEnum
|
|
2
|
-
from pydantic import BaseModel
|
|
3
|
-
|
|
4
|
-
class ActivityDataType(StrEnum):
|
|
5
|
-
"""Enumeration of activity data types."""
|
|
6
|
-
ACTIVITY: str
|
|
7
|
-
|
|
8
|
-
class Activity(BaseModel):
|
|
9
|
-
'''Schema for activity info payload.
|
|
10
|
-
|
|
11
|
-
Fields:
|
|
12
|
-
- data_type: always "activity"
|
|
13
|
-
- id: UUID string identifying this activity event
|
|
14
|
-
- data_value: JSON string with additional info (e.g., {"message": "..."})
|
|
15
|
-
'''
|
|
16
|
-
data_type: ActivityDataType
|
|
17
|
-
id: str
|
|
18
|
-
data_value: str
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
from enum import StrEnum
|
|
2
|
-
from pydantic import BaseModel
|
|
3
|
-
|
|
4
|
-
class ThinkingDataType(StrEnum):
|
|
5
|
-
"""Enum for thinking data types."""
|
|
6
|
-
THINKING: str
|
|
7
|
-
THINKING_START: str
|
|
8
|
-
THINKING_END: str
|
|
9
|
-
|
|
10
|
-
class Thinking(BaseModel):
|
|
11
|
-
'''Schema for thinking info payload.
|
|
12
|
-
|
|
13
|
-
Fields:
|
|
14
|
-
- data_type: type of thinking event
|
|
15
|
-
- id: UUID string identifying this thinking event
|
|
16
|
-
- data_value: JSON string with additional info (e.g., {"message": "..."})
|
|
17
|
-
'''
|
|
18
|
-
data_type: ThinkingDataType
|
|
19
|
-
id: str
|
|
20
|
-
data_value: str
|