Skip to content

Commit

Permalink
Merge branch 'main' into playwright-coverage
Browse files Browse the repository at this point in the history
  • Loading branch information
davorrunje authored Nov 15, 2024
2 parents 72b399d + c4b0305 commit 40671bf
Show file tree
Hide file tree
Showing 265 changed files with 3,296 additions and 133 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/check-broken-links-in-docs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,5 @@ jobs:
uses: ruzickap/action-my-broken-link-checker@v2
with:
url: https://fastagency.ai
cmd_params: '--buffer-size=8192 --max-connections=1 --color=always --header="User-Agent:Mozilla/5.0(Firefox/97.0)" --exclude="(localhost:8000|linkedin.com|fonts.gstatic.com|reddit.com|code.visualstudio.com)" --max-connections-per-host=1 --rate-limit=1 --max-response-body-size=20000000'
cmd_params: '--buffer-size=8192 --max-connections=1 --color=always --header="User-Agent:Mozilla/5.0(Firefox/97.0)" --exclude="(localhost:8000|linkedin.com|fonts.gstatic.com|reddit.com|code.visualstudio.com|facebook.com|openai.com|java.com|whatsapp.com)" --max-connections-per-host=1 --rate-limit=1 --max-response-body-size=20000000'
debug: true
6 changes: 3 additions & 3 deletions .secrets.baseline
Original file line number Diff line number Diff line change
Expand Up @@ -151,15 +151,15 @@
"filename": "docs/docs/en/tutorials/whatsapp/index.md",
"hashed_secret": "52e0d11a70cdb70d4c51064d08bd8f179ebb8bb4",
"is_verified": false,
"line_number": 75,
"line_number": 50,
"is_secret": false
},
{
"type": "Secret Keyword",
"filename": "docs/docs/en/tutorials/whatsapp/index.md",
"hashed_secret": "bc39a40e023f4ffb425b82830f86a464e5ea1072",
"is_verified": false,
"line_number": 76,
"line_number": 51,
"is_secret": false
}
],
Expand Down Expand Up @@ -252,5 +252,5 @@
}
]
},
"generated_at": "2024-11-11T13:22:59Z"
"generated_at": "2024-11-13T14:43:44Z"
}
9 changes: 6 additions & 3 deletions .semgrepignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
docs/overrides/main.html
docs/docs_src/getting_started/mesop/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/nats_n_fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/no_auth/mesop/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/no_auth/fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/no_auth/nats_n_fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/basic_auth/mesop/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/basic_auth/fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
docs/docs_src/getting_started/basic_auth/nats_n_fastapi/my_fastagency_app/.devcontainer/docker-compose.yml
27 changes: 27 additions & 0 deletions docs/docs/en/snippets/creating_whatsapp_api_key.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
#### Create Infobip Account
**Step 1**: If you don’t have a Infobip account, you’ll need to sign up:

