ag2 0.9.1a1__py3-none-any.whl → 0.9.2__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.
Potentially problematic release.
This version of ag2 might be problematic. Click here for more details.
- {ag2-0.9.1a1.dist-info → ag2-0.9.2.dist-info}/METADATA +272 -75
- ag2-0.9.2.dist-info/RECORD +406 -0
- {ag2-0.9.1a1.dist-info → ag2-0.9.2.dist-info}/WHEEL +1 -2
- autogen/__init__.py +89 -0
- autogen/_website/__init__.py +3 -0
- autogen/_website/generate_api_references.py +427 -0
- autogen/_website/generate_mkdocs.py +1174 -0
- autogen/_website/notebook_processor.py +476 -0
- autogen/_website/process_notebooks.py +656 -0
- autogen/_website/utils.py +412 -0
- autogen/agentchat/__init__.py +44 -0
- autogen/agentchat/agent.py +182 -0
- autogen/agentchat/assistant_agent.py +85 -0
- autogen/agentchat/chat.py +309 -0
- autogen/agentchat/contrib/__init__.py +5 -0
- autogen/agentchat/contrib/agent_eval/README.md +7 -0
- autogen/agentchat/contrib/agent_eval/agent_eval.py +108 -0
- autogen/agentchat/contrib/agent_eval/criterion.py +43 -0
- autogen/agentchat/contrib/agent_eval/critic_agent.py +44 -0
- autogen/agentchat/contrib/agent_eval/quantifier_agent.py +39 -0
- autogen/agentchat/contrib/agent_eval/subcritic_agent.py +45 -0
- autogen/agentchat/contrib/agent_eval/task.py +42 -0
- autogen/agentchat/contrib/agent_optimizer.py +429 -0
- autogen/agentchat/contrib/capabilities/__init__.py +5 -0
- autogen/agentchat/contrib/capabilities/agent_capability.py +20 -0
- autogen/agentchat/contrib/capabilities/generate_images.py +301 -0
- autogen/agentchat/contrib/capabilities/teachability.py +393 -0
- autogen/agentchat/contrib/capabilities/text_compressors.py +66 -0
- autogen/agentchat/contrib/capabilities/tools_capability.py +22 -0
- autogen/agentchat/contrib/capabilities/transform_messages.py +93 -0
- autogen/agentchat/contrib/capabilities/transforms.py +566 -0
- autogen/agentchat/contrib/capabilities/transforms_util.py +122 -0
- autogen/agentchat/contrib/capabilities/vision_capability.py +214 -0
- autogen/agentchat/contrib/captainagent/__init__.py +9 -0
- autogen/agentchat/contrib/captainagent/agent_builder.py +790 -0
- autogen/agentchat/contrib/captainagent/captainagent.py +512 -0
- autogen/agentchat/contrib/captainagent/tool_retriever.py +335 -0
- autogen/agentchat/contrib/captainagent/tools/README.md +44 -0
- autogen/agentchat/contrib/captainagent/tools/__init__.py +5 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/calculate_correlation.py +40 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/calculate_skewness_and_kurtosis.py +28 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/detect_outlier_iqr.py +28 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/detect_outlier_zscore.py +28 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/explore_csv.py +21 -0
- autogen/agentchat/contrib/captainagent/tools/data_analysis/shapiro_wilk_test.py +30 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/arxiv_download.py +27 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/arxiv_search.py +53 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/extract_pdf_image.py +53 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/extract_pdf_text.py +38 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/get_wikipedia_text.py +21 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/get_youtube_caption.py +34 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/image_qa.py +60 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/optical_character_recognition.py +61 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/perform_web_search.py +47 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/scrape_wikipedia_tables.py +33 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/transcribe_audio_file.py +21 -0
- autogen/agentchat/contrib/captainagent/tools/information_retrieval/youtube_download.py +35 -0
- autogen/agentchat/contrib/captainagent/tools/math/calculate_circle_area_from_diameter.py +21 -0
- autogen/agentchat/contrib/captainagent/tools/math/calculate_day_of_the_week.py +18 -0
- autogen/agentchat/contrib/captainagent/tools/math/calculate_fraction_sum.py +28 -0
- autogen/agentchat/contrib/captainagent/tools/math/calculate_matrix_power.py +31 -0
- autogen/agentchat/contrib/captainagent/tools/math/calculate_reflected_point.py +16 -0
- autogen/agentchat/contrib/captainagent/tools/math/complex_numbers_product.py +25 -0
- autogen/agentchat/contrib/captainagent/tools/math/compute_currency_conversion.py +23 -0
- autogen/agentchat/contrib/captainagent/tools/math/count_distinct_permutations.py +27 -0
- autogen/agentchat/contrib/captainagent/tools/math/evaluate_expression.py +28 -0
- autogen/agentchat/contrib/captainagent/tools/math/find_continuity_point.py +34 -0
- autogen/agentchat/contrib/captainagent/tools/math/fraction_to_mixed_numbers.py +39 -0
- autogen/agentchat/contrib/captainagent/tools/math/modular_inverse_sum.py +23 -0
- autogen/agentchat/contrib/captainagent/tools/math/simplify_mixed_numbers.py +36 -0
- autogen/agentchat/contrib/captainagent/tools/math/sum_of_digit_factorials.py +15 -0
- autogen/agentchat/contrib/captainagent/tools/math/sum_of_primes_below.py +15 -0
- autogen/agentchat/contrib/captainagent/tools/requirements.txt +10 -0
- autogen/agentchat/contrib/captainagent/tools/tool_description.tsv +34 -0
- autogen/agentchat/contrib/gpt_assistant_agent.py +526 -0
- autogen/agentchat/contrib/graph_rag/__init__.py +9 -0
- autogen/agentchat/contrib/graph_rag/document.py +29 -0
- autogen/agentchat/contrib/graph_rag/falkor_graph_query_engine.py +170 -0
- autogen/agentchat/contrib/graph_rag/falkor_graph_rag_capability.py +103 -0
- autogen/agentchat/contrib/graph_rag/graph_query_engine.py +53 -0
- autogen/agentchat/contrib/graph_rag/graph_rag_capability.py +63 -0
- autogen/agentchat/contrib/graph_rag/neo4j_graph_query_engine.py +268 -0
- autogen/agentchat/contrib/graph_rag/neo4j_graph_rag_capability.py +83 -0
- autogen/agentchat/contrib/graph_rag/neo4j_native_graph_query_engine.py +210 -0
- autogen/agentchat/contrib/graph_rag/neo4j_native_graph_rag_capability.py +93 -0
- autogen/agentchat/contrib/img_utils.py +397 -0
- autogen/agentchat/contrib/llamaindex_conversable_agent.py +117 -0
- autogen/agentchat/contrib/llava_agent.py +187 -0
- autogen/agentchat/contrib/math_user_proxy_agent.py +464 -0
- autogen/agentchat/contrib/multimodal_conversable_agent.py +125 -0
- autogen/agentchat/contrib/qdrant_retrieve_user_proxy_agent.py +324 -0
- autogen/agentchat/contrib/rag/__init__.py +10 -0
- autogen/agentchat/contrib/rag/chromadb_query_engine.py +272 -0
- autogen/agentchat/contrib/rag/llamaindex_query_engine.py +198 -0
- autogen/agentchat/contrib/rag/mongodb_query_engine.py +329 -0
- autogen/agentchat/contrib/rag/query_engine.py +74 -0
- autogen/agentchat/contrib/retrieve_assistant_agent.py +56 -0
- autogen/agentchat/contrib/retrieve_user_proxy_agent.py +703 -0
- autogen/agentchat/contrib/society_of_mind_agent.py +199 -0
- autogen/agentchat/contrib/swarm_agent.py +1425 -0
- autogen/agentchat/contrib/text_analyzer_agent.py +79 -0
- autogen/agentchat/contrib/vectordb/__init__.py +5 -0
- autogen/agentchat/contrib/vectordb/base.py +232 -0
- autogen/agentchat/contrib/vectordb/chromadb.py +315 -0
- autogen/agentchat/contrib/vectordb/couchbase.py +407 -0
- autogen/agentchat/contrib/vectordb/mongodb.py +550 -0
- autogen/agentchat/contrib/vectordb/pgvectordb.py +928 -0
- autogen/agentchat/contrib/vectordb/qdrant.py +320 -0
- autogen/agentchat/contrib/vectordb/utils.py +126 -0
- autogen/agentchat/contrib/web_surfer.py +303 -0
- autogen/agentchat/conversable_agent.py +4023 -0
- autogen/agentchat/group/__init__.py +64 -0
- autogen/agentchat/group/available_condition.py +91 -0
- autogen/agentchat/group/context_condition.py +77 -0
- autogen/agentchat/group/context_expression.py +238 -0
- autogen/agentchat/group/context_str.py +41 -0
- autogen/agentchat/group/context_variables.py +192 -0
- autogen/agentchat/group/group_tool_executor.py +202 -0
- autogen/agentchat/group/group_utils.py +591 -0
- autogen/agentchat/group/handoffs.py +244 -0
- autogen/agentchat/group/llm_condition.py +93 -0
- autogen/agentchat/group/multi_agent_chat.py +237 -0
- autogen/agentchat/group/on_condition.py +58 -0
- autogen/agentchat/group/on_context_condition.py +54 -0
- autogen/agentchat/group/patterns/__init__.py +18 -0
- autogen/agentchat/group/patterns/auto.py +159 -0
- autogen/agentchat/group/patterns/manual.py +176 -0
- autogen/agentchat/group/patterns/pattern.py +288 -0
- autogen/agentchat/group/patterns/random.py +106 -0
- autogen/agentchat/group/patterns/round_robin.py +117 -0
- autogen/agentchat/group/reply_result.py +26 -0
- autogen/agentchat/group/speaker_selection_result.py +41 -0
- autogen/agentchat/group/targets/__init__.py +4 -0
- autogen/agentchat/group/targets/group_chat_target.py +132 -0
- autogen/agentchat/group/targets/group_manager_target.py +151 -0
- autogen/agentchat/group/targets/transition_target.py +413 -0
- autogen/agentchat/group/targets/transition_utils.py +6 -0
- autogen/agentchat/groupchat.py +1694 -0
- autogen/agentchat/realtime/__init__.py +3 -0
- autogen/agentchat/realtime/experimental/__init__.py +20 -0
- autogen/agentchat/realtime/experimental/audio_adapters/__init__.py +8 -0
- autogen/agentchat/realtime/experimental/audio_adapters/twilio_audio_adapter.py +148 -0
- autogen/agentchat/realtime/experimental/audio_adapters/websocket_audio_adapter.py +139 -0
- autogen/agentchat/realtime/experimental/audio_observer.py +42 -0
- autogen/agentchat/realtime/experimental/clients/__init__.py +15 -0
- autogen/agentchat/realtime/experimental/clients/gemini/__init__.py +7 -0
- autogen/agentchat/realtime/experimental/clients/gemini/client.py +274 -0
- autogen/agentchat/realtime/experimental/clients/oai/__init__.py +8 -0
- autogen/agentchat/realtime/experimental/clients/oai/base_client.py +220 -0
- autogen/agentchat/realtime/experimental/clients/oai/rtc_client.py +243 -0
- autogen/agentchat/realtime/experimental/clients/oai/utils.py +48 -0
- autogen/agentchat/realtime/experimental/clients/realtime_client.py +190 -0
- autogen/agentchat/realtime/experimental/function_observer.py +85 -0
- autogen/agentchat/realtime/experimental/realtime_agent.py +158 -0
- autogen/agentchat/realtime/experimental/realtime_events.py +42 -0
- autogen/agentchat/realtime/experimental/realtime_observer.py +100 -0
- autogen/agentchat/realtime/experimental/realtime_swarm.py +475 -0
- autogen/agentchat/realtime/experimental/websockets.py +21 -0
- autogen/agentchat/realtime_agent/__init__.py +21 -0
- autogen/agentchat/user_proxy_agent.py +111 -0
- autogen/agentchat/utils.py +206 -0
- autogen/agents/__init__.py +3 -0
- autogen/agents/contrib/__init__.py +10 -0
- autogen/agents/contrib/time/__init__.py +8 -0
- autogen/agents/contrib/time/time_reply_agent.py +73 -0
- autogen/agents/contrib/time/time_tool_agent.py +51 -0
- autogen/agents/experimental/__init__.py +27 -0
- autogen/agents/experimental/deep_research/__init__.py +7 -0
- autogen/agents/experimental/deep_research/deep_research.py +52 -0
- autogen/agents/experimental/discord/__init__.py +7 -0
- autogen/agents/experimental/discord/discord.py +66 -0
- autogen/agents/experimental/document_agent/__init__.py +19 -0
- autogen/agents/experimental/document_agent/chroma_query_engine.py +316 -0
- autogen/agents/experimental/document_agent/docling_doc_ingest_agent.py +118 -0
- autogen/agents/experimental/document_agent/document_agent.py +461 -0
- autogen/agents/experimental/document_agent/document_conditions.py +50 -0
- autogen/agents/experimental/document_agent/document_utils.py +380 -0
- autogen/agents/experimental/document_agent/inmemory_query_engine.py +220 -0
- autogen/agents/experimental/document_agent/parser_utils.py +130 -0
- autogen/agents/experimental/document_agent/url_utils.py +426 -0
- autogen/agents/experimental/reasoning/__init__.py +7 -0
- autogen/agents/experimental/reasoning/reasoning_agent.py +1178 -0
- autogen/agents/experimental/slack/__init__.py +7 -0
- autogen/agents/experimental/slack/slack.py +73 -0
- autogen/agents/experimental/telegram/__init__.py +7 -0
- autogen/agents/experimental/telegram/telegram.py +77 -0
- autogen/agents/experimental/websurfer/__init__.py +7 -0
- autogen/agents/experimental/websurfer/websurfer.py +62 -0
- autogen/agents/experimental/wikipedia/__init__.py +7 -0
- autogen/agents/experimental/wikipedia/wikipedia.py +90 -0
- autogen/browser_utils.py +309 -0
- autogen/cache/__init__.py +10 -0
- autogen/cache/abstract_cache_base.py +75 -0
- autogen/cache/cache.py +203 -0
- autogen/cache/cache_factory.py +88 -0
- autogen/cache/cosmos_db_cache.py +144 -0
- autogen/cache/disk_cache.py +102 -0
- autogen/cache/in_memory_cache.py +58 -0
- autogen/cache/redis_cache.py +123 -0
- autogen/code_utils.py +596 -0
- autogen/coding/__init__.py +22 -0
- autogen/coding/base.py +119 -0
- autogen/coding/docker_commandline_code_executor.py +268 -0
- autogen/coding/factory.py +47 -0
- autogen/coding/func_with_reqs.py +202 -0
- autogen/coding/jupyter/__init__.py +23 -0
- autogen/coding/jupyter/base.py +36 -0
- autogen/coding/jupyter/docker_jupyter_server.py +167 -0
- autogen/coding/jupyter/embedded_ipython_code_executor.py +182 -0
- autogen/coding/jupyter/import_utils.py +82 -0
- autogen/coding/jupyter/jupyter_client.py +231 -0
- autogen/coding/jupyter/jupyter_code_executor.py +160 -0
- autogen/coding/jupyter/local_jupyter_server.py +172 -0
- autogen/coding/local_commandline_code_executor.py +405 -0
- autogen/coding/markdown_code_extractor.py +45 -0
- autogen/coding/utils.py +56 -0
- autogen/doc_utils.py +34 -0
- autogen/events/__init__.py +7 -0
- autogen/events/agent_events.py +1013 -0
- autogen/events/base_event.py +99 -0
- autogen/events/client_events.py +167 -0
- autogen/events/helpers.py +36 -0
- autogen/events/print_event.py +46 -0
- autogen/exception_utils.py +73 -0
- autogen/extensions/__init__.py +5 -0
- autogen/fast_depends/__init__.py +16 -0
- autogen/fast_depends/_compat.py +80 -0
- autogen/fast_depends/core/__init__.py +14 -0
- autogen/fast_depends/core/build.py +225 -0
- autogen/fast_depends/core/model.py +576 -0
- autogen/fast_depends/dependencies/__init__.py +15 -0
- autogen/fast_depends/dependencies/model.py +29 -0
- autogen/fast_depends/dependencies/provider.py +39 -0
- autogen/fast_depends/library/__init__.py +10 -0
- autogen/fast_depends/library/model.py +46 -0
- autogen/fast_depends/py.typed +6 -0
- autogen/fast_depends/schema.py +66 -0
- autogen/fast_depends/use.py +280 -0
- autogen/fast_depends/utils.py +187 -0
- autogen/formatting_utils.py +83 -0
- autogen/function_utils.py +13 -0
- autogen/graph_utils.py +178 -0
- autogen/import_utils.py +526 -0
- autogen/interop/__init__.py +22 -0
- autogen/interop/crewai/__init__.py +7 -0
- autogen/interop/crewai/crewai.py +88 -0
- autogen/interop/interoperability.py +71 -0
- autogen/interop/interoperable.py +46 -0
- autogen/interop/langchain/__init__.py +8 -0
- autogen/interop/langchain/langchain_chat_model_factory.py +155 -0
- autogen/interop/langchain/langchain_tool.py +82 -0
- autogen/interop/litellm/__init__.py +7 -0
- autogen/interop/litellm/litellm_config_factory.py +179 -0
- autogen/interop/pydantic_ai/__init__.py +7 -0
- autogen/interop/pydantic_ai/pydantic_ai.py +168 -0
- autogen/interop/registry.py +69 -0
- autogen/io/__init__.py +15 -0
- autogen/io/base.py +151 -0
- autogen/io/console.py +56 -0
- autogen/io/processors/__init__.py +12 -0
- autogen/io/processors/base.py +21 -0
- autogen/io/processors/console_event_processor.py +56 -0
- autogen/io/run_response.py +293 -0
- autogen/io/thread_io_stream.py +63 -0
- autogen/io/websockets.py +213 -0
- autogen/json_utils.py +43 -0
- autogen/llm_config.py +382 -0
- autogen/logger/__init__.py +11 -0
- autogen/logger/base_logger.py +128 -0
- autogen/logger/file_logger.py +261 -0
- autogen/logger/logger_factory.py +42 -0
- autogen/logger/logger_utils.py +57 -0
- autogen/logger/sqlite_logger.py +523 -0
- autogen/math_utils.py +339 -0
- autogen/mcp/__init__.py +7 -0
- autogen/mcp/__main__.py +78 -0
- autogen/mcp/mcp_client.py +208 -0
- autogen/mcp/mcp_proxy/__init__.py +19 -0
- autogen/mcp/mcp_proxy/fastapi_code_generator_helpers.py +63 -0
- autogen/mcp/mcp_proxy/mcp_proxy.py +581 -0
- autogen/mcp/mcp_proxy/operation_grouping.py +158 -0
- autogen/mcp/mcp_proxy/operation_renaming.py +114 -0
- autogen/mcp/mcp_proxy/patch_fastapi_code_generator.py +98 -0
- autogen/mcp/mcp_proxy/security.py +400 -0
- autogen/mcp/mcp_proxy/security_schema_visitor.py +37 -0
- autogen/messages/__init__.py +7 -0
- autogen/messages/agent_messages.py +948 -0
- autogen/messages/base_message.py +107 -0
- autogen/messages/client_messages.py +171 -0
- autogen/messages/print_message.py +49 -0
- autogen/oai/__init__.py +53 -0
- autogen/oai/anthropic.py +714 -0
- autogen/oai/bedrock.py +628 -0
- autogen/oai/cerebras.py +299 -0
- autogen/oai/client.py +1444 -0
- autogen/oai/client_utils.py +169 -0
- autogen/oai/cohere.py +479 -0
- autogen/oai/gemini.py +998 -0
- autogen/oai/gemini_types.py +155 -0
- autogen/oai/groq.py +305 -0
- autogen/oai/mistral.py +303 -0
- autogen/oai/oai_models/__init__.py +11 -0
- autogen/oai/oai_models/_models.py +16 -0
- autogen/oai/oai_models/chat_completion.py +87 -0
- autogen/oai/oai_models/chat_completion_audio.py +32 -0
- autogen/oai/oai_models/chat_completion_message.py +86 -0
- autogen/oai/oai_models/chat_completion_message_tool_call.py +37 -0
- autogen/oai/oai_models/chat_completion_token_logprob.py +63 -0
- autogen/oai/oai_models/completion_usage.py +60 -0
- autogen/oai/ollama.py +643 -0
- autogen/oai/openai_utils.py +881 -0
- autogen/oai/together.py +370 -0
- autogen/retrieve_utils.py +491 -0
- autogen/runtime_logging.py +160 -0
- autogen/token_count_utils.py +267 -0
- autogen/tools/__init__.py +20 -0
- autogen/tools/contrib/__init__.py +9 -0
- autogen/tools/contrib/time/__init__.py +7 -0
- autogen/tools/contrib/time/time.py +41 -0
- autogen/tools/dependency_injection.py +254 -0
- autogen/tools/experimental/__init__.py +48 -0
- autogen/tools/experimental/browser_use/__init__.py +7 -0
- autogen/tools/experimental/browser_use/browser_use.py +161 -0
- autogen/tools/experimental/crawl4ai/__init__.py +7 -0
- autogen/tools/experimental/crawl4ai/crawl4ai.py +153 -0
- autogen/tools/experimental/deep_research/__init__.py +7 -0
- autogen/tools/experimental/deep_research/deep_research.py +328 -0
- autogen/tools/experimental/duckduckgo/__init__.py +7 -0
- autogen/tools/experimental/duckduckgo/duckduckgo_search.py +109 -0
- autogen/tools/experimental/google/__init__.py +14 -0
- autogen/tools/experimental/google/authentication/__init__.py +11 -0
- autogen/tools/experimental/google/authentication/credentials_hosted_provider.py +43 -0
- autogen/tools/experimental/google/authentication/credentials_local_provider.py +91 -0
- autogen/tools/experimental/google/authentication/credentials_provider.py +35 -0
- autogen/tools/experimental/google/drive/__init__.py +9 -0
- autogen/tools/experimental/google/drive/drive_functions.py +124 -0
- autogen/tools/experimental/google/drive/toolkit.py +88 -0
- autogen/tools/experimental/google/model.py +17 -0
- autogen/tools/experimental/google/toolkit_protocol.py +19 -0
- autogen/tools/experimental/google_search/__init__.py +8 -0
- autogen/tools/experimental/google_search/google_search.py +93 -0
- autogen/tools/experimental/google_search/youtube_search.py +181 -0
- autogen/tools/experimental/messageplatform/__init__.py +17 -0
- autogen/tools/experimental/messageplatform/discord/__init__.py +7 -0
- autogen/tools/experimental/messageplatform/discord/discord.py +288 -0
- autogen/tools/experimental/messageplatform/slack/__init__.py +7 -0
- autogen/tools/experimental/messageplatform/slack/slack.py +391 -0
- autogen/tools/experimental/messageplatform/telegram/__init__.py +7 -0
- autogen/tools/experimental/messageplatform/telegram/telegram.py +275 -0
- autogen/tools/experimental/perplexity/__init__.py +7 -0
- autogen/tools/experimental/perplexity/perplexity_search.py +260 -0
- autogen/tools/experimental/reliable/__init__.py +10 -0
- autogen/tools/experimental/reliable/reliable.py +1316 -0
- autogen/tools/experimental/tavily/__init__.py +7 -0
- autogen/tools/experimental/tavily/tavily_search.py +183 -0
- autogen/tools/experimental/web_search_preview/__init__.py +7 -0
- autogen/tools/experimental/web_search_preview/web_search_preview.py +114 -0
- autogen/tools/experimental/wikipedia/__init__.py +7 -0
- autogen/tools/experimental/wikipedia/wikipedia.py +287 -0
- autogen/tools/function_utils.py +411 -0
- autogen/tools/tool.py +187 -0
- autogen/tools/toolkit.py +86 -0
- autogen/types.py +29 -0
- autogen/version.py +7 -0
- templates/client_template/main.jinja2 +69 -0
- templates/config_template/config.jinja2 +7 -0
- templates/main.jinja2 +61 -0
- ag2-0.9.1a1.dist-info/RECORD +0 -6
- ag2-0.9.1a1.dist-info/top_level.txt +0 -1
- {ag2-0.9.1a1.dist-info → ag2-0.9.2.dist-info/licenses}/LICENSE +0 -0
- {ag2-0.9.1a1.dist-info → ag2-0.9.2.dist-info/licenses}/NOTICE.md +0 -0
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
# Copyright (c) 2023 - 2025, AG2ai, Inc., AG2ai open-source projects maintainers and core contributors
|
|
2
|
+
#
|
|
3
|
+
# SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
#
|
|
5
|
+
# Portions derived from https://github.com/microsoft/autogen are under the MIT License.
|
|
6
|
+
# SPDX-License-Identifier: MIT
|
|
7
|
+
import copy
|
|
8
|
+
import logging
|
|
9
|
+
import re
|
|
10
|
+
from datetime import datetime
|
|
11
|
+
from typing import Annotated, Any, Callable, Literal, Optional, Union
|
|
12
|
+
|
|
13
|
+
from ... import Agent, AssistantAgent, ConversableAgent, OpenAIWrapper, UserProxyAgent
|
|
14
|
+
from ...browser_utils import SimpleTextBrowser
|
|
15
|
+
from ...llm_config import LLMConfig
|
|
16
|
+
from ...oai.openai_utils import filter_config
|
|
17
|
+
from ...token_count_utils import count_token, get_max_token_limit
|
|
18
|
+
|
|
19
|
+
logger = logging.getLogger(__name__)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class WebSurferAgent(ConversableAgent):
|
|
23
|
+
"""(In preview) An agent that acts as a basic web surfer that can search the web and visit web pages."""
|
|
24
|
+
|
|
25
|
+
DEFAULT_PROMPT = (
|
|
26
|
+
"You are a helpful AI assistant with access to a web browser (via the provided functions). In fact, YOU ARE THE ONLY MEMBER OF YOUR PARTY WITH ACCESS TO A WEB BROWSER, so please help out where you can by performing web searches, navigating pages, and reporting what you find. Today's date is "
|
|
27
|
+
+ datetime.now().date().isoformat()
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
DEFAULT_DESCRIPTION = "A helpful assistant with access to a web browser. Ask them to perform web searches, open pages, navigate to Wikipedia, answer questions from pages, and or generate summaries."
|
|
31
|
+
|
|
32
|
+
def __init__(
|
|
33
|
+
self,
|
|
34
|
+
name: str,
|
|
35
|
+
system_message: Optional[Union[str, list[str]]] = DEFAULT_PROMPT,
|
|
36
|
+
description: Optional[str] = DEFAULT_DESCRIPTION,
|
|
37
|
+
is_termination_msg: Optional[Callable[[dict[str, Any]], bool]] = None,
|
|
38
|
+
max_consecutive_auto_reply: Optional[int] = None,
|
|
39
|
+
human_input_mode: Literal["ALWAYS", "NEVER", "TERMINATE"] = "TERMINATE",
|
|
40
|
+
function_map: Optional[dict[str, Callable[..., Any]]] = None,
|
|
41
|
+
code_execution_config: Union[dict[str, Any], Literal[False]] = False,
|
|
42
|
+
llm_config: Optional[Union[LLMConfig, dict[str, Any], Literal[False]]] = None,
|
|
43
|
+
summarizer_llm_config: Optional[Union[LLMConfig, dict[str, Any], Literal[False]]] = None,
|
|
44
|
+
default_auto_reply: Optional[Union[str, dict[str, Any]]] = "",
|
|
45
|
+
browser_config: Optional[dict[str, Any]] = None,
|
|
46
|
+
**kwargs: Any,
|
|
47
|
+
):
|
|
48
|
+
super().__init__(
|
|
49
|
+
name=name,
|
|
50
|
+
system_message=system_message,
|
|
51
|
+
description=description,
|
|
52
|
+
is_termination_msg=is_termination_msg,
|
|
53
|
+
max_consecutive_auto_reply=max_consecutive_auto_reply,
|
|
54
|
+
human_input_mode=human_input_mode,
|
|
55
|
+
function_map=function_map,
|
|
56
|
+
code_execution_config=code_execution_config,
|
|
57
|
+
llm_config=llm_config,
|
|
58
|
+
default_auto_reply=default_auto_reply,
|
|
59
|
+
**kwargs,
|
|
60
|
+
)
|
|
61
|
+
|
|
62
|
+
self._create_summarizer_client(summarizer_llm_config, llm_config)
|
|
63
|
+
|
|
64
|
+
# Create the browser
|
|
65
|
+
self.browser = SimpleTextBrowser(**(browser_config if browser_config else {}))
|
|
66
|
+
|
|
67
|
+
inner_llm_config = copy.deepcopy(llm_config)
|
|
68
|
+
|
|
69
|
+
# Set up the inner monologue
|
|
70
|
+
self._assistant = AssistantAgent(
|
|
71
|
+
self.name + "_inner_assistant",
|
|
72
|
+
system_message=system_message, # type: ignore[arg-type]
|
|
73
|
+
llm_config=inner_llm_config,
|
|
74
|
+
is_termination_msg=lambda m: False,
|
|
75
|
+
)
|
|
76
|
+
|
|
77
|
+
self._user_proxy = UserProxyAgent(
|
|
78
|
+
self.name + "_inner_user_proxy",
|
|
79
|
+
human_input_mode="NEVER",
|
|
80
|
+
code_execution_config=False,
|
|
81
|
+
default_auto_reply="",
|
|
82
|
+
is_termination_msg=lambda m: False,
|
|
83
|
+
)
|
|
84
|
+
|
|
85
|
+
if inner_llm_config not in [None, False]:
|
|
86
|
+
self._register_functions()
|
|
87
|
+
|
|
88
|
+
self.register_reply([Agent, None], WebSurferAgent.generate_surfer_reply, remove_other_reply_funcs=True)
|
|
89
|
+
self.register_reply([Agent, None], ConversableAgent.generate_code_execution_reply)
|
|
90
|
+
self.register_reply([Agent, None], ConversableAgent.generate_function_call_reply)
|
|
91
|
+
self.register_reply([Agent, None], ConversableAgent.check_termination_and_human_reply)
|
|
92
|
+
|
|
93
|
+
def _create_summarizer_client(
|
|
94
|
+
self, summarizer_llm_config: Union[LLMConfig, dict[str, Any]], llm_config: Union[LLMConfig, dict[str, Any]]
|
|
95
|
+
) -> None:
|
|
96
|
+
# If the summarizer_llm_config is None, we copy it from the llm_config
|
|
97
|
+
if summarizer_llm_config is None:
|
|
98
|
+
if llm_config is None: # Nothing to copy
|
|
99
|
+
self.summarizer_llm_config = None
|
|
100
|
+
elif llm_config is False: # LLMs disabled
|
|
101
|
+
self.summarizer_llm_config = False
|
|
102
|
+
else: # Create a suitable config
|
|
103
|
+
self.summarizer_llm_config = copy.deepcopy(llm_config) # type: ignore[assignment]
|
|
104
|
+
if "config_list" in self.summarizer_llm_config: # type: ignore[operator]
|
|
105
|
+
preferred_models = filter_config( # type: ignore[no-untyped-call]
|
|
106
|
+
self.summarizer_llm_config["config_list"], # type: ignore[index]
|
|
107
|
+
{"model": ["gpt-3.5-turbo-1106", "gpt-3.5-turbo-16k-0613", "gpt-3.5-turbo-16k"]},
|
|
108
|
+
)
|
|
109
|
+
if len(preferred_models) == 0:
|
|
110
|
+
logger.warning(
|
|
111
|
+
"The summarizer did not find the preferred model (gpt-3.5-turbo-16k) in the config list. "
|
|
112
|
+
"Semantic operations on webpages (summarization or Q&A) might be costly or ineffective."
|
|
113
|
+
)
|
|
114
|
+
else:
|
|
115
|
+
self.summarizer_llm_config["config_list"] = preferred_models # type: ignore[index]
|
|
116
|
+
else:
|
|
117
|
+
self.summarizer_llm_config = summarizer_llm_config # type: ignore[assignment]
|
|
118
|
+
|
|
119
|
+
# Create the summarizer client
|
|
120
|
+
self.summarization_client = (
|
|
121
|
+
None if self.summarizer_llm_config is False else OpenAIWrapper(**self.summarizer_llm_config)
|
|
122
|
+
) # type: ignore[arg-type]
|
|
123
|
+
|
|
124
|
+
def _register_functions(self) -> None:
|
|
125
|
+
"""Register the functions for the inner assistant and user proxy."""
|
|
126
|
+
|
|
127
|
+
# Helper functions
|
|
128
|
+
def _browser_state() -> tuple[str, str]:
|
|
129
|
+
header = f"Address: {self.browser.address}\n"
|
|
130
|
+
if self.browser.page_title is not None:
|
|
131
|
+
header += f"Title: {self.browser.page_title}\n"
|
|
132
|
+
|
|
133
|
+
current_page = self.browser.viewport_current_page
|
|
134
|
+
total_pages = len(self.browser.viewport_pages)
|
|
135
|
+
|
|
136
|
+
header += f"Viewport position: Showing page {current_page + 1} of {total_pages}.\n"
|
|
137
|
+
return (header, self.browser.viewport)
|
|
138
|
+
|
|
139
|
+
@self._user_proxy.register_for_execution()
|
|
140
|
+
@self._assistant.register_for_llm(
|
|
141
|
+
name="informational_web_search",
|
|
142
|
+
description="Perform an INFORMATIONAL web search query then return the search results.",
|
|
143
|
+
)
|
|
144
|
+
def _informational_search(query: Annotated[str, "The informational web search query to perform."]) -> str:
|
|
145
|
+
self.browser.visit_page(f"bing: {query}")
|
|
146
|
+
header, content = _browser_state()
|
|
147
|
+
return header.strip() + "\n=======================\n" + content
|
|
148
|
+
|
|
149
|
+
@self._user_proxy.register_for_execution()
|
|
150
|
+
@self._assistant.register_for_llm(
|
|
151
|
+
name="navigational_web_search",
|
|
152
|
+
description="Perform a NAVIGATIONAL web search query then immediately navigate to the top result. Useful, for example, to navigate to a particular Wikipedia article or other known destination. Equivalent to Google's \"I'm Feeling Lucky\" button.",
|
|
153
|
+
)
|
|
154
|
+
def _navigational_search(query: Annotated[str, "The navigational web search query to perform."]) -> str:
|
|
155
|
+
self.browser.visit_page(f"bing: {query}")
|
|
156
|
+
|
|
157
|
+
# Extract the first linl
|
|
158
|
+
m = re.search(r"\[.*?\]\((http.*?)\)", self.browser.page_content)
|
|
159
|
+
if m:
|
|
160
|
+
self.browser.visit_page(m.group(1))
|
|
161
|
+
|
|
162
|
+
# Return where we ended up
|
|
163
|
+
header, content = _browser_state()
|
|
164
|
+
return header.strip() + "\n=======================\n" + content
|
|
165
|
+
|
|
166
|
+
@self._user_proxy.register_for_execution()
|
|
167
|
+
@self._assistant.register_for_llm(
|
|
168
|
+
name="visit_page", description="Visit a webpage at a given URL and return its text."
|
|
169
|
+
)
|
|
170
|
+
def _visit_page(url: Annotated[str, "The relative or absolute url of the webpage to visit."]) -> str:
|
|
171
|
+
self.browser.visit_page(url)
|
|
172
|
+
header, content = _browser_state()
|
|
173
|
+
return header.strip() + "\n=======================\n" + content
|
|
174
|
+
|
|
175
|
+
@self._user_proxy.register_for_execution()
|
|
176
|
+
@self._assistant.register_for_llm(
|
|
177
|
+
name="page_up",
|
|
178
|
+
description="Scroll the viewport UP one page-length in the current webpage and return the new viewport content.",
|
|
179
|
+
)
|
|
180
|
+
def _page_up() -> str:
|
|
181
|
+
self.browser.page_up()
|
|
182
|
+
header, content = _browser_state()
|
|
183
|
+
return header.strip() + "\n=======================\n" + content
|
|
184
|
+
|
|
185
|
+
@self._user_proxy.register_for_execution()
|
|
186
|
+
@self._assistant.register_for_llm(
|
|
187
|
+
name="page_down",
|
|
188
|
+
description="Scroll the viewport DOWN one page-length in the current webpage and return the new viewport content.",
|
|
189
|
+
)
|
|
190
|
+
def _page_down() -> str:
|
|
191
|
+
self.browser.page_down()
|
|
192
|
+
header, content = _browser_state()
|
|
193
|
+
return header.strip() + "\n=======================\n" + content
|
|
194
|
+
|
|
195
|
+
if self.summarization_client is not None:
|
|
196
|
+
|
|
197
|
+
@self._user_proxy.register_for_execution()
|
|
198
|
+
@self._assistant.register_for_llm(
|
|
199
|
+
name="answer_from_page",
|
|
200
|
+
description="Uses AI to read the page and directly answer a given question based on the content.",
|
|
201
|
+
)
|
|
202
|
+
def _answer_from_page(
|
|
203
|
+
question: Annotated[Optional[str], "The question to directly answer."],
|
|
204
|
+
url: Annotated[Optional[str], "[Optional] The url of the page. (Defaults to the current page)"] = None,
|
|
205
|
+
) -> str:
|
|
206
|
+
if url is not None and url != self.browser.address:
|
|
207
|
+
self.browser.visit_page(url)
|
|
208
|
+
|
|
209
|
+
# We are likely going to need to fix this later, but summarize only as many tokens that fit in the buffer
|
|
210
|
+
limit = 4096
|
|
211
|
+
try:
|
|
212
|
+
limit = get_max_token_limit(self.summarizer_llm_config["config_list"][0]["model"]) # type: ignore[index]
|
|
213
|
+
except ValueError:
|
|
214
|
+
pass # limit is unknown
|
|
215
|
+
except TypeError:
|
|
216
|
+
pass # limit is unknown
|
|
217
|
+
|
|
218
|
+
if limit < 16000:
|
|
219
|
+
logger.warning(
|
|
220
|
+
f"The token limit ({limit}) of the WebSurferAgent.summarizer_llm_config, is below the recommended 16k."
|
|
221
|
+
)
|
|
222
|
+
|
|
223
|
+
buffer = ""
|
|
224
|
+
for line in re.split(r"([\r\n]+)", self.browser.page_content):
|
|
225
|
+
tokens = count_token(buffer + line)
|
|
226
|
+
if tokens + 1024 > limit: # Leave room for our summary
|
|
227
|
+
break
|
|
228
|
+
buffer += line
|
|
229
|
+
|
|
230
|
+
buffer = buffer.strip()
|
|
231
|
+
if len(buffer) == 0:
|
|
232
|
+
return "Nothing to summarize."
|
|
233
|
+
|
|
234
|
+
messages = [
|
|
235
|
+
{
|
|
236
|
+
"role": "system",
|
|
237
|
+
"content": "You are a helpful assistant that can summarize long documents to answer question.",
|
|
238
|
+
}
|
|
239
|
+
]
|
|
240
|
+
|
|
241
|
+
prompt = f"Please summarize the following into one or two paragraph:\n\n{buffer}"
|
|
242
|
+
if question is not None:
|
|
243
|
+
prompt = f"Please summarize the following into one or two paragraphs with respect to '{question}':\n\n{buffer}"
|
|
244
|
+
|
|
245
|
+
messages.append(
|
|
246
|
+
{"role": "user", "content": prompt},
|
|
247
|
+
)
|
|
248
|
+
|
|
249
|
+
response = self.summarization_client.create(context=None, messages=messages) # type: ignore[union-attr]
|
|
250
|
+
extracted_response = self.summarization_client.extract_text_or_completion_object(response)[0] # type: ignore[union-attr]
|
|
251
|
+
return str(extracted_response)
|
|
252
|
+
|
|
253
|
+
@self._user_proxy.register_for_execution()
|
|
254
|
+
@self._assistant.register_for_llm(
|
|
255
|
+
name="summarize_page",
|
|
256
|
+
description="Uses AI to summarize the content found at a given url. If the url is not provided, the current page is summarized.",
|
|
257
|
+
)
|
|
258
|
+
def _summarize_page(
|
|
259
|
+
url: Annotated[
|
|
260
|
+
Optional[str], "[Optional] The url of the page to summarize. (Defaults to current page)"
|
|
261
|
+
] = None,
|
|
262
|
+
) -> str:
|
|
263
|
+
return _answer_from_page(url=url, question=None)
|
|
264
|
+
|
|
265
|
+
def generate_surfer_reply(
|
|
266
|
+
self,
|
|
267
|
+
messages: Optional[list[dict[str, str]]] = None,
|
|
268
|
+
sender: Optional[Agent] = None,
|
|
269
|
+
config: Optional[OpenAIWrapper] = None,
|
|
270
|
+
) -> tuple[bool, Optional[Union[str, dict[str, str]]]]:
|
|
271
|
+
"""Generate a reply using autogen.oai."""
|
|
272
|
+
if messages is None:
|
|
273
|
+
messages = self._oai_messages[sender]
|
|
274
|
+
|
|
275
|
+
self._user_proxy.reset() # type: ignore[no-untyped-call]
|
|
276
|
+
self._assistant.reset() # type: ignore[no-untyped-call]
|
|
277
|
+
|
|
278
|
+
# Clone the messages to give context
|
|
279
|
+
self._assistant.chat_messages[self._user_proxy] = list()
|
|
280
|
+
history = messages[0 : len(messages) - 1]
|
|
281
|
+
for message in history:
|
|
282
|
+
self._assistant.chat_messages[self._user_proxy].append(message)
|
|
283
|
+
|
|
284
|
+
# Remind the agent where it is
|
|
285
|
+
self._user_proxy.send(
|
|
286
|
+
f"Your browser is currently open to the page '{self.browser.page_title}' at the address '{self.browser.address}'.",
|
|
287
|
+
self._assistant,
|
|
288
|
+
request_reply=False,
|
|
289
|
+
silent=True,
|
|
290
|
+
)
|
|
291
|
+
|
|
292
|
+
self._user_proxy.send(messages[-1]["content"], self._assistant, request_reply=True, silent=True)
|
|
293
|
+
agent_reply = self._user_proxy.chat_messages[self._assistant][-1]
|
|
294
|
+
# print("Agent Reply: " + str(agent_reply))
|
|
295
|
+
proxy_reply = self._user_proxy.generate_reply(
|
|
296
|
+
messages=self._user_proxy.chat_messages[self._assistant], sender=self._assistant
|
|
297
|
+
)
|
|
298
|
+
# print("Proxy Reply: " + str(proxy_reply))
|
|
299
|
+
|
|
300
|
+
if proxy_reply == "": # Was the default reply
|
|
301
|
+
return True, None if agent_reply is None else agent_reply["content"]
|
|
302
|
+
else:
|
|
303
|
+
return True, None if proxy_reply is None else proxy_reply["content"] # type: ignore[index]
|