WYV-1186 Create API to replay webhook callbacks (#4)

This commit is contained in:
Suchintan
2024-03-02 00:38:32 -05:00
committed by GitHub
parent 9eddb3d812
commit 861114794a
3 changed files with 88 additions and 4 deletions

View File

@@ -692,16 +692,19 @@ class ForgeAgent(Agent):
# Wait for all tasks to complete before generating the links for the artifacts
await app.ARTIFACT_MANAGER.wait_for_upload_aiotasks_for_task(task.task_id)
if not task.webhook_callback_url:
await self.execute_task_webhook(task=task, last_step=last_step, api_key=api_key)
async def execute_task_webhook(self, task: Task, last_step: Step, api_key: str | None) -> None:
if not api_key:
LOG.warning(
"Task has no webhook callback url. Not sending task response",
"Request has no api key. Not sending task response",
task_id=task.task_id,
)
return
if not api_key:
if not task.webhook_callback_url:
LOG.warning(
"Request has no api key. Not sending task response",
"Task has no webhook callback url. Not sending task response",
task_id=task.task_id,
)
return
@@ -732,6 +735,7 @@ class ForgeAgent(Agent):
if not task_from_db:
LOG.error("Failed to get task from db when sending task response")
raise TaskNotFound(task_id=task.task_id)
task = task_from_db
if not task.webhook_callback_url:
LOG.info("Task has no webhook callback url. Not sending task response")

View File

@@ -218,6 +218,36 @@ async def get_task(
)
@base_router.post(
"/tasks/{task_id}/retry_webhook",
tags=["agent"],
response_model=TaskResponse,
)
async def retry_webhook(
request: Request,
task_id: str,
current_org: Organization = Depends(org_auth_service.get_current_org),
x_api_key: Annotated[str | None, Header()] = None,
) -> TaskResponse:
agent = request["agent"]
task_obj = await agent.db.get_task(task_id, organization_id=current_org.organization_id)
if not task_obj:
raise HTTPException(
status_code=status.HTTP_404_NOT_FOUND,
detail=f"Task not found {task_id}",
)
# get latest step
latest_step = await agent.db.get_latest_step(task_id, organization_id=current_org.organization_id)
if not latest_step:
return task_obj.to_task_response()
# retry the webhook
await agent.execute_task_webhook(task=task_obj, last_step=latest_step, api_key=x_api_key)
return task_obj.to_task_response()
@base_router.get("/internal/tasks/{task_id}", response_model=list[Task])
async def get_task_internal(
request: Request,

50
skyvern/webeye/README.md Normal file
View File

@@ -0,0 +1,50 @@
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*
- [WebHuman Automation Tool](#webhuman-automation-tool)
- [Getting Started](#getting-started)
- [Prerequisites](#prerequisites)
- [Installation](#installation)
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
# WebHuman Automation Tool
WebHuman is a Python-based automation tool that uses Playwright to interact with web pages.
## Getting Started
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
### Prerequisites
Before you begin, ensure you have the following installed:
- [Python 3.11](https://www.python.org/downloads/)
- [Poetry](https://python-poetry.org/docs/#installation)
### Installation
1. **Clone the repository**
```sh
git clone https://your-repository-url.git
cd webhuman
```
2. **Install dependencies**
```sh
poetry install
```
3. *Define the following environment variables*
```sh
export
```
4. **Run the project**
```sh
python web_eye.py <url>
```