- Go to [Infobip Portal](https://www.infobip.com/signup){target="_blank"} and create account

**Step 2**: Settings

- In the **Customize your experience** section, choose:
1. **WhatsApp**
2. ***Customer support***
3. ***By using code (APIs, SDKs)***

**Step 3**: Test WhatsApp API

- After you have created the account, you will be redirected [Infobip Homepage](https://portal.infobip.com/homepage){target="_blank"}.
- Check the **Send your first message** option and send a WhatsApp message to yourself.
- In this tutorial, we will only be sending messages **to your own number**

!!! note "Important"
Upon receiving this message, please **reply** (e.g., with "Hi") to initiate the session. Note that sessions expire after 24 hours. If your session has expired, simply send another message to create a new one.

Copy the **API Key** from the top-right corner and continue with the next steps.

**Step 4**: Register your WhatsApp sender (Optional)

- By default, Infobip number will be used as the sender for your messages.
- If you wish to create a new sender phone number and customize your branding (including your name and logo), click on [Register Sender](https://portal.infobip.com/channels-and-numbers/channels/whatsapp/senders){target="_blank"}.
8 changes: 4 additions & 4 deletions docs/docs/en/tutorials/mesop_template.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ You could also use virtual environment managers such as [venv](https://docs.pyth
4. Executing the `cookiecutter` command will create the following file structure:

```console
{!> docs_src/getting_started/mesop/folder_structure.txt !}
{!> docs_src/getting_started/no_auth/mesop/folder_structure.txt !}
```

5. To run LLM-based applications, you need an API key for the LLM used. The most commonly used LLM is [OpenAI](https://platform.openai.com/docs/models). To use it, create an [OpenAI API Key](https://openai.com/index/openai-api/) and set it as an environment variable in the terminal using the following command:
Expand All @@ -60,7 +60,7 @@ You could also use virtual environment managers such as [venv](https://docs.pyth

7. Once the project is opened, you will get the following option to reopen it in a devcontainer:

<img src="../getting-started/images/reopen-in-container.png" width="600" class="center">
<img src="../../user-guide/getting-started/images/reopen-in-container.png" width="600" class="center">

8. After reopening the project in devcontainer, you can verify that the setup is correct by running the provided tests with the following command:

Expand Down Expand Up @@ -121,7 +121,7 @@ You need to define the workflow that your application will use. This is where yo
<details>
<summary>main.py</summary>
```python
{! docs_src/getting_started/mesop/my_fastagency_app/my_fastagency_app/deployment/main.py [ln:1-10] !}
{! docs_src/getting_started/no_auth/mesop/my_fastagency_app/my_fastagency_app/deployment/main.py [ln:1-10] !}
```

</details>
Expand All @@ -132,7 +132,7 @@ You need to define the workflow that your application will use. This is where yo
The FastAgency app is created, using the registered workflows (**`wf`**) and web-based user interface ([**`MesopUI`**](../../api/fastagency/ui/mesop/MesopUI.md)). This makes the conversation between agents and the user interactive.

```python
{! docs_src/getting_started/mesop/my_fastagency_app/my_fastagency_app/deployment/main.py [ln:6-10] !}
{! docs_src/getting_started/no_auth/mesop/my_fastagency_app/my_fastagency_app/deployment/main.py [ln:6-10] !}
```

For more information, visit [**Mesop User Guide**](../../user-guide/ui/mesop/basics.md){target="_blank"}.
Expand Down
27 changes: 1 addition & 26 deletions docs/docs/en/tutorials/whatsapp/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,33 +36,8 @@ To create [Bing Web Search](https://www.microsoft.com/en-us/bing/apis/pricing){t
!!! note
You will need to create **Microsoft Azure** Account.

#### Create Infobip Account
**Step 1**: If you don’t have a Infobip account, you’ll need to sign up:

- Go to [Infobip Portal](https://www.infobip.com/signup){target="_blank"} and create account

**Step 2**: Settings

- In the **Customize your experience** section, choose:
1. **WhatsApp**
2. ***Customer support***
3. ***By using code (APIs, SDKs)***

**Step 3**: Test WhatsApp API

- After you have created the account, you will be redirected [Infobip Homepage](https://portal.infobip.com/homepage){target="_blank"}.
- Check the **Send your first message** option and send a WhatsApp message to yourself.
- In this tutorial, we will only be sending messages **to your own number**

!!! note "Important"
Upon receiving this message, please **reply** (e.g., with "Hi") to initiate the session. Note that sessions expire after 24 hours. If your session has expired, simply send another message to create a new one.

Copy the **API Key** from the top-right corner and continue with the next steps.

**Step 4**: Register your WhatsApp sender (Optional)

- By default, Infobip number will be used as the sender for your messages.
- If you wish to create a new sender phone number and customize your branding (including your name and logo), click on [Register Sender](https://portal.infobip.com/channels-and-numbers/channels/whatsapp/senders){target="_blank"}.
{! docs/en/snippets/creating_whatsapp_api_key.md !}

#### Set Up Your API Keys in the Environment

Expand Down
20 changes: 10 additions & 10 deletions docs/docs/en/user-guide/adapters/fastapi/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ Alternatively, you can use **pip + venv**.
To get started, 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/getting_started/fastapi/my_fastagency_app/my_fastagency_app/workflow.py [ln:1-47] !}
{! docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/workflow.py [ln:1-47] !}
```

#### 2. **Import Required Modules**
Expand All @@ -233,23 +233,23 @@ To get started, define the workflow that your application will use. This is wher
Next, import the required modules from the **FastAgency**. Import the [**`FastAPIAdapter`**](../../../api/fastagency/adapters/fastapi/FastAPIAdapter.md) class to expose the workflows as a [**REST API**](https://en.wikipedia.org/wiki/REST){target="_blank"}.

```python hl_lines="3"
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py [ln:1-4] !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py [ln:1-4] !}
```

=== "Custom REST API and Websocket"

Next, import the required modules from the **FastAgency** and **AutoGen**. These imports provide the essential building blocks for creating agents, workflows, and integrating with the custom client. Additionally, import the [**`FastAPIAdapter`**](../../../api/fastagency/adapters/fastapi/FastAPIAdapter.md) and [**`HTMLResponse`**](https://fastapi.tiangolo.com/advanced/custom-response/#html-response){target="_blank"} class to expose the workflows as a [**REST API**](https://en.wikipedia.org/wiki/REST){target="_blank"}.

```python hl_lines="6 9"
{!> docs_src/getting_started/fastapi/main_fastapi_custom_client.py [ln:1-10] !}
{!> docs_src/getting_started/no_auth/fastapi/main_fastapi_custom_client.py [ln:1-10] !}
```

#### 3. **Define FastAgency Application**

Create an instance of the [**`FastAPIAdapter`**](../../../api/fastagency/adapters/fastapi/FastAPIAdapter.md) and pass your workflow to it. Then, include a router to the [**FastAPI**](https://fastapi.tiangolo.com/){target="_blank"} application. The adapter will have all [**REST API**](https://en.wikipedia.org/wiki/REST){target="_blank"} and [**WebSocket**](https://en.wikipedia.org/wiki/WebSocket){target="_blank"} routes for communicating with the client.

```python hl_lines="1 4"
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py [ln:8-11] !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py [ln:8-11] !}
```

=== "Mesop"
Expand All @@ -260,7 +260,7 @@ Create an instance of the [**`FastAPIAdapter`**](../../../api/fastagency/adapter

!!! note "main_2_mesop.py"
```python
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_2_mesop.py [ln:1-15] !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_2_mesop.py [ln:1-15] !}
```

=== "Custom REST API and Websocket"
Expand All @@ -270,7 +270,7 @@ Create an instance of the [**`FastAPIAdapter`**](../../../api/fastagency/adapter
Finally, use the [**HTML Response**](https://fastapi.tiangolo.com/advanced/custom-response/#html-response){target="_blank"} from FastAPI to serve the custom client code.

```python
{!> docs_src/getting_started/fastapi/main_fastapi_custom_client.py [ln:12-98,146-148] !}
{!> docs_src/getting_started/no_auth/fastapi/main_fastapi_custom_client.py [ln:12-98,146-148] !}
```

### Complete Application Code
Expand All @@ -282,21 +282,21 @@ Please copy and paste the following code into the same folder, using the file na
<details>
<summary>workflow.py</summary>
```python
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/workflow.py !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/workflow.py !}
```
</details>

<details>
<summary>main_1_fastapi.py</summary>
```python
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_1_fastapi.py !}
```
</details>

<details>
<summary>main_2_mesop.py</summary>
```python
{!> docs_src/getting_started/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_2_mesop.py !}
{!> docs_src/getting_started/no_auth/fastapi/my_fastagency_app/my_fastagency_app/deployment/main_2_mesop.py !}
```
</details>

Expand All @@ -305,7 +305,7 @@ Please copy and paste the following code into the same folder, using the file na
<details>
<summary>main_fastapi_custom_client.py</summary>
```python
{!> docs_src/getting_started/fastapi/main_fastapi_custom_client.py !}
{!> docs_src/getting_started/no_auth/fastapi/main_fastapi_custom_client.py !}
```
</details>

Expand Down
Loading

0 comments on commit 40671bf

Please sign in to comment.