|
## Request & Response Examples |
|
The server provides a simple layer for managing agent processes. |
|
|
|
### API Resources |
|
|
|
- [POST /start](#get-magazines) |
|
- [POST /stop](#get-magazinesid) |
|
- [POST /ping](#post-magazinesidarticles) |
|
|
|
|
|
### POST /start |
|
This api starts an agent with given graph and override properties. The started agent will join into the specified channel, and subscribe to the uid which your browser/device's rtc use to join. |
|
|
|
| Param | Description | |
|
| -------- | ------- | |
|
| request_id | any uuid for tracing purpose | |
|
| channel_name | channel name, it needs to be the same with the one your browser/device joins, agent needs to stay with your browser/device in the same channel to communicate | |
|
| user_uid | the uid which your browser/device's rtc use to join, agent needs to know your rtc uid to subscribe your audio | |
|
| bot_uid | optional, the uid bot used to join rtc | |
|
| graph_name | the graph to be used when starting agent, will find in property.json | |
|
| properties | additional properties to override in property.json, the override will not change original property.json, only the one agent used to start | |
|
| timeout | determines how long the agent will remain active without receiving any pings. If the timeout is set to `-1`, the agent will not terminate due to inactivity. By default, the timeout is set to 60 seconds, but this can be adjusted using the `WORKER_QUIT_TIMEOUT_SECONDS` variable in your `.env` file. | |
|
|
|
Example: |
|
```bash |
|
curl 'http://localhost:8080/start' \ |
|
-H 'Content-Type: application/json' \ |
|
--data-raw '{ |
|
"request_id": "c1912182-924c-4d15-a8bb-85063343077c", |
|
"channel_name": "test", |
|
"user_uid": 176573, |
|
"graph_name": "camera_va_openai_azure", |
|
"properties": { |
|
"openai_chatgpt": { |
|
"model": "gpt-4o" |
|
} |
|
} |
|
}' |
|
``` |
|
|
|
### POST /stop |
|
This api stops the agent you started |
|
|
|
| Param | Description | |
|
| -------- | ------- | |
|
| request_id | any uuid for tracing purpose | |
|
| channel_name | channel name, the one you used to start the agent | |
|
|
|
Example: |
|
```bash |
|
curl 'http://localhost:8080/stop' \ |
|
-H 'Content-Type: application/json' \ |
|
--data-raw '{ |
|
"request_id": "c1912182-924c-4d15-a8bb-85063343077c", |
|
"channel_name": "test" |
|
}' |
|
``` |
|
|
|
|
|
### POST /ping |
|
This api sends a ping to the server to indicate connection is still alive. This is not needed if you specify `timeout:-1` when starting the agent, otherwise the agent will quit if not receiving ping after timeout in seconds. |
|
|
|
| Param | Description | |
|
| -------- | ------- | |
|
| request_id | any uuid for tracing purpose | |
|
| channel_name | channel name, the one you used to start the agent | |
|
|
|
Example: |
|
```bash |
|
curl 'http://localhost:8080/ping' \ |
|
-H 'Content-Type: application/json' \ |
|
--data-raw '{ |
|
"request_id": "c1912182-924c-4d15-a8bb-85063343077c", |
|
"channel_name": "test" |
|
}' |
|
``` |
|
|