From db901940da7d57f1bea4a133e4bb07442be7a8e4 Mon Sep 17 00:00:00 2001 From: Davor Runje Date: Thu, 12 Sep 2024 20:44:15 +0200 Subject: [PATCH] Add user guide (#179) * wip * test fixed * wip * wip * User guide added * version bumped to 0.1.0b0 --------- Co-authored-by: Kumaran Rajendhiran --- CONTRIBUTING.md | 2 +- README.md | 18 ++-- docs/docs.py | 4 +- docs/docs/SUMMARY.md | 37 +++++--- .../autogen/AutoGenWorkflows.md | 2 +- .../autogen/IOStreamAdapter.md | 2 +- .../runtime/autogen/base/AutoGenWorkflows.md | 11 +++ .../autogen/base/CurrentMessage.md | 2 +- .../autogen/base/IOStreamAdapter.md | 2 +- .../runtimes/autogen/base/AutoGenWorkflows.md | 11 --- .../contributing/CONTRIBUTING.md | 0 .../contributing/docs.md | 0 docs/docs/en/contributing/index.md | 1 + docs/docs/en/getting-started/index.md | 40 ++++----- docs/docs/en/user-guide/api/index.md | 23 +++++ .../api/openapi}/index.md | 10 +-- .../api}/security.md | 12 +-- .../index.md => user-guide/basics.md} | 28 +++--- docs/docs/en/user-guide/cli/index.md | 66 ++++++++++++++ docs/docs/en/user-guide/index.md | 29 ++++++ .../en/user-guide/runtime/autogen/index.md | 89 +++++++++++++++++++ .../runtime/autogen/interactions.md} | 14 +-- .../en/user-guide/runtime/crewai/basics.md | 9 ++ docs/docs/en/user-guide/runtime/index.md | 21 +++++ docs/docs/en/user-guide/testing/index.md | 17 ++++ docs/docs/en/user-guide/ui/console/basics.md | 74 +++++++++++++++ docs/docs/en/user-guide/ui/fastapi/basics.md | 17 ++++ docs/docs/en/user-guide/ui/index.md | 26 ++++++ docs/docs/en/user-guide/ui/mesop/basics.md | 83 +++++++++++++++++ docs/docs/navigation_template.txt | 25 ++++-- docs/docs/stylesheets/extra.css | 21 +++-- .../{tutorial => getting_started}/__init__.py | 0 .../main_console.py} | 4 +- docs/docs_src/getting_started/main_mesop.py | 47 ++++++++++ .../__init__.py | 0 .../custom_user_interactions}/__init__.py | 0 .../custom_user_interactions/main.py | 10 +-- .../external_rest_apis}/__init__.py | 0 .../external_rest_apis/main.py | 4 +- .../external_rest_apis/security.py | 4 +- .../docs_src/user_guide/runtime}/__init__.py | 0 .../user_guide/runtime/autogen/__init__.py | 0 .../user_guide/runtime/autogen/main.py | 71 +++++++++++++++ examples/autogen.ipynb | 24 ++--- examples/cli/main_console.py | 4 +- examples/cli/main_mesop.py | 4 +- examples/cli/main_user_proxy.py | 4 +- fastagency/__about__.py | 2 +- fastagency/app.py | 2 +- fastagency/base.py | 2 +- fastagency/runtime/__init__.py | 0 .../{runtimes => runtime}/autogen/__init__.py | 0 .../{runtimes => runtime}/autogen/base.py | 2 +- fastagency/ui/console/base.py | 2 +- tests/cli/test_discover.py | 2 +- .../external_rest_apis/test_with_security.py | 2 +- .../test_without_security.py | 2 +- tests/examples/__init__.py | 0 tests/test_autogen.py | 4 +- tests/ui/console/test_base.py | 2 +- 60 files changed, 739 insertions(+), 155 deletions(-) rename docs/docs/en/api/fastagency/{runtimes => runtime}/autogen/AutoGenWorkflows.md (69%) rename docs/docs/en/api/fastagency/{runtimes => runtime}/autogen/IOStreamAdapter.md (69%) create mode 100644 docs/docs/en/api/fastagency/runtime/autogen/base/AutoGenWorkflows.md rename docs/docs/en/api/fastagency/{runtimes => runtime}/autogen/base/CurrentMessage.md (67%) rename docs/docs/en/api/fastagency/{runtimes => runtime}/autogen/base/IOStreamAdapter.md (67%) delete mode 100644 docs/docs/en/api/fastagency/runtimes/autogen/base/AutoGenWorkflows.md rename docs/docs/en/{getting-started => }/contributing/CONTRIBUTING.md (100%) rename docs/docs/en/{getting-started => }/contributing/docs.md (100%) create mode 100644 docs/docs/en/contributing/index.md create mode 100644 docs/docs/en/user-guide/api/index.md rename docs/docs/en/{tutorial/external-rest-apis => user-guide/api/openapi}/index.md (97%) rename docs/docs/en/{tutorial/external-rest-apis => user-guide/api}/security.md (97%) rename docs/docs/en/{tutorial/index.md => user-guide/basics.md} (88%) create mode 100644 docs/docs/en/user-guide/cli/index.md create mode 100644 docs/docs/en/user-guide/index.md create mode 100644 docs/docs/en/user-guide/runtime/autogen/index.md rename docs/docs/en/{tutorial/custom-user-interactions/index.md => user-guide/runtime/autogen/interactions.md} (68%) create mode 100644 docs/docs/en/user-guide/runtime/crewai/basics.md create mode 100644 docs/docs/en/user-guide/runtime/index.md create mode 100644 docs/docs/en/user-guide/testing/index.md create mode 100644 docs/docs/en/user-guide/ui/console/basics.md create mode 100644 docs/docs/en/user-guide/ui/fastapi/basics.md create mode 100644 docs/docs/en/user-guide/ui/index.md create mode 100644 docs/docs/en/user-guide/ui/mesop/basics.md rename docs/docs_src/{tutorial => getting_started}/__init__.py (100%) rename docs/docs_src/{tutorial/getting_started/main.py => getting_started/main_console.py} (89%) create mode 100644 docs/docs_src/getting_started/main_mesop.py rename docs/docs_src/{tutorial/custom_user_interactions => user_guide}/__init__.py (100%) rename docs/docs_src/{tutorial/external_rest_apis => user_guide/custom_user_interactions}/__init__.py (100%) rename docs/docs_src/{tutorial => user_guide}/custom_user_interactions/main.py (94%) rename docs/docs_src/{tutorial/getting_started => user_guide/external_rest_apis}/__init__.py (100%) rename docs/docs_src/{tutorial => user_guide}/external_rest_apis/main.py (91%) rename docs/docs_src/{tutorial => user_guide}/external_rest_apis/security.py (93%) rename {fastagency/runtimes => docs/docs_src/user_guide/runtime}/__init__.py (100%) create mode 100644 docs/docs_src/user_guide/runtime/autogen/__init__.py create mode 100644 docs/docs_src/user_guide/runtime/autogen/main.py create mode 100644 fastagency/runtime/__init__.py rename fastagency/{runtimes => runtime}/autogen/__init__.py (100%) rename fastagency/{runtimes => runtime}/autogen/base.py (99%) create mode 100644 tests/examples/__init__.py diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index f1e393895..8b5e9bb2a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,4 +1,4 @@ -> **_NOTE:_** This is an auto-generated file. Please edit docs/docs/en/getting-started/contributing/CONTRIBUTING.md instead. +> **_NOTE:_** This is an auto-generated file. Please edit docs/docs/en/contributing/CONTRIBUTING.md instead. # Development diff --git a/README.md b/README.md index 46b7c4ea5..87872c8c8 100644 --- a/README.md +++ b/README.md @@ -61,8 +61,8 @@ With FastAgency, you can create interactive applications using various interface FastAgency currently supports workflows defined using AutoGen and provides options for different types of applications: -- **Console**: Use the [ConsoleIO](https://fastagency.ai/latest/api/fastagency/core/io/console/ConsoleIO/) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. -- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/) with [MesopIO](https://fastagency.ai/latest/api/fastagency/core/io/mesop/MesopIO/) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. +- **Console**: Use the [ConsoleUI](https://fastagency.ai/latest/api/fastagency/io/console/ConsoleUI/) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. +- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/) with [MesopUI](https://fastagency.ai/latest/api/fastagency/io/mesop/MesopUI/) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. We are also working on adding support for other frameworks, such as [CrewAI](https://www.crewai.com/), to broaden the scope and capabilities of FastAgency. Stay tuned for updates on these integrations. @@ -92,14 +92,14 @@ import os from autogen.agentchat import ConversableAgent -from fastagency.core import Chatable -from fastagency.core.runtimes.autogen.base import AutoGenWorkflows -from fastagency.core.io.console import ConsoleIO +from fastagency import UI +from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.ui.console import ConsoleUI from fastagency import FastAgency ``` -For Console applications, import `ConsoleIO` to handle command-line input and output. +For Console applications, import `ConsoleUI` to handle command-line input and output. ### Define Workflow @@ -120,7 +120,7 @@ llm_config = { wf = AutoGenWorkflows() @wf.register(name="simple_learning", description="Student and teacher learning chat") -def simple_workflow(io: Chatable, initial_message: str, session_id: str) -> str: +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: student_agent = ConversableAgent( name="Student_Agent", system_message="You are a student willing to learn.", @@ -149,9 +149,9 @@ This code snippet sets up a simple learning chat between a student and a teacher Next, define your FastAgency application. This ties together your workflow and the interface you chose: ```python -from fastagency.core.io.console import ConsoleIO +from fastagency.ui.console import ConsoleUI -app = FastAgency(wf=wf, io=ConsoleIO()) +app = FastAgency(wf=wf, io=ConsoleUI()) ``` ## Run Application diff --git a/docs/docs.py b/docs/docs.py index 8772104b6..9ae30a879 100644 --- a/docs/docs.py +++ b/docs/docs.py @@ -28,9 +28,7 @@ EN_DOCS_DIR = DOCS_DIR / "en" EN_INDEX_PATH = EN_DOCS_DIR / "index.md" README_PATH = BASE_DIR.parent / "README.md" -EN_CONTRIBUTING_PATH = ( - EN_DOCS_DIR / "getting-started" / "contributing" / "CONTRIBUTING.md" -) +EN_CONTRIBUTING_PATH = EN_DOCS_DIR / "contributing" / "CONTRIBUTING.md" CONTRIBUTING_PATH = BASE_DIR.parent / "CONTRIBUTING.md" diff --git a/docs/docs/SUMMARY.md b/docs/docs/SUMMARY.md index 8334eee7c..c14248254 100644 --- a/docs/docs/SUMMARY.md +++ b/docs/docs/SUMMARY.md @@ -4,11 +4,20 @@ search: --- - Getting Started - [Getting Started](getting-started/index.md) -- Tutorial - - [Getting Started](tutorial/index.md) - - [Using External REST APIs](tutorial/external-rest-apis/index.md) - - [Using External REST APIs with security](tutorial/external-rest-apis/security.md) - - [Custom User Interactions](tutorial/custom-user-interactions/index.md) +- [User guide](user-guide/index.md) + - [Runtimes](user-guide/runtime/index.md) + - [AutoGen](user-guide/runtime/autogen/index.md) + - [User interaction](user-guide/runtime/autogen/interactions.md) + - [CrewAI](user-guide/runtime/crewai/basics.md) + - [UI](user-guide/ui/index.md) + - [Console](user-guide/ui/console/basics.md) + - [Mesop](user-guide/ui/mesop/basics.md) + - [FastAPI](user-guide/ui/fastapi/basics.md) + - [API-s](user-guide/api/index.md) + - [OpenAPI](user-guide/api/openapi/index.md) + - [Security](user-guide/api/security.md) + - [Testing](user-guide/testing/index.md) + - [CLI](user-guide/cli/index.md) - Reference - fastagency - [FastAgency](api/fastagency/FastAgency.md) @@ -76,14 +85,14 @@ search: - [setup_logging](api/fastagency/cli/logging/setup_logging.md) - logging - [get_logger](api/fastagency/logging/get_logger.md) - - runtimes + - runtime - autogen - - [AutoGenWorkflows](api/fastagency/runtimes/autogen/AutoGenWorkflows.md) - - [IOStreamAdapter](api/fastagency/runtimes/autogen/IOStreamAdapter.md) + - [AutoGenWorkflows](api/fastagency/runtime/autogen/AutoGenWorkflows.md) + - [IOStreamAdapter](api/fastagency/runtime/autogen/IOStreamAdapter.md) - base - - [AutoGenWorkflows](api/fastagency/runtimes/autogen/base/AutoGenWorkflows.md) - - [CurrentMessage](api/fastagency/runtimes/autogen/base/CurrentMessage.md) - - [IOStreamAdapter](api/fastagency/runtimes/autogen/base/IOStreamAdapter.md) + - [AutoGenWorkflows](api/fastagency/runtime/autogen/base/AutoGenWorkflows.md) + - [CurrentMessage](api/fastagency/runtime/autogen/base/CurrentMessage.md) + - [IOStreamAdapter](api/fastagency/runtime/autogen/base/IOStreamAdapter.md) - studio - app - [ChatRequest](api/fastagency/studio/app/ChatRequest.md) @@ -262,7 +271,7 @@ search: - send_prompt - [send_prompt_to_autogen](api/fastagency/ui/mesop/send_prompt/send_prompt_to_autogen.md) - [send_user_feedback_to_autogen](api/fastagency/ui/mesop/send_prompt/send_user_feedback_to_autogen.md) -- Contributing - - [Development](getting-started/contributing/CONTRIBUTING.md) - - [Documentation](getting-started/contributing/docs.md) +- [Contributing](contributing/index.md) + - [Development](contributing/CONTRIBUTING.md) + - [Documentation](contributing/docs.md) - [Release Notes](release.md) \ No newline at end of file diff --git a/docs/docs/en/api/fastagency/runtimes/autogen/AutoGenWorkflows.md b/docs/docs/en/api/fastagency/runtime/autogen/AutoGenWorkflows.md similarity index 69% rename from docs/docs/en/api/fastagency/runtimes/autogen/AutoGenWorkflows.md rename to docs/docs/en/api/fastagency/runtime/autogen/AutoGenWorkflows.md index 01c0b718a..3f840bb1e 100644 --- a/docs/docs/en/api/fastagency/runtimes/autogen/AutoGenWorkflows.md +++ b/docs/docs/en/api/fastagency/runtime/autogen/AutoGenWorkflows.md @@ -8,4 +8,4 @@ search: boost: 0.5 --- -::: fastagency.runtimes.autogen.AutoGenWorkflows +::: fastagency.runtime.autogen.AutoGenWorkflows diff --git a/docs/docs/en/api/fastagency/runtimes/autogen/IOStreamAdapter.md b/docs/docs/en/api/fastagency/runtime/autogen/IOStreamAdapter.md similarity index 69% rename from docs/docs/en/api/fastagency/runtimes/autogen/IOStreamAdapter.md rename to docs/docs/en/api/fastagency/runtime/autogen/IOStreamAdapter.md index a8ee8e0e1..cdcf8879f 100644 --- a/docs/docs/en/api/fastagency/runtimes/autogen/IOStreamAdapter.md +++ b/docs/docs/en/api/fastagency/runtime/autogen/IOStreamAdapter.md @@ -8,4 +8,4 @@ search: boost: 0.5 --- -::: fastagency.runtimes.autogen.IOStreamAdapter +::: fastagency.runtime.autogen.IOStreamAdapter diff --git a/docs/docs/en/api/fastagency/runtime/autogen/base/AutoGenWorkflows.md b/docs/docs/en/api/fastagency/runtime/autogen/base/AutoGenWorkflows.md new file mode 100644 index 000000000..7478687ef --- /dev/null +++ b/docs/docs/en/api/fastagency/runtime/autogen/base/AutoGenWorkflows.md @@ -0,0 +1,11 @@ +--- +# 0.5 - API +# 2 - Release +# 3 - Contributing +# 5 - Template Page +# 10 - Default +search: + boost: 0.5 +--- + +::: fastagency.runtime.autogen.base.AutoGenWorkflows diff --git a/docs/docs/en/api/fastagency/runtimes/autogen/base/CurrentMessage.md b/docs/docs/en/api/fastagency/runtime/autogen/base/CurrentMessage.md similarity index 67% rename from docs/docs/en/api/fastagency/runtimes/autogen/base/CurrentMessage.md rename to docs/docs/en/api/fastagency/runtime/autogen/base/CurrentMessage.md index 5864227f8..e6cc98308 100644 --- a/docs/docs/en/api/fastagency/runtimes/autogen/base/CurrentMessage.md +++ b/docs/docs/en/api/fastagency/runtime/autogen/base/CurrentMessage.md @@ -8,4 +8,4 @@ search: boost: 0.5 --- -::: fastagency.runtimes.autogen.base.CurrentMessage +::: fastagency.runtime.autogen.base.CurrentMessage diff --git a/docs/docs/en/api/fastagency/runtimes/autogen/base/IOStreamAdapter.md b/docs/docs/en/api/fastagency/runtime/autogen/base/IOStreamAdapter.md similarity index 67% rename from docs/docs/en/api/fastagency/runtimes/autogen/base/IOStreamAdapter.md rename to docs/docs/en/api/fastagency/runtime/autogen/base/IOStreamAdapter.md index c7876374a..78a638152 100644 --- a/docs/docs/en/api/fastagency/runtimes/autogen/base/IOStreamAdapter.md +++ b/docs/docs/en/api/fastagency/runtime/autogen/base/IOStreamAdapter.md @@ -8,4 +8,4 @@ search: boost: 0.5 --- -::: fastagency.runtimes.autogen.base.IOStreamAdapter +::: fastagency.runtime.autogen.base.IOStreamAdapter diff --git a/docs/docs/en/api/fastagency/runtimes/autogen/base/AutoGenWorkflows.md b/docs/docs/en/api/fastagency/runtimes/autogen/base/AutoGenWorkflows.md deleted file mode 100644 index 481336b15..000000000 --- a/docs/docs/en/api/fastagency/runtimes/autogen/base/AutoGenWorkflows.md +++ /dev/null @@ -1,11 +0,0 @@ ---- -# 0.5 - API -# 2 - Release -# 3 - Contributing -# 5 - Template Page -# 10 - Default -search: - boost: 0.5 ---- - -::: fastagency.runtimes.autogen.base.AutoGenWorkflows diff --git a/docs/docs/en/getting-started/contributing/CONTRIBUTING.md b/docs/docs/en/contributing/CONTRIBUTING.md similarity index 100% rename from docs/docs/en/getting-started/contributing/CONTRIBUTING.md rename to docs/docs/en/contributing/CONTRIBUTING.md diff --git a/docs/docs/en/getting-started/contributing/docs.md b/docs/docs/en/contributing/docs.md similarity index 100% rename from docs/docs/en/getting-started/contributing/docs.md rename to docs/docs/en/contributing/docs.md diff --git a/docs/docs/en/contributing/index.md b/docs/docs/en/contributing/index.md new file mode 100644 index 000000000..854139a31 --- /dev/null +++ b/docs/docs/en/contributing/index.md @@ -0,0 +1 @@ +# Contributing diff --git a/docs/docs/en/getting-started/index.md b/docs/docs/en/getting-started/index.md index a289b7a86..c3e5f4df3 100644 --- a/docs/docs/en/getting-started/index.md +++ b/docs/docs/en/getting-started/index.md @@ -73,8 +73,8 @@ With FastAgency, you can create interactive applications using various interface FastAgency currently supports workflows defined using AutoGen and provides options for different types of applications: -- **Console**: Use the [ConsoleIO](../api/fastagency/core/io/console/ConsoleIO.md) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. -- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/){target="_blank"} with [MesopIO](../api/fastagency/core/io/mesop/MesopIO.md) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. +- **Console**: Use the [ConsoleUI](../api/fastagency/io/console/ConsoleUI.md) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. +- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/){target="_blank"} with [MesopUI](../api/fastagency/io/mesop/MesopUI.md) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. We are also working on adding support for other frameworks, such as [CrewAI](https://www.crewai.com/){target="_blank"}, to broaden the scope and capabilities of FastAgency. Stay tuned for updates on these integrations. @@ -119,33 +119,25 @@ To get started, you need to install FastAgency. You can do this using `pip`, Pyt Depending on the interface you choose, you'll need to import different modules. These imports set up the necessary components for your application: === "Console" - ```python - {!> docs_src/tutorial/getting_started/main.py [ln:1-8] !} + ```python hl_lines="7" + {!> docs_src/getting_started/main_console.py [ln:1-8] !} ``` - For Console applications, import `ConsoleIO` to handle command-line input and output. + For Console applications, import `ConsoleUI` to handle command-line input and output. === "Mesop" - ```python - import os - - from autogen.agentchat import ConversableAgent - - from fastagency.core import Chatable - from fastagency.core.runtimes.autogen.base import AutoGenWorkflows - from fastagency.core.io.mesop import MesopIO - - from fastagency import FastAgency + ```python hl_lines="7" + {!> docs_src/getting_started/main_mesop.py [ln:1-8] !} ``` - For Mesop applications, import `MesopIO` to integrate with the Mesop web interface. + For Mesop applications, import `MesopUI` to integrate with the Mesop web interface. ### Define Workflow You need to define the workflow that your application will use. This is where you specify how the agents interact and what they do. Here's a simple example of a workflow definition: ```python -{! docs_src/tutorial/getting_started/main.py [ln:10-43] !} +{! docs_src/getting_started/main_console.py [ln:10-43] !} ``` This code snippet sets up a simple learning chat between a student and a teacher. You define the agents and how they should interact, specifying how the conversation should be summarized. @@ -155,20 +147,18 @@ This code snippet sets up a simple learning chat between a student and a teacher Next, define your FastAgency application. This ties together your workflow and the interface you chose: === "Console" - ```python - {!> docs_src/tutorial/getting_started/main.py [ln:7,46,47] !} + ```python hl_lines="1" + {!> docs_src/getting_started/main_console.py [ln:47] !} ``` - For Console applications, use `ConsoleIO` to handle user interaction via the command line. + For Console applications, use `ConsoleUI` to handle user interaction via the command line. === "Mesop" - ```python - from fastagency.core.io.mesop import MesopIO - - app = FastAgency(wf=wf, io=MesopIO()) + ```python hl_lines="1" + {!> docs_src/getting_started/main_mesop.py [ln:47] !} ``` - For Mesop applications, use `MesopIO` to enable web-based interactions. + For Mesop applications, use `MesopUI` to enable web-based interactions. ### Run Application diff --git a/docs/docs/en/user-guide/api/index.md b/docs/docs/en/user-guide/api/index.md new file mode 100644 index 000000000..637e0087f --- /dev/null +++ b/docs/docs/en/user-guide/api/index.md @@ -0,0 +1,23 @@ +# API Integration + +FastAgency makes it easy to integrate external APIs into your multi-agent workflows, allowing agents to access and interact with real-time data. By leveraging FastAgency's API support, developers can automatically create functions properly annotated for use with large language models (LLMs). This functionality allows agents to fetch and process external information seamlessly. + +Currently, FastAgency supports importing API functionality from [**OpenAPI**](https://swagger.io/specification/) specifications, enabling developers to connect their agents with RESTful APIs effortlessly. In addition, we support various types of security for accessing APIs, ensuring your integrations are both functional and secure. + +## API Features in FastAgency + +### 1. **[OpenAPI Import](./openapi/)** +FastAgency can automatically generate API functions from OpenAPI specifications, streamlining the process of connecting agents to external services. With just a few lines of code, you can import an API specification, and FastAgency will handle the function generation and LLM integration, making it simple for agents to call external APIs. + +[Learn more about OpenAPI Import →](./openapi/) + +### 2. **[API Security](./security/)** +FastAgency supports different types of security for REST APIs, including OAuth, API keys, and more. This ensures that your API integrations are secure and can handle sensitive data. Our API security mechanisms are flexible, allowing you to configure and manage secure communication between your agents and external APIs. + +[Learn more about API Security →](./security/) + +--- + +FastAgency’s API integration capabilities allow your multi-agent systems to interact with the real world in meaningful ways. Whether you’re pulling data from an external service or managing secure connections, FastAgency provides the tools you need to build powerful, connected applications. + +For more updates and discussions, join our [**Discord channel**](https://discord.gg/kJjSGWrknU). diff --git a/docs/docs/en/tutorial/external-rest-apis/index.md b/docs/docs/en/user-guide/api/openapi/index.md similarity index 97% rename from docs/docs/en/tutorial/external-rest-apis/index.md rename to docs/docs/en/user-guide/api/openapi/index.md index b37ae6a7e..602acd58a 100644 --- a/docs/docs/en/tutorial/external-rest-apis/index.md +++ b/docs/docs/en/user-guide/api/openapi/index.md @@ -1,4 +1,4 @@ -# Using External REST APIs +# OpenAPI FastAgency can automatically create functions properly annotated for use with LLM-s from [OpenAPI](https://swagger.io/specification/) specification. @@ -21,7 +21,7 @@ pip install "fastagency[autogen,openapi]" These imports are similar to the imports section we have already covered, with the only difference being the additional imports of the `OpenAPI` Client and `UserProxyAgent`: ```python -{! docs_src/tutorial/external_rest_apis/main.py [ln:1-10] !} +{! docs_src/user_guide/external_rest_apis/main.py [ln:1-10] !} ``` ## Define Workflow @@ -29,7 +29,7 @@ These imports are similar to the imports section we have already covered, with t In this workflow, the only difference is that we create a Python client for the external REST API by passing the URL of the `openapi.json` to the `Client.create` method. Then, we register the generated client with the agent using the methods `register_for_llm` and `register_for_execution`. Here's a simple example of a workflow definition: ```python -{! docs_src/tutorial/external_rest_apis/main.py [ln:12-55] !} +{! docs_src/user_guide/external_rest_apis/main.py [ln:12-55] !} ``` This code snippet sets up a simple weather agent that calls an external weather API using the registered functions generated from the `openapi.json` URL. @@ -39,7 +39,7 @@ This code snippet sets up a simple weather agent that calls an external weather Next, define your FastAgency application. ```python -{! docs_src/tutorial/external_rest_apis/main.py [ln:58] !} +{! docs_src/user_guide/external_rest_apis/main.py [ln:58] !} ``` ## Run Application @@ -47,7 +47,7 @@ Next, define your FastAgency application. You can run this chapter's FastAgency application using the following command: ```console -fastagency run docs/docs_src/tutorial/external_rest_apis/main.py +fastagency run docs/docs_src/user_guide/external_rest_apis/main.py ``` ## Output diff --git a/docs/docs/en/tutorial/external-rest-apis/security.md b/docs/docs/en/user-guide/api/security.md similarity index 97% rename from docs/docs/en/tutorial/external-rest-apis/security.md rename to docs/docs/en/user-guide/api/security.md index 6ce873177..e723ed0b1 100644 --- a/docs/docs/en/tutorial/external-rest-apis/security.md +++ b/docs/docs/en/user-guide/api/security.md @@ -1,4 +1,4 @@ -# Using External REST APIs with security +# Security In the [previous chapter](./index.md){.internal-link}, we learned how to integrate external REST APIs into `AutoGen` agents using `FastAgency`, and we used a weather API route which had no security. However, not all external REST APIs are open to the public; some are behind a paywall and require security parameters for access. This section of the documentation explains how to create an agent that accesses an external REST API with security. @@ -19,7 +19,7 @@ pip install "fastagency[autogen,openapi]" The imports are the same as in the [previous chapter](./index.md){.internal-link}, except here we also import `APIKeyHeader` to set the security value in the header: ```python hl_lines="11" -{! docs_src/tutorial/external_rest_apis/security.py [ln:1-11] !} +{! docs_src/user_guide/external_rest_apis/security.py [ln:1-11] !} ``` ## Define Workflow @@ -29,13 +29,13 @@ In this workflow, we create a Python client for the external REST API by passing Additionally, we set the API key for the API using the `set_security_params` method: ```python hl_lines="2" -{! docs_src/tutorial/external_rest_apis/security.py [ln:33.5,34.5] !} +{! docs_src/user_guide/external_rest_apis/security.py [ln:33.5,34.5] !} ``` Here's a simple example of a workflow definition: ```python hl_lines="22" -{! docs_src/tutorial/external_rest_apis/security.py [ln:13-65] !} +{! docs_src/user_guide/external_rest_apis/security.py [ln:13-65] !} ``` This code snippet sets up a simple weather agent that calls an external weather API with security, using the registered functions generated from the `openapi.json` URL. @@ -45,7 +45,7 @@ This code snippet sets up a simple weather agent that calls an external weather Next, define your FastAgency application. ```python -{! docs_src/tutorial/external_rest_apis/security.py [ln:68] !} +{! docs_src/user_guide/external_rest_apis/security.py [ln:68] !} ``` ## Run Application @@ -53,7 +53,7 @@ Next, define your FastAgency application. You can run this chapter's FastAgency application using the following command:: ```console -fastagency run docs/docs_src/tutorial/external_rest_apis/security.py +fastagency run docs/docs_src/user_guide/external_rest_apis/security.py ``` ## Output diff --git a/docs/docs/en/tutorial/index.md b/docs/docs/en/user-guide/basics.md similarity index 88% rename from docs/docs/en/tutorial/index.md rename to docs/docs/en/user-guide/basics.md index 409064113..6ec44fc87 100644 --- a/docs/docs/en/tutorial/index.md +++ b/docs/docs/en/user-guide/basics.md @@ -66,8 +66,8 @@ With FastAgency, you can create interactive applications using various interface FastAgency currently supports workflows defined using AutoGen and provides options for different types of applications: -- **Console**: Use the [ConsoleIO](../api/fastagency/core/io/console/ConsoleIO.md) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. -- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/){target="_blank"} with [MesopIO](../api/fastagency/core/io/mesop/MesopIO.md) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. +- **Console**: Use the [ConsoleUI](../api/fastagency/io/console/ConsoleUI.md) interface for command-line based interaction. This is ideal for developing and testing workflows in a text-based environment. +- **Mesop**: Utilize [Mesop](https://google.github.io/mesop/){target="_blank"} with [MesopUI](../api/fastagency/io/mesop/MesopUI.md) for web-based applications. This interface is suitable for creating web applications with a user-friendly interface. We are also working on adding support for other frameworks, such as [CrewAI](https://www.crewai.com/){target="_blank"}, to broaden the scope and capabilities of FastAgency. Stay tuned for updates on these integrations. @@ -113,10 +113,10 @@ Depending on the interface you choose, you'll need to import different modules. === "Console" ```python - {!> docs_src/tutorial/getting_started/main.py [ln:1-8] !} + {!> docs_src/getting_started/main_console.py [ln:1-8] !} ``` - For Console applications, import `ConsoleIO` to handle command-line input and output. + For Console applications, import `ConsoleUI` to handle command-line input and output. === "Mesop" ```python @@ -124,21 +124,21 @@ Depending on the interface you choose, you'll need to import different modules. from autogen.agentchat import ConversableAgent - from fastagency.core import Chatable - from fastagency.core.runtimes.autogen.base import AutoGenWorkflows - from fastagency.core.io.mesop import MesopIO + from fastagency import UI + from fastagency.runtimes.autogen.base import AutoGenWorkflows + from fastagency.ui.mesop import MesopUI from fastagency import FastAgency ``` - For Mesop applications, import `MesopIO` to integrate with the Mesop web interface. + For Mesop applications, import `MesopUI` to integrate with the Mesop web interface. ### Define Workflow You need to define the workflow that your application will use. This is where you specify how the agents interact and what they do. Here's a simple example of a workflow definition: ```python -{! docs_src/tutorial/getting_started/main.py [ln:10-43] !} +{! docs_src/getting_started/main_console.py [ln:10-43] !} ``` This code snippet sets up a simple learning chat between a student and a teacher. You define the agents and how they should interact, specifying how the conversation should be summarized. @@ -149,19 +149,19 @@ Next, define your FastAgency application. This ties together your workflow and t === "Console" ```python - {!> docs_src/tutorial/getting_started/main.py [ln:7,46,47] !} + {!> docs_src/getting_started/main_console.py [ln:7,46,47] !} ``` - For Console applications, use `ConsoleIO` to handle user interaction via the command line. + For Console applications, use `ConsoleUI` to handle user interaction via the command line. === "Mesop" ```python - from fastagency.core.io.mesop import MesopIO + from fastagency.ui.mesop import MesopUI - app = FastAgency(wf=wf, io=MesopIO()) + app = FastAgency(wf=wf, io=MesopUI()) ``` - For Mesop applications, use `MesopIO` to enable web-based interactions. + For Mesop applications, use `MesopUI` to enable web-based interactions. ### Run Application diff --git a/docs/docs/en/user-guide/cli/index.md b/docs/docs/en/user-guide/cli/index.md new file mode 100644 index 000000000..2da6c5809 --- /dev/null +++ b/docs/docs/en/user-guide/cli/index.md @@ -0,0 +1,66 @@ +# FastAgency CLI Overview + +The **FastAgency Command Line Interface (CLI)** enables developers to manage and run FastAgency projects directly from the terminal. The CLI simplifies interactions with FastAgency apps, providing options for running, testing, and managing workflows efficiently. Below is an overview of the key commands and options available in the FastAgency CLI. + +## CLI Commands + +### `dev` +```bash +$ fastagency dev [OPTIONS] [PATH] +``` +The `dev` command runs a FastAgency app in **development mode**, which is equivalent to running `fastapi` but with live reload enabled. This is useful for testing and development, as it listens on `127.0.0.1` and automatically detects the Python module or package that needs to be imported based on the file or directory path provided. + +#### Command Details: +- If no path is provided, it will try to locate the application using common file names like `main.py`, `app.py`, `api.py`, or from the `app` directory. +- It automatically detects the **FastAgency app** object to use, typically looking for an object named `app` or `api`. + +#### Common Options: +- `--app`: The name of the variable that contains the FastAgency app in the imported module. It defaults to automatic detection. +- `--workflow (-w)`: Specifies the name of the workflow to run. +- `--initial_message (-i)`: Sets the initial message sent to the workflow. + +### `run` +```bash +$ fastagency run [OPTIONS] [PATH] +``` +The `run` command starts a FastAgency app in **production mode**, similar to the `dev` command, but optimized for production environments. + +#### Common Options for `run`: +- `--app`: Specifies the name of the app variable to run, like in `dev`. +- `--workflow (-w)`: Specifies a particular workflow to run. +- `--initial_message (-i)`: Sends a custom initial message to the workflow. + +### `version` +```bash +$ fastagency version +``` +The `version` command shows the currently installed version of FastAgency. + +### Global Options +- `--version`: Displays the current version of FastAgency. +- `--install-completion`: Installs shell completion for supported shells (bash, zsh, etc.). +- `--show-completion`: Shows the shell completion script for manual installation or customization. +- `--help`: Displays detailed help information for commands. + +--- + +## Example Usage + +### Running a FastAgency App in Development Mode +```bash +fastagency dev path/to/app.py +``` + +### Running a FastAgency App with a Specific Workflow +```bash +fastagency run path/to/app.py --workflow simple_workflow +``` + +### Setting an Initial Message +```bash +fastagency run path/to/app.py --initial_message "Hello, let's start!" +``` + +--- + +For more information, visit the [FastAgency Docs](https://fastagency.ai/latest/) or join our [**Discord community**](https://discord.gg/kJjSGWrknU). diff --git a/docs/docs/en/user-guide/index.md b/docs/docs/en/user-guide/index.md new file mode 100644 index 000000000..be089530d --- /dev/null +++ b/docs/docs/en/user-guide/index.md @@ -0,0 +1,29 @@ +# Introduction to FastAgency + +**FastAgency** is an open-source framework designed to accelerate the transition from prototype to production for multi-agent AI workflows. For developers who use the AutoGen framework, FastAgency enables you to seamlessly scale Jupyter notebook prototypes into fully functional, production-ready applications. With multi-framework support, a unified programming interface, and powerful API integration capabilities, FastAgency streamlines the deployment process, saving time and effort while maintaining flexibility and performance. + +Whether you're orchestrating complex AI agents or integrating external APIs into workflows, FastAgency provides the tools necessary to quickly transition from concept to production, reducing development cycles and allowing you to focus on optimizing your multi-agent systems. + +## Key Features + +- [**Multi-Runtime Support**](runtime/): FastAgency supports multiple agentic [runtimes](runtime/) to provide maximum flexibility. Currently, it supports **AutoGen** and plans to extend support to [CrewAI](https://www.crewai.com/){target="_blank"}. This ensures that as the AI ecosystem evolves, FastAgency remains a reliable and adaptable framework, capable of leveraging emerging agentic technologies. Developers can easily switch between frameworks, choosing the best one for their project's specific needs. + +- [**Unified Programming Interface Across UIs**](ui/): FastAgency features a **common programming interface** that enables you to develop your core workflows once and reuse them across various user interfaces without rewriting code. This includes support for both **console-based applications** via `ConsoleUI` and **web-based applications** via `MesopUI`. Whether you need a command-line tool or a fully interactive web app, FastAgency allows you to deploy the same underlying workflows across environments, saving development time and ensuring consistency. + +- [**Seamless External API Integration**](api/): One of FastAgency's standout features is its ability to easily integrate external APIs into your agent workflows. With just a **single line of code**, you can import an OpenAPI specification, and in only one more line, you can connect it to your agents. This dramatically simplifies the process of enhancing AI agents with real-time data, external processing, or third-party services. For example, you can easily integrate a weather API to provide dynamic, real-time weather updates to your users, making your application more interactive and useful with minimal effort. + +- [**Tester Class for Continuous Integration**](testing/): FastAgency also provides a **Tester Class** that enables developers to write and execute tests for their multi-agent workflows. This feature is crucial for maintaining the reliability and robustness of your application, allowing you to automatically verify agent behavior and interactions. The Tester Class is designed to integrate smoothly with **continuous integration (CI)** pipelines, helping you catch bugs early and ensure that your workflows remain functional as they scale into production. + +- [**Command-Line Interface (CLI) for Orchestration**](cli/): FastAgency includes a powerful **command-line interface (CLI)** for orchestrating and managing multi-agent applications directly from the terminal. The CLI allows developers to quickly run workflows, pass parameters, and monitor agent interactions without needing a full GUI. This is especially useful for automating deployments and integrating workflows into broader DevOps pipelines, enabling developers to maintain control and flexibility in how they manage AI-driven applications. + +## Why FastAgency? + +FastAgency bridges the gap between rapid prototyping and production-ready deployment, empowering developers to bring their multi-agent systems to life quickly and efficiently. By integrating familiar frameworks like AutoGen, providing powerful API integration, and offering robust CI testing tools, FastAgency reduces the complexity and overhead typically associated with deploying AI agents in real-world applications. + +Whether you’re building interactive console tools, developing fully-featured web apps, or orchestrating large-scale multi-agent systems, FastAgency is built to help you deploy faster, more reliably, and with greater flexibility. + +## ⭐⭐⭐ Stay in touch ⭐⭐⭐ + +Stay up to date with new features and integrations by following our documentation and community updates on our [**Discord server**](https://discord.gg/kJjSGWrknU){target="_blank"}. FastAgency is continually evolving to support new frameworks, APIs, and deployment strategies, ensuring you remain at the forefront of AI-driven development. + +Last but not least, show us your support by giving a star to our [**GitHub repository**](https://github.com/airtai/fastagency/){target="_blank"}. diff --git a/docs/docs/en/user-guide/runtime/autogen/index.md b/docs/docs/en/user-guide/runtime/autogen/index.md new file mode 100644 index 000000000..01b656462 --- /dev/null +++ b/docs/docs/en/user-guide/runtime/autogen/index.md @@ -0,0 +1,89 @@ +# AutoGen in FastAgency + +The **AutoGen** runtime is a key component of FastAgency, empowering developers to create intelligent, multi-agent systems powered by large language models (LLMs). AutoGen allows agents to communicate, collaborate, and perform complex tasks autonomously while easily integrating with external APIs for real-time data and functionality. + +In this example, we will create a simple weather chatbot using **AutoGen** in FastAgency. The chatbot will enable a user to interact with a weather agent that fetches real-time weather information from an external API using OpenAPI specifications. + +## Installation + +Before getting started, make sure you have installed FastAgency with support for the AutoGen runtime by running the following command: + +```bash +pip install "fastagency[autogen]" +``` + +This installation includes the AutoGen runtime, allowing you to build multi-agent workflows and integrate external APIs seamlessly. + +## Example: Integrating a Weather API with AutoGen + +### Step-by-Step Breakdown + +#### 1. **Import Required Modules** +The example starts by importing the necessary modules from **AutoGen** and **FastAgency**. These imports lay the foundation for building and running multi-agent workflows. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:1-11] !} +``` + +#### 2. **Configure the Language Model (LLM)** +Here, the large language model is configured to use the `gpt-4o-mini` model, and the API key is retrieved from the environment. This setup ensures that both the user and weather agents can interact effectively. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:12-22] !} +``` + +#### 3. **Set Up the Weather API** +We define the OpenAPI specification URL for the weather service. This API will later be used by the weather agent to fetch real-time weather data. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:23-26] !} +``` + +#### 4. **Define the Workflow and Agents** +In this step, we create two agents: + +- **UserProxyAgent**: This agent simulates the user interacting with the system. + +- **ConversableAgent**: This agent acts as the weather agent, responsible for fetching weather data from the API. + +The workflow is registered using **[AutoGenWorkflows](../../../../api/fastagency/runtime/autogen/AutoGenWorkflows/)**. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:27-45] !} +``` + +#### 5. **Register API Functions with the Agents** +In this step, we register the weather API functions to ensure that the weather agent can call the correct functions, such as `get_daily_weather` and `get_daily_weather_weekly_get`, to retrieve the required weather data. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:46-60] !} +``` + +#### 6. **Enable Agent Interaction and Chat** +Here, the user agent initiates a chat with the weather agent, which queries the API and returns the weather information. The conversation is summarized using a method provided by the LLM. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:61-69] !} +``` + +#### 7. **Create and Run the Application** +Finally, we create the FastAgency application and launch it using the console interface. + +```python +{! docs_src/user_guide/runtime/autogen/main.py [ln:71-72] !} +``` + +### Running the Application + +```bash +cd docs/docs_src/user_guide/runtime/autogen +fastagency run main.py +``` + +Ensure you have set your OpenAI API key in the environment and that the weather API URL is accessible. The command will launch a console interface where users can input their requests and interact with the weather agent. + +--- + +This example demonstrates the power of the **AutoGen** runtime within FastAgency, showing how easy it is to integrate LLM-powered agents with real-time API services. By leveraging FastAgency, developers can quickly create interactive, scalable applications that interact with external data sources in real-time. + +For more detailed documentation, visit the [AutoGen Reference](../../../../api/fastagency/runtime/autogen/AutoGenWorkflows/). diff --git a/docs/docs/en/tutorial/custom-user-interactions/index.md b/docs/docs/en/user-guide/runtime/autogen/interactions.md similarity index 68% rename from docs/docs/en/tutorial/custom-user-interactions/index.md rename to docs/docs/en/user-guide/runtime/autogen/interactions.md index f58fcb340..bf440d8a0 100644 --- a/docs/docs/en/tutorial/custom-user-interactions/index.md +++ b/docs/docs/en/user-guide/runtime/autogen/interactions.md @@ -1,6 +1,6 @@ # Custom User Interactions -In this example, we'll demonstrate how to create custom interaction with the user using [`Chatable`](../api/fastagency/core/Chatable.md) protocol and its [`process_message`](../api/fastagency/core/Chatable.md#fastagency.core.Chatable.create_subconversation) method. +In this example, we'll demonstrate how to create custom interaction with the user using [`UI`](../api/fastagency/UI.md) protocol and its [`process_message`](../api/fastagency/UI.md#fastagency.UI.create_subconversation) method. ## Install @@ -23,7 +23,7 @@ Let's define three functions which will be available to the agents: `TextInput` is suitable for free-form text messages, ideal for open-ended queries and dialogues. This function allows the student to request exam questions from the teacher and provides some suggestions using `TextInput`. ```python -{! docs_src/tutorial/custom_user_interactions/main.py [ln:52.5,53.5,54.5,55.5,56.5,57.5,58.5,59.5,60.5,61.5,62.5,63.5,64.5,66.5,67.5,68.5,69.5,70.5] !} +{! docs_src/user_guide/custom_user_interactions/main.py [ln:52.5,53.5,54.5,55.5,56.5,57.5,58.5,59.5,60.5,61.5,62.5,63.5,64.5,66.5,67.5,68.5,69.5,70.5] !} ``` ### System Info Messages @@ -31,7 +31,7 @@ Let's define three functions which will be available to the agents: `SystemMessage` is used for operational or system-related instructions, such as logging data, and is not part of the agent dialogue. This function logs the final answers after the student completes the discussion using `SystemMessage` to log the event. ```python -{! docs_src/tutorial/custom_user_interactions/main.py [ln:72.5,73.5,74.5,75.5,76.5,77.5,78.5,79.5,80.5,81.5,82.5,83.5,84.5,85.5] !} +{! docs_src/user_guide/custom_user_interactions/main.py [ln:72.5,73.5,74.5,75.5,76.5,77.5,78.5,79.5,80.5,81.5,82.5,83.5,84.5,85.5] !} ``` ### Multiple Choice @@ -39,25 +39,25 @@ Let's define three functions which will be available to the agents: `MultipleChoice` is used for structured responses where the user must select one of several predefined options. This function retrieves the final grade for the student's submitted answers using `MultipleChoice`, presenting the user with grading options. ```python -{! docs_src/tutorial/custom_user_interactions/main.py [ln:87.5,88.5,89.5,90.5,91.5,92.5,93.5,94.5,96.5,97.5,98.5,99.5] !} +{! docs_src/user_guide/custom_user_interactions/main.py [ln:87.5,88.5,89.5,90.5,91.5,92.5,93.5,94.5,96.5,97.5,98.5,99.5] !} ``` ### Other Types of Messages -All supported messages are subclasses of the [IOMessage](../api/fastagency/core/IOMessage.md) base class. +All supported messages are subclasses of the [IOMessage](../api/fastagency/IOMessage.md) base class. ## Registering the Functions We now register these functions with the workflow, linking the `student_agent` as the caller and the `teacher_agent` as the executor. ```python -{! docs_src/tutorial/custom_user_interactions/main.py [ln:101.5,102.5,103.5,104.5,105.5,106.5,107.5,108.5,109.5,110.5,111.5,112.5,113.5,114.5,115.5,116.5,117.5,118.5,119.5,120.5,121.5,122.5,123.5] !} +{! docs_src/user_guide/custom_user_interactions/main.py [ln:101.5,102.5,103.5,104.5,105.5,106.5,107.5,108.5,109.5,110.5,111.5,112.5,113.5,114.5,115.5,116.5,117.5,118.5,119.5,120.5,121.5,122.5,123.5] !} ``` ## Define FastAgency Application Finally, we'll define the entire application: ```python -{! docs_src/tutorial/custom_user_interactions/main.py!} +{! docs_src/user_guide/custom_user_interactions/main.py!} ``` ## Run Application diff --git a/docs/docs/en/user-guide/runtime/crewai/basics.md b/docs/docs/en/user-guide/runtime/crewai/basics.md new file mode 100644 index 000000000..53def3d16 --- /dev/null +++ b/docs/docs/en/user-guide/runtime/crewai/basics.md @@ -0,0 +1,9 @@ +# CrewAI in FastAgency (Coming Soon) + +The **CrewAI** runtime is an exciting upcoming feature in FastAgency, designed to expand the framework’s capabilities for building sophisticated multi-agent workflows. **CrewAI** will enable agents to collaborate in dynamic and scalable environments, allowing for more complex use cases that involve multiple agents working together to achieve shared goals. + +Stay tuned for more updates on **CrewAI** as it is integrated into FastAgency. Once released, it will provide a powerful new option for building intelligent, multi-agent applications. + +--- + +Check back soon for detailed documentation and usage examples! For real-time updates and to join the discussion, visit our [**Discord channel**](https://discord.gg/kJjSGWrknU). diff --git a/docs/docs/en/user-guide/runtime/index.md b/docs/docs/en/user-guide/runtime/index.md new file mode 100644 index 000000000..83a86305d --- /dev/null +++ b/docs/docs/en/user-guide/runtime/index.md @@ -0,0 +1,21 @@ +# Runtimes in FastAgency + +**FastAgency** is a flexible, open-source framework designed to accelerate the transition from prototype to production for multi-agent AI workflows. If you're a developer working with agentic frameworks like **AutoGen**, FastAgency provides the tools to rapidly scale your projects into fully operational applications. A key feature of FastAgency is its support for multiple runtimes, allowing developers to switch between or combine various frameworks based on project needs. With multi-framework compatibility, FastAgency ensures that your workflows are not only optimized for today’s needs but also future-proofed as new frameworks emerge. + +## [AutoGen](autogen/) +The **AutoGen** runtime is central to FastAgency’s architecture and provides a powerful foundation for multi-agent workflows. AutoGen allows developers to define workflows in Python, leveraging large language models (LLMs) such as GPT to handle communication and collaboration between agents. It enables rapid prototyping and deployment of workflows that involve tasks like decision-making, customer service, or research. + +FastAgency seamlessly integrates with AutoGen, helping you transition from development in Jupyter notebooks to fully deployed applications. Whether you're managing conversational agents or orchestrating task automation, the AutoGen runtime in FastAgency helps you streamline the path from prototype to production. + +For more information on using AutoGen within FastAgency, visit the [AutoGen section](runtime/autogen/). + +## [CrewAI (coming soon)](crewai/) +The **CrewAI** runtime is an upcoming integration designed to further expand FastAgency’s capabilities. CrewAI offers a highly modular approach, providing greater flexibility for building more complex and dynamic workflows where agents need to collaborate autonomously. Its role-based design, combined with autonomous task delegation, makes CrewAI particularly suitable for projects involving a large number of specialized agents working in tandem. + +As the AI ecosystem continues to evolve, FastAgency’s support for CrewAI ensures that your workflows remain adaptable and ready for future innovations. This planned integration allows you to harness the advanced features of CrewAI, offering more options for scaling your multi-agent applications. + +For future updates and documentation on CrewAI, please visit the [CrewAI section](crewai/). + +--- + +With support for multiple runtimes, FastAgency enables developers to easily switch between frameworks like AutoGen and CrewAI, providing unmatched flexibility when building and deploying AI workflows. Whether you are utilizing the established features of AutoGen or preparing to explore CrewAI’s advanced capabilities, FastAgency ensures that your AI solutions are future-ready and capable of evolving alongside new technologies. diff --git a/docs/docs/en/user-guide/testing/index.md b/docs/docs/en/user-guide/testing/index.md new file mode 100644 index 000000000..8a56d6197 --- /dev/null +++ b/docs/docs/en/user-guide/testing/index.md @@ -0,0 +1,17 @@ +# Testing (Coming Soon) + +FastAgency is working on introducing a comprehensive testing framework to help developers ensure the reliability and correctness of their multi-agent workflows. This upcoming feature will allow you to write and execute tests for your workflows, ensuring agents behave as expected under various scenarios. The testing tools will seamlessly integrate into your development pipeline, enabling continuous integration (CI) support and ensuring that your applications remain robust and reliable as they scale. + +### Key Features (Planned): + +- **Automated Workflow Testing**: Define tests to simulate agent interactions and verify correct behavior. + +- **CI Integration**: Easily integrate tests into your continuous integration pipelines for automated validation. + +- **Mocking External APIs**: Simulate external API responses to test how agents handle external data sources. + +Stay tuned for more updates! To get the latest news and join the discussion, visit our [**Discord channel**](https://discord.gg/kJjSGWrknU). + +--- + +Check back soon for detailed documentation and examples once the testing framework is available! diff --git a/docs/docs/en/user-guide/ui/console/basics.md b/docs/docs/en/user-guide/ui/console/basics.md new file mode 100644 index 000000000..df64ed957 --- /dev/null +++ b/docs/docs/en/user-guide/ui/console/basics.md @@ -0,0 +1,74 @@ +# Console + +**[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)** in FastAgency provides a text-based interface for interacting with multi-agent workflows directly from the command line. This interface allows developers to quickly test and prototype workflows without needing to set up a graphical or web-based interface, making it an excellent tool for early-stage development and debugging. + +Below is an example that demonstrates how to set up a simple learning conversation between a student and a teacher using **[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)**. + +## Example: Student and Teacher Learning Chat + +This example demonstrates how to create a workflow where a student agent interacts with a teacher agent. The student asks questions, and the teacher provides responses, simulating a learning environment. The interaction is facilitated through the console using **[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)**. + +### Step-by-Step Breakdown + +#### 1. **Import Required Modules** +We begin by importing the necessary modules from **FastAgency** and **AutoGen**. These imports provide the essential building blocks for creating agents, workflows, and integrating the ConsoleUI. + +```python +{! docs_src/getting_started/main_console.py [ln:1-8] !} +``` + +- **ConversableAgent**: This class allows the creation of agents that can engage in conversational tasks. +- **[FastAgency](../../../../api/fastagency/FastAgency/)**: The core class responsible for orchestrating workflows and connecting them with UIs. +- **[UI](../../../../api/fastagency/UI/)** and **[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)**: These classes define the user interface for interaction, with ConsoleUI providing a text-based interface. +- **[AutoGenWorkflows](../../../../api/fastagency/runtime/autogen/base/AutoGenWorkflows/)**: Manages the creation and execution of multi-agent workflows. + +#### 2. **Configure the Language Model (LLM)** +Next, we configure the language model that will power the agents. In this case, we're using **GPT-4o-mini**, and the API key is retrieved from the environment. + +```python +{! docs_src/getting_started/main_console.py [ln:9-19] !} +``` + +- **Explanation**: The configuration specifies the LLM model and API key used for powering the conversation between agents. The temperature is set to `0.0` to ensure deterministic responses from the agents, making interactions consistent and reliable. This is particularly useful for scenarios where repeatability and predictability are required, such as testing. + +#### 3. **Define the Workflow and Agents** +Here, we define a simple workflow where the **Student Agent** interacts with the **Teacher Agent**. The student asks questions, and the teacher responds as a math teacher. The workflow is registered using **AutoGenWorkflows**. + +```python +{! docs_src/getting_started/main_console.py [ln:20-44] !} +``` + +- **Agent Overview**: The **Student Agent** is configured with a system message, "You are a student willing to learn," and will initiate questions during the interaction. The **Teacher Agent**, on the other hand, is set up as a math teacher and will respond to the student's questions. +- **Workflow Registration**: The workflow is registered under the name `simple_learning`. The **ConversableAgent** class is used to represent both the student and teacher agents, allowing them to communicate with each other up to 5 turns before summarizing the conversation using the `reflection_with_llm` method. + +#### 4. **Using ConsoleUI** +Finally, we instantiate **[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)** to link the workflow to a text-based console interface. This allows the user to interact with the agents via the terminal. + +```python +{! docs_src/getting_started/main_console.py [ln:47-48] !} +``` + +- **Explanation**: Here, we set up the **ConsoleUI** as the user interface for the workflow, which will allow the entire agent interaction to take place within the terminal. + +### Running the Application + +Once the workflow is set up, you can run the application using the **FastAgency CLI**. Navigate to the directory where the script is located and run the following command: + +```bash +cd docs/docs_src/getting_started +fastagency run main_console.py +``` + +This will launch the console interface, allowing you to input messages as the student and observe how the teacher agent responds. + +**Note**: Ensure that your OpenAI API key is set in the environment, as the agents rely on it to interact using GPT-4o-mini. If the API key is not correctly configured, the application may fail to retrieve LLM-powered responses. + +### Debugging Tips +If you encounter issues running the application, ensure that: +- The OpenAI API key is correctly set in your environment variables. +- All necessary packages are installed, especially the `fastagency[autogen]` dependencies. +- The API connection to GPT-4o-mini is functional and responds as expected. + +--- + +By using **[ConsoleUI](../../../../api/fastagency/ui/console/ConsoleUI/)**, developers can rapidly test and deploy multi-agent workflows in a simple, text-based environment. The flexibility of this interface makes it ideal for prototyping agent interactions before scaling them into more complex applications. You can extend this workflow or modify the agents for various use cases, such as tutoring, customer support, or information retrieval. diff --git a/docs/docs/en/user-guide/ui/fastapi/basics.md b/docs/docs/en/user-guide/ui/fastapi/basics.md new file mode 100644 index 000000000..77169abb3 --- /dev/null +++ b/docs/docs/en/user-guide/ui/fastapi/basics.md @@ -0,0 +1,17 @@ +# FastAPI (Coming Soon) + +FastAgency is expanding its capabilities with support for [**FastAPI**](https://fastapi.tiangolo.com/)! This upcoming feature will allow developers to build multi-agent applications with a powerful, fully-fledged FastAPI backend, making it even easier to integrate agents into modern web applications. + +With [**FastAPI**](https://fastapi.tiangolo.com/), you will be able to: + +- Seamlessly integrate FastAgency's agent workflows with FastAPI endpoints. + +- Create RESTful APIs that interact with multi-agent systems. + +- Build scalable, high-performance web applications powered by FastAgency agents. + +Stay tuned for more updates as this feature is being developed. To get the latest news and join the discussion, visit our [**Discord channel**](https://discord.gg/kJjSGWrknU). + +--- + +Check back soon for detailed documentation and usage examples! diff --git a/docs/docs/en/user-guide/ui/index.md b/docs/docs/en/user-guide/ui/index.md new file mode 100644 index 000000000..e867e75f2 --- /dev/null +++ b/docs/docs/en/user-guide/ui/index.md @@ -0,0 +1,26 @@ +# User Interfaces + +FastAgency provides multiple ways to interact with and manage your multi-agent workflows through various user interface (UI) options. These interfaces enable developers to interact with agents in different environments—whether it’s a simple text-based console interface for quick testing or a web-based interface for more user-friendly interaction. Each UI option is designed to suit different development needs, from early-stage prototyping to fully deployed web applications. + +Below is an overview of the supported UIs, with links to their respective pages for more detailed information. + +## Available User Interfaces + +### 1. **[ConsoleUI](./console/)** +The **ConsoleUI** provides a command-line interface for interacting with FastAgency's agent workflows. It’s an ideal choice for developers who need to quickly test and prototype workflows directly in the terminal. + +[Learn more about ConsoleUI →](./console/) + +### 2. **[MesopUI](./mesop/)** +The **MesopUI** is a web-based interface that enables users to interact with agents through a browser. This UI is designed for applications that need a more graphical and interactive experience for users. + +[Learn more about MesopUI →](./mesop/) + +### 3. **[FastAPI UI (Coming Soon)](./fastapi/)** +FastAgency will soon introduce **FastAPI UI** support, which will allow you to build multi-agent systems with a FastAPI backend. This will enable seamless integration with RESTful APIs for modern web applications. + +[Learn more about FastAPI UI (Coming Soon) →](./fastapi/) + +--- + +Each of these UI options is designed to cater to different stages of the development lifecycle, providing flexibility whether you're prototyping or deploying a production-ready application. Stay tuned for updates, and if you have any questions or want to join the community, visit our [**Discord channel**](https://discord.gg/kJjSGWrknU). diff --git a/docs/docs/en/user-guide/ui/mesop/basics.md b/docs/docs/en/user-guide/ui/mesop/basics.md new file mode 100644 index 000000000..f29f5309d --- /dev/null +++ b/docs/docs/en/user-guide/ui/mesop/basics.md @@ -0,0 +1,83 @@ +# Mesop + +**[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)** in FastAgency offers a web-based interface for interacting with multi-agent workflows. Unlike the **ConsoleUI**, which is text-based and runs in the command line, MesopUI provides a user-friendly browser interface, making it ideal for applications that need a more engaging, graphical interaction. MesopUI is perfect for building interactive web applications and enabling users to interact with agents in a more intuitive way. + +To install **FastAgency** with MesopUI support, use the following command: + +```bash +pip install "fastagency[autogen,mesop]" +``` + +This command ensures that the required dependencies for both **AutoGen** and **MesopUI** are installed. + +Below, we’ll demonstrate how to set up a basic student-teacher conversation using **[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)**. + +## Example: Student and Teacher Learning Chat + +This example shows how to create a simple learning chat where a student agent interacts with a teacher agent. The student asks questions, and the teacher provides responses, simulating a learning environment. The conversation is facilitated through the web interface using **[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)**. + +### Step-by-Step Breakdown + +#### 1. **Import Required Modules** +We begin by importing the necessary modules from **FastAgency** and **AutoGen**. These imports provide the essential building blocks for creating agents, workflows, and integrating MesopUI. + +```python +{! docs_src/getting_started/main_mesop.py [ln:1-8] !} +``` + +- **ConversableAgent**: This class allows the creation of agents that can engage in conversational tasks. +- **[FastAgency](../../../../api/fastagency/FastAgency/)**: The core class responsible for orchestrating workflows and connecting them with UIs. +- **[UI](../../../../api/fastagency/UI/)** and **[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)**: These classes define the user interface for interaction, with **MesopUI** enabling a web-based interaction. +- **[AutoGenWorkflows](../../../../api/fastagency/runtime/autogen/base/AutoGenWorkflows/)**: Manages the creation and execution of multi-agent workflows. + +#### 2. **Configure the Language Model (LLM)** +Next, we configure the language model that powers the agents. In this case, we're using **GPT-4o-mini**, and the API key is retrieved from the environment. + +```python +{! docs_src/getting_started/main_mesop.py [ln:9-19] !} +``` + +- **Explanation**: The configuration specifies the LLM model and API key used for powering the conversation between agents. The temperature is set to `0.0` to ensure deterministic responses from the agents, making interactions consistent and reliable. + +#### 3. **Define the Workflow and Agents** +Here, we define a simple workflow where the **Student Agent** interacts with the **Teacher Agent**. The student asks questions, and the teacher responds as a math teacher. The workflow is registered using **AutoGenWorkflows**. + +```python +{! docs_src/getting_started/main_mesop.py [ln:20-44] !} +``` + +- **Agent Overview**: The **Student Agent** is configured with a system message, "You are a student willing to learn," and will initiate questions during the interaction. The **Teacher Agent**, on the other hand, is set up as a math teacher and will respond to the student's questions. +- **Workflow Registration**: The workflow is registered under the name `simple_learning`. The **ConversableAgent** class is used to represent both the student and teacher agents, allowing them to communicate with each other up to 5 turns before summarizing the conversation using the `reflection_with_llm` method. + +#### 4. **Using MesopUI** +Finally, we instantiate **[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)** to link the workflow to a web-based interface. This allows the user to interact with the agents through a web browser. + +```python +from fastagency.ui.mesop import MesopUI +app = FastAgency(wf=wf, ui=MesopUI()) +``` + +- **Explanation**: Here, we set up the **MesopUI** as the user interface for the workflow, which will allow the entire agent interaction to take place through a web-based platform. + +### Running the Application + +Once the workflow is set up, you can run the application using the **FastAgency CLI**. Navigate to the directory where the script is located and run the following command: + +```bash +cd docs/docs_src/getting_started +fastagency run main_mesop.py +``` + +This will launch a local web server, and you will be able to access the MesopUI interface through your browser. The web interface will display the interaction between the student and teacher agents, allowing you to input questions and see the teacher’s responses. + +**Note**: Ensure that your OpenAI API key is set in the environment, as the agents rely on it to interact using GPT-4o-mini. If the API key is not correctly configured, the application may fail to retrieve LLM-powered responses. + +### Debugging Tips +If you encounter issues running the application, ensure that: +- The OpenAI API key is correctly set in your environment variables. +- All necessary packages are installed, especially the `fastagency[autogen,mesop]` dependencies. +- The MesopUI web interface is accessible from the browser, and no firewall is blocking the connection. + +--- + +By using **[MesopUI](../../../../api/fastagency/ui/mesop/MesopUI/)**, developers can create interactive, web-based multi-agent applications with ease. This interface is ideal for building user-friendly, browser-accessible systems, enabling users to interact with agents in a more engaging and visual environment. You can extend this workflow for more complex scenarios, such as tutoring systems, customer support, or real-time information retrieval. diff --git a/docs/docs/navigation_template.txt b/docs/docs/navigation_template.txt index f0d130cf3..0509cfbd2 100644 --- a/docs/docs/navigation_template.txt +++ b/docs/docs/navigation_template.txt @@ -4,14 +4,23 @@ search: --- - Getting Started - [Getting Started](getting-started/index.md) -- Tutorial - - [Getting Started](tutorial/index.md) - - [Using External REST APIs](tutorial/external-rest-apis/index.md) - - [Using External REST APIs with security](tutorial/external-rest-apis/security.md) - - [Custom User Interactions](tutorial/custom-user-interactions/index.md) +- [User guide](user-guide/index.md) + - [Runtimes](user-guide/runtime/index.md) + - [AutoGen](user-guide/runtime/autogen/index.md) + - [User interaction](user-guide/runtime/autogen/interactions.md) + - [CrewAI](user-guide/runtime/crewai/basics.md) + - [UI](user-guide/ui/index.md) + - [Console](user-guide/ui/console/basics.md) + - [Mesop](user-guide/ui/mesop/basics.md) + - [FastAPI](user-guide/ui/fastapi/basics.md) + - [API-s](user-guide/api/index.md) + - [OpenAPI](user-guide/api/openapi/index.md) + - [Security](user-guide/api/security.md) + - [Testing](user-guide/testing/index.md) + - [CLI](user-guide/cli/index.md) - Reference {api} -- Contributing - - [Development](getting-started/contributing/CONTRIBUTING.md) - - [Documentation](getting-started/contributing/docs.md) +- [Contributing](contributing/index.md) + - [Development](contributing/CONTRIBUTING.md) + - [Documentation](contributing/docs.md) - [Release Notes](release.md) diff --git a/docs/docs/stylesheets/extra.css b/docs/docs/stylesheets/extra.css index a21f44b4c..31d697044 100644 --- a/docs/docs/stylesheets/extra.css +++ b/docs/docs/stylesheets/extra.css @@ -5,16 +5,16 @@ https://github.com/squidfunk/mkdocs-material/blob/master/src/assets/stylesheets/ :root { /* Primary color */ - --md-primary-fg-color: #E43F2B; + --md-primary-fg-color: #E43F2B; --md-primary-fg-color--light: #E43F2B; - --md-primary-fg-color--dark: #E43F2B; + --md-primary-fg-color--dark: #E43F2B; /* Accent color */ - --md-accent-fg-color: #0080FF; - --md-accent-fg-color--transparent: #0080FF1A; + --md-accent-fg-color: #164DFF; + --md-accent-fg-color--transparent: #164DFF1A; /* Text color */ - --md-typeset-color: #ffffff; + --md-typeset-color: #ffffff; } [data-md-color-scheme="default"] { @@ -22,10 +22,10 @@ https://github.com/squidfunk/mkdocs-material/blob/master/src/assets/stylesheets/ --md-footer-bg-color: #F25C49; --md-footer-bg-color--dark: #E43F2B; - } +} [data-md-color-scheme=slate] { - --md-default-bg-color: hsla(var(--md-hue),7%,18%,1); + --md-default-bg-color: hsla(var(--md-hue), 7%, 18%, 1); /* Footer background color */ --md-footer-bg-color: #F25C49; @@ -54,10 +54,15 @@ a.internal-link::after { content: "\00A0↪"; } -.md-header__button.md-logo img, .md-header__button.md-logo svg { +.md-header__button.md-logo img, +.md-header__button.md-logo svg { height: 1.8rem; } .md-header__button.md-logo { padding: 0 .2rem; } + +.highlight .hll { + background-color: #FFF587; +} diff --git a/docs/docs_src/tutorial/__init__.py b/docs/docs_src/getting_started/__init__.py similarity index 100% rename from docs/docs_src/tutorial/__init__.py rename to docs/docs_src/getting_started/__init__.py diff --git a/docs/docs_src/tutorial/getting_started/main.py b/docs/docs_src/getting_started/main_console.py similarity index 89% rename from docs/docs_src/tutorial/getting_started/main.py rename to docs/docs_src/getting_started/main_console.py index 59615e8aa..57bcf35e6 100644 --- a/docs/docs_src/tutorial/getting_started/main.py +++ b/docs/docs_src/getting_started/main_console.py @@ -5,7 +5,7 @@ from fastagency import FastAgency from fastagency import UI from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows llm_config = { "config_list": [ @@ -21,7 +21,7 @@ @wf.register(name="simple_learning", description="Student and teacher learning chat") -def simple_workflow(io: UI, initial_message: str, session_id: str) -> str: +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: student_agent = ConversableAgent( name="Student_Agent", system_message="You are a student willing to learn.", diff --git a/docs/docs_src/getting_started/main_mesop.py b/docs/docs_src/getting_started/main_mesop.py new file mode 100644 index 000000000..29bbac98f --- /dev/null +++ b/docs/docs_src/getting_started/main_mesop.py @@ -0,0 +1,47 @@ +import os + +from autogen.agentchat import ConversableAgent + +from fastagency import FastAgency +from fastagency import UI +from fastagency.ui.mesop import MesopUI +from fastagency.runtime.autogen.base import AutoGenWorkflows + +llm_config = { + "config_list": [ + { + "model": "gpt-4o-mini", + "api_key": os.getenv("OPENAI_API_KEY"), + } + ], + "temperature": 0.8, +} + +wf = AutoGenWorkflows() + + +@wf.register(name="simple_learning", description="Student and teacher learning chat") +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: + student_agent = ConversableAgent( + name="Student_Agent", + system_message="You are a student willing to learn.", + llm_config=llm_config, + ) + teacher_agent = ConversableAgent( + name="Teacher_Agent", + system_message="You are a math teacher.", + llm_config=llm_config, + ) + + chat_result = student_agent.initiate_chat( + teacher_agent, + message=initial_message, + summary_method="reflection_with_llm", + max_turns=5, + ) + + return chat_result.summary # type: ignore[no-any-return] + + + +app = FastAgency(wf=wf, ui=MesopUI()) diff --git a/docs/docs_src/tutorial/custom_user_interactions/__init__.py b/docs/docs_src/user_guide/__init__.py similarity index 100% rename from docs/docs_src/tutorial/custom_user_interactions/__init__.py rename to docs/docs_src/user_guide/__init__.py diff --git a/docs/docs_src/tutorial/external_rest_apis/__init__.py b/docs/docs_src/user_guide/custom_user_interactions/__init__.py similarity index 100% rename from docs/docs_src/tutorial/external_rest_apis/__init__.py rename to docs/docs_src/user_guide/custom_user_interactions/__init__.py diff --git a/docs/docs_src/tutorial/custom_user_interactions/main.py b/docs/docs_src/user_guide/custom_user_interactions/main.py similarity index 94% rename from docs/docs_src/tutorial/custom_user_interactions/main.py rename to docs/docs_src/user_guide/custom_user_interactions/main.py index 3fe160b27..f248450c1 100644 --- a/docs/docs_src/tutorial/custom_user_interactions/main.py +++ b/docs/docs_src/user_guide/custom_user_interactions/main.py @@ -8,7 +8,7 @@ from fastagency import UI from fastagency.base import MultipleChoice, SystemMessage, TextInput from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows llm_config = { "config_list": [ @@ -24,7 +24,7 @@ @wf.register(name="exam_practice", description="Student and teacher chat") # type: ignore[type-var] -def exam_learning(io: UI, initial_message: str, session_id: str) -> Optional[str]: +def exam_learning(ui: UI, initial_message: str, session_id: str) -> Optional[str]: def is_termination_msg(msg: dict[str, Any]) -> bool: return msg["content"] is not None and "TERMINATE" in msg["content"] @@ -65,7 +65,7 @@ def retrieve_exam_questions( "5) Vitruvian Man", ], ) - return io.process_message(msg) + return ui.process_message(msg) except Exception as e: return f"retrieve_exam_questions() FAILED! {e}" @@ -79,7 +79,7 @@ def write_final_answers(message: Annotated[str, "Message for examiner"]) -> str: "content": message, }, ) - io.process_message(msg) + ui.process_message(msg) return "Final answers stored." except Exception as e: return f"write_final_answers() FAILED! {e}" @@ -94,7 +94,7 @@ def get_final_grade( prompt=message, choices=["A", "B", "C", "D", "F"], ) - return io.process_message(msg) + return ui.process_message(msg) except Exception as e: return f"get_final_grade() FAILED! {e}" diff --git a/docs/docs_src/tutorial/getting_started/__init__.py b/docs/docs_src/user_guide/external_rest_apis/__init__.py similarity index 100% rename from docs/docs_src/tutorial/getting_started/__init__.py rename to docs/docs_src/user_guide/external_rest_apis/__init__.py diff --git a/docs/docs_src/tutorial/external_rest_apis/main.py b/docs/docs_src/user_guide/external_rest_apis/main.py similarity index 91% rename from docs/docs_src/tutorial/external_rest_apis/main.py rename to docs/docs_src/user_guide/external_rest_apis/main.py index 996c76423..ea88cfcc0 100644 --- a/docs/docs_src/tutorial/external_rest_apis/main.py +++ b/docs/docs_src/user_guide/external_rest_apis/main.py @@ -6,7 +6,7 @@ from fastagency import FastAgency from fastagency import UI from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency.api.openapi import OpenAPI @@ -27,7 +27,7 @@ @wf.register(name="simple_weather", description="Weather chat") -def weather_workflow(io: UI, initial_message: str, session_id: str) -> str: +def weather_workflow(ui: UI, initial_message: str, session_id: str) -> str: weather_api = OpenAPI.create(openapi_url=WEATHER_OPENAPI_URL) diff --git a/docs/docs_src/tutorial/external_rest_apis/security.py b/docs/docs_src/user_guide/external_rest_apis/security.py similarity index 93% rename from docs/docs_src/tutorial/external_rest_apis/security.py rename to docs/docs_src/user_guide/external_rest_apis/security.py index 669837c86..c2229c77c 100644 --- a/docs/docs_src/tutorial/external_rest_apis/security.py +++ b/docs/docs_src/user_guide/external_rest_apis/security.py @@ -6,7 +6,7 @@ from fastagency import FastAgency from fastagency import UI from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency.api.openapi.client import OpenAPI from fastagency.api.openapi.security import APIKeyHeader @@ -26,7 +26,7 @@ @wf.register(name="simple_weather_with_security", description="Weather chat with security") -def weather_workflow_with_security(io: UI, initial_message: str, session_id: str) -> str: +def weather_workflow_with_security(ui: UI, initial_message: str, session_id: str) -> str: weather_client = OpenAPI.create(openapi_url=WEATHER_OPENAPI_URL) diff --git a/fastagency/runtimes/__init__.py b/docs/docs_src/user_guide/runtime/__init__.py similarity index 100% rename from fastagency/runtimes/__init__.py rename to docs/docs_src/user_guide/runtime/__init__.py diff --git a/docs/docs_src/user_guide/runtime/autogen/__init__.py b/docs/docs_src/user_guide/runtime/autogen/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/docs/docs_src/user_guide/runtime/autogen/main.py b/docs/docs_src/user_guide/runtime/autogen/main.py new file mode 100644 index 000000000..93d008800 --- /dev/null +++ b/docs/docs_src/user_guide/runtime/autogen/main.py @@ -0,0 +1,71 @@ +import os + +from autogen import UserProxyAgent +from autogen.agentchat import ConversableAgent + +from fastagency import FastAgency +from fastagency import UI +from fastagency.ui.console import ConsoleUI +from fastagency.runtime.autogen.base import AutoGenWorkflows + +from fastagency.api.openapi import OpenAPI + + +llm_config = { + "config_list": [ + { + "model": "gpt-4o-mini", + "api_key": os.getenv("OPENAI_API_KEY"), + } + ], + "temperature": 0.0, +} + +openapi_url="https://weather.tools.fastagency.ai/openapi.json" + +weather_api = OpenAPI.create(openapi_url=openapi_url) + +wf = AutoGenWorkflows() + +@wf.register(name="simple_weather", description="Weather chat") # type: ignore[type-var] +def weather_workflow(wf: AutoGenWorkflows, ui: UI, initial_message: str, session_id: str) -> str: + + user_agent = UserProxyAgent( + name="User_Agent", + system_message="You are a user agent", + llm_config=llm_config, + human_input_mode="NEVER", + ) + weather_agent = ConversableAgent( + name="Weather_Agent", + system_message="You are a weather agent", + llm_config=llm_config, + human_input_mode="NEVER", + ) + + wf.register_api( # type: ignore[attr-defined] + api=weather_api, + callers=[user_agent], + executors=[weather_agent], + functions=[ + { + "get_daily_weather_daily_get": { + "name": "get_daily_weather", + "description": "Get the daily weather", + } + }, + "get_daily_weather_weekly_get" + ] + ) + + chat_result = user_agent.initiate_chat( + weather_agent, + message=initial_message, + summary_method="reflection_with_llm", + max_turns=3, + ) + + return chat_result.summary # type: ignore[no-any-return] + + +app = FastAgency(wf=wf, ui=ConsoleUI()) diff --git a/examples/autogen.ipynb b/examples/autogen.ipynb index 55d078d23..48e172ad0 100644 --- a/examples/autogen.ipynb +++ b/examples/autogen.ipynb @@ -13,9 +13,9 @@ "from autogen.agentchat import ConversableAgent\n", "from fixtures import openai_gpt4o_mini_llm_config\n", "\n", - "from fastagency.core import Chatable, IOMessage\n", - "from fastagency.core.io.console import ConsoleIO\n", - "from fastagency.core.runtimes.autogen import AutoGenWorkflows\n", + "from fastagency import UI, IOMessage\n", + "from fastagency.ui.console import ConsoleUI\n", + "from fastagency.runtimes.autogen import AutoGenWorkflows\n", "from fastagency.logging import get_logger" ] }, @@ -52,7 +52,7 @@ "\n", "\n", "@wf.register(name=\"simple_learning\", description=\"Student and teacher learning chat\")\n", - "def simple_workflow(io: Chatable, initial_message: str, session_id: str) -> str:\n", + "def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str:\n", " student_agent = ConversableAgent(\n", " name=\"Student_Agent\",\n", " system_message=\"You are a student willing to learn.\",\n", @@ -82,9 +82,9 @@ "source": [ "def run_workflow(name: str, initial_message: str):\n", "\n", - " io = ConsoleIO()\n", + " io = ConsoleUI()\n", "\n", - " io.process_message(\n", + " ui.process_message(\n", " IOMessage.create(\n", " sender=\"user\",\n", " recipient=\"workflow\",\n", @@ -98,7 +98,7 @@ "\n", " result = wf.run(name=name, session_id=\"session_id\", io=io.create_subconversation(), initial_message=initial_message)\n", "\n", - " io.process_message(\n", + " ui.process_message(\n", " IOMessage.create(\n", " sender=\"user\",\n", " recipient=\"workflow\",\n", @@ -453,11 +453,11 @@ "source": [ "# wf = AutoGenWorkflows()\n", "\n", - "from fastagency.core.base import MultipleChoice, SystemMessage, TextInput\n", + "from fastagency.base import MultipleChoice, SystemMessage, TextInput\n", "\n", "\n", "@wf.register(name=\"exam_practice\", description=\"Student and teacher chat\")\n", - "def exam_learning(io: Chatable, initial_message: str, session_id: str) -> str:\n", + "def exam_learning(ui: UI, initial_message: str, session_id: str) -> str:\n", "\n", " def is_termination_msg(msg: str) -> bool:\n", " return msg[\"content\"] is not None and \"TERMINATE\" in msg[\"content\"]\n", @@ -491,7 +491,7 @@ " prompt=message,\n", " suggestions=[\"1) Mona Lisa\", \"2) Innovations\", \"3) Florence at the time of Leonardo\", \"4) The Last Supper\", \"5) Vit\"],\n", " )\n", - " return io.process_message(msg)\n", + " return ui.process_message(msg)\n", " except Exception as e:\n", " logger.error(f\"retrieve_exam_questions() FAILED! {e}\")\n", " return f\"retrieve_exam_questions() FAILED! {e}\"\n", @@ -506,7 +506,7 @@ " \"content\": message,\n", " },\n", " )\n", - " io.process_message(msg)\n", + " ui.process_message(msg)\n", " return \"Final answers stored.\"\n", " except Exception as e:\n", " logger.error(f\"write_final_answers() FAILED! {e}\")\n", @@ -520,7 +520,7 @@ " prompt=message,\n", " choices=[\"A\", \"B\", \"C\", \"D\", \"F\"],\n", " )\n", - " return io.process_message(msg)\n", + " return ui.process_message(msg)\n", " except Exception as e:\n", " logger.error(f\"get_final_grade() FAILED! {e}\")\n", " return f\"get_final_grade() FAILED! {e}\"\n", diff --git a/examples/cli/main_console.py b/examples/cli/main_console.py index ee2898bef..2d8142bad 100644 --- a/examples/cli/main_console.py +++ b/examples/cli/main_console.py @@ -4,7 +4,7 @@ from fastagency import UI from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency import FastAgency @@ -22,7 +22,7 @@ wf = AutoGenWorkflows() @wf.register(name="simple_learning", description="Student and teacher learning chat") -def simple_workflow(io: UI, initial_message: str, session_id: str) -> str: +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: student_agent = ConversableAgent( name="Student_Agent", system_message="You are a student willing to learn.", diff --git a/examples/cli/main_mesop.py b/examples/cli/main_mesop.py index 7d63eb774..6c90b2f63 100644 --- a/examples/cli/main_mesop.py +++ b/examples/cli/main_mesop.py @@ -4,7 +4,7 @@ from fastagency import UI from fastagency.ui.mesop import MesopUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency import FastAgency @@ -22,7 +22,7 @@ wf = AutoGenWorkflows() @wf.register(name="simple_learning", description="Student and teacher learning chat") -def simple_workflow(io: UI, initial_message: str, session_id: str) -> str: +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: student_agent = ConversableAgent( name="Student_Agent", system_message="You are a student willing to learn.", diff --git a/examples/cli/main_user_proxy.py b/examples/cli/main_user_proxy.py index b7e1f1ef8..2f8ad83f2 100644 --- a/examples/cli/main_user_proxy.py +++ b/examples/cli/main_user_proxy.py @@ -4,7 +4,7 @@ from fastagency import UI from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency.api.openapi.client import OpenAPI from fastagency.api.openapi.security import APIKeyHeader @@ -24,7 +24,7 @@ wf = AutoGenWorkflows() @wf.register(name="weatherman_workflow", description="Weatherman chat") -def simple_workflow(io: UI, initial_message: str, session_id: str) -> str: +def simple_workflow(ui: UI, initial_message: str, session_id: str) -> str: user_proxy = UserProxyAgent( name="User_Proxy", diff --git a/fastagency/__about__.py b/fastagency/__about__.py index 41523a223..b6791e5f2 100644 --- a/fastagency/__about__.py +++ b/fastagency/__about__.py @@ -1,3 +1,3 @@ """The fastest way to bring multi-agent workflows to production.""" -__version__ = "0.0.1" +__version__ = "0.1.0b0" diff --git a/fastagency/app.py b/fastagency/app.py index 7523ead33..5e892d2fb 100644 --- a/fastagency/app.py +++ b/fastagency/app.py @@ -13,7 +13,7 @@ def __init__(self, wf: Workflows, ui: UI) -> None: Args: wf (Workflows): The workflows object to use - ui (Chatable): The UI object to use + ui (UI): The UI object to use """ self._wf = wf self._ui = ui diff --git a/fastagency/base.py b/fastagency/base.py index c530addbd..9574f898e 100644 --- a/fastagency/base.py +++ b/fastagency/base.py @@ -264,7 +264,7 @@ def run_workflow( Args: wf (Workflows): The workflows object to use. - ui (Chatable): The UI object to use. + ui (UI): The UI object to use. name (Optional[str]): The name of the workflow to run. If not provided, the default workflow will be run. initial_message (Optional[str], optional): The initial message to send to the workflow. If not provided, a default message will be sent. Defaults to None. """ diff --git a/fastagency/runtime/__init__.py b/fastagency/runtime/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/fastagency/runtimes/autogen/__init__.py b/fastagency/runtime/autogen/__init__.py similarity index 100% rename from fastagency/runtimes/autogen/__init__.py rename to fastagency/runtime/autogen/__init__.py diff --git a/fastagency/runtimes/autogen/base.py b/fastagency/runtime/autogen/base.py similarity index 99% rename from fastagency/runtimes/autogen/base.py rename to fastagency/runtime/autogen/base.py index 0cd1f7604..9a7225277 100644 --- a/fastagency/runtimes/autogen/base.py +++ b/fastagency/runtime/autogen/base.py @@ -183,7 +183,7 @@ def __init__(self, ui: UI) -> None: self.messages: list[IOMessage] = [] if not isinstance(self.ui, UI): - raise ValueError("The ui object must be an instance of Chatable.") + raise ValueError("The ui object must be an instance of UI.") def _process_message_chunk(self, chunk: str) -> bool: if self.current_message.process_chunk(chunk): diff --git a/fastagency/ui/console/base.py b/fastagency/ui/console/base.py index e4b0e2c9c..462a2102e 100644 --- a/fastagency/ui/console/base.py +++ b/fastagency/ui/console/base.py @@ -34,7 +34,7 @@ def __init__(self, super_conversation: Optional["ConsoleUI"] = None) -> None: """Initialize the console UI object. Args: - super_conversation (Optional[Chatable], optional): The super conversation. Defaults to None. + super_conversation (Optional[UI], optional): The super conversation. Defaults to None. """ self.super_conversation: Optional[ConsoleUI] = super_conversation self.sub_conversations: list[ConsoleUI] = [] diff --git a/tests/cli/test_discover.py b/tests/cli/test_discover.py index abbb7e4d8..7fc8541d3 100644 --- a/tests/cli/test_discover.py +++ b/tests/cli/test_discover.py @@ -17,7 +17,7 @@ def import_fixture() -> Generator[dict[str, Any], None, None]: # Create a temporary file for testing file_content = """ from fastagency.ui.console import ConsoleUI -from fastagency.runtimes.autogen.base import AutoGenWorkflows +from fastagency.runtime.autogen.base import AutoGenWorkflows from fastagency import FastAgency wf = AutoGenWorkflows() diff --git a/tests/docs_src/external_rest_apis/test_with_security.py b/tests/docs_src/external_rest_apis/test_with_security.py index c91e5506a..2656571bd 100644 --- a/tests/docs_src/external_rest_apis/test_with_security.py +++ b/tests/docs_src/external_rest_apis/test_with_security.py @@ -14,7 +14,7 @@ def test_cli_with_security(monkeypatch: pytest.MonkeyPatch) -> None: monkeypatch.setattr("builtins.input", InputMock([INPUT_MESSAGE])) result = runner.invoke( - app, ["run", "docs/docs_src/tutorial/external_rest_apis/security.py"] + app, ["run", "docs/docs_src/user_guide/external_rest_apis/security.py"] ) assert INPUT_MESSAGE in result.stdout assert "get_hourly_weather_hourly_get" in result.stdout diff --git a/tests/docs_src/external_rest_apis/test_without_security.py b/tests/docs_src/external_rest_apis/test_without_security.py index f2292d9e8..717fc49bb 100644 --- a/tests/docs_src/external_rest_apis/test_without_security.py +++ b/tests/docs_src/external_rest_apis/test_without_security.py @@ -14,7 +14,7 @@ def test_cli_without_security(monkeypatch: pytest.MonkeyPatch) -> None: monkeypatch.setattr("builtins.input", InputMock([INPUT_MESSAGE])) result = runner.invoke( - app, ["run", "docs/docs_src/tutorial/external_rest_apis/main.py"] + app, ["run", "docs/docs_src/user_guide/external_rest_apis/main.py"] ) assert INPUT_MESSAGE in result.stdout assert "get_daily_weather_daily_get" in result.stdout diff --git a/tests/examples/__init__.py b/tests/examples/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/tests/test_autogen.py b/tests/test_autogen.py index 0ebec20c4..648482330 100644 --- a/tests/test_autogen.py +++ b/tests/test_autogen.py @@ -4,8 +4,8 @@ from autogen.agentchat import ConversableAgent, UserProxyAgent from fastagency import UI, IOMessage -from fastagency.runtimes.autogen import AutoGenWorkflows -from fastagency.runtimes.autogen.base import _findall, _match +from fastagency.runtime.autogen import AutoGenWorkflows +from fastagency.runtime.autogen.base import _findall, _match from fastagency.ui.console import ConsoleUI from tests.conftest import InputMock diff --git a/tests/ui/console/test_base.py b/tests/ui/console/test_base.py index 0ebab2f5c..acc92ce1a 100644 --- a/tests/ui/console/test_base.py +++ b/tests/ui/console/test_base.py @@ -3,7 +3,7 @@ import pytest from fastagency.app import FastAgency -from fastagency.runtimes.autogen import AutoGenWorkflows +from fastagency.runtime.autogen import AutoGenWorkflows from fastagency.ui.console import ConsoleUI