Spaces:
Sleeping
Sleeping
File size: 2,751 Bytes
a7c2cd2 30c85ad 32c2587 f039650 32c2587 f039650 60da9c8 4a7815d 32c2587 f039650 32c2587 ea4e048 32c2587 16eaf19 f40fa43 32c2587 95feb70 30c85ad 48225dd f420a36 f039650 bcf795e 32c2587 30c85ad f039650 f420a36 f039650 32c2587 ea4e048 30c85ad ea4e048 f420a36 48225dd f039650 30c85ad ea4e048 32c2587 ea4e048 32c2587 30c85ad 32c2587 a7c2cd2 876efb6 b0bc07c 4a7815d b0bc07c 4a7815d b0bc07c 30c85ad 32c2587 6020a54 16eaf19 f40fa43 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
import os
from datetime import datetime
from queue import Queue
import argilla as rg
import gradio as gr
print("Creating argilla client")
client = rg.Argilla()
server = rg.get_webhook_server()
incoming_events = Queue()
# Set up the webhook listeners
# Delete all existing webhooks
for webhook in client.webhooks:
print(f"Deleting webhook: {webhook.url}")
webhook.delete()
# Create a webhook for record events
@rg.webhook_listener(events=["record.deleted", "record.completed"])
async def record_events(record: rg.Record, type: str, timestamp: datetime):
print(f"Received event type {type} at {timestamp}: ", record)
incoming_events.put({"event": type, "data": record})
# Create a webhook for dataset events
@rg.webhook_listener(events=["dataset.created", "dataset.updated", "dataset.deleted", "dataset.published"])
async def dataset_events(dataset: rg.Dataset, type: str, timestamp: datetime):
print(f"Received event type {type} at {timestamp}: ", dataset)
incoming_events.put({"event": type, "data": dataset})
# Create a webhook for response events
@rg.webhook_listener(events=["response.created", "response.updated"])
async def response_events(response: rg.UserResponse, type: str, timestamp: datetime):
print(f"Received event type {type} at {timestamp}: ", response)
incoming_events.put({"event": type, "data": response})
def read_next_event():
event = incoming_events.get()
return event
with gr.Blocks() as demo:
argilla_server = client.http_client.base_url
gr.Markdown("## Argilla Webhooks")
gr.Markdown(f"""
This demo shows the incoming events from the [Argilla Server]({argilla_server}).
The application defines three webhook listeners for the following events:
- Record events: `record.deleted`, `record.completed`
- Dataset events: `dataset.created`, `dataset.updated`, `dataset.deleted`, `dataset.published`
- Response events: `response.created`, `response.updated`
The events are stored in a queue and displayed in the JSON component and the incoming events is updated every second.
You can view the incoming events in the JSON component below.
This application is just a demonstration of how to use the Argilla webhook listeners.
You can visit the [Argilla documentation](https://docs.argilla.io/dev/how_to_guides/webhooks) for more information.
""")
json_component = gr.JSON(label="Incoming argilla events:", value={})
gr.Timer(1, active=True).tick(read_next_event, outputs=json_component)
gr.mount_gradio_app(server, demo, path="/")
# Start the FastAPI server
import uvicorn
uvicorn.run(server, host="0.0.0.0", port=7860)
|