Spaces:
Runtime error
Runtime error
Francisco Aranda
commited on
Commit
·
30c85ad
1
Parent(s):
bcf795e
chore: prepare space example
Browse files
main.py
CHANGED
|
@@ -1,4 +1,5 @@
|
|
| 1 |
import os
|
|
|
|
| 2 |
from queue import Queue
|
| 3 |
|
| 4 |
import argilla as rg
|
|
@@ -9,55 +10,53 @@ client = rg.Argilla()
|
|
| 9 |
server = rg.get_webhook_server()
|
| 10 |
incoming_events = Queue()
|
| 11 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 12 |
|
| 13 |
# Set up the webhook listeners
|
| 14 |
|
| 15 |
# Create a webhook for record events
|
| 16 |
-
|
| 17 |
-
|
| 18 |
-
|
| 19 |
-
print("Received event", type, record)
|
| 20 |
|
| 21 |
incoming_events.put(record)
|
| 22 |
|
| 23 |
|
| 24 |
# Create a webhook for dataset events
|
| 25 |
-
@rg.webhook_listener(events=["dataset.created", "dataset.updated", "dataset.published"])
|
| 26 |
-
async def dataset_events(type: str,
|
| 27 |
-
print(f"Received event
|
| 28 |
|
| 29 |
incoming_events.put((type, dataset))
|
| 30 |
|
| 31 |
|
| 32 |
# Create a webhook for response events
|
| 33 |
@rg.webhook_listener(events=["response.created", "response.updated"])
|
| 34 |
-
async def response_events(type:str,
|
| 35 |
-
print(f"Received event
|
| 36 |
|
| 37 |
incoming_events.put(response)
|
| 38 |
|
| 39 |
|
| 40 |
-
|
| 41 |
-
async def deleted_events(type: str, data: dict, **kwargs):
|
| 42 |
-
print(f"Received event {type} for resource {data}")
|
| 43 |
-
|
| 44 |
-
incoming_events.put((type, data))
|
| 45 |
-
|
| 46 |
-
|
| 47 |
-
def check_incoming_events():
|
| 48 |
-
"""
|
| 49 |
-
This function is called every 5 seconds to check if there are any incoming
|
| 50 |
-
events and send data to update the JSON component.
|
| 51 |
-
"""
|
| 52 |
event = incoming_events.get()
|
| 53 |
|
| 54 |
return event
|
| 55 |
|
|
|
|
| 56 |
with gr.Blocks() as demo:
|
| 57 |
argilla_server = client.http_client.base_url
|
| 58 |
gr.Markdown("## Argilla Events")
|
| 59 |
gr.Markdown(f"This demo shows the incoming events from the [Argilla Server]({argilla_server}).")
|
| 60 |
-
json_component = gr.JSON(label="Incoming argilla events:")
|
| 61 |
-
gr.Timer(1, active=True).tick(
|
| 62 |
|
| 63 |
gr.mount_gradio_app(server, demo, path="/")
|
|
|
|
| 1 |
import os
|
| 2 |
+
from datetime import datetime
|
| 3 |
from queue import Queue
|
| 4 |
|
| 5 |
import argilla as rg
|
|
|
|
| 10 |
server = rg.get_webhook_server()
|
| 11 |
incoming_events = Queue()
|
| 12 |
|
| 13 |
+
# The default webhook server URL is set to http://127.0.0.1:8000
|
| 14 |
+
# This value is important since the webhook server URL is used to create the webhook URLs
|
| 15 |
+
# When the SPACE_HOST environment variable is set, the default webhook server URL is set to https://SPACE_HOST value
|
| 16 |
+
# If the FastAPI app is running on a different URL, the WEBHOOK_SERVER_URL environment variable should be set
|
| 17 |
+
default_webhook_server_url = os.getenv("WEBHOOK_SERVER_URL")
|
| 18 |
+
if default_webhook_server_url is None and "SPACE_HOST" in os.environ:
|
| 19 |
+
# We set it to the default gradio server URL
|
| 20 |
+
os.environ["WEBHOOK_SERVER_URL"] = "http://127.0.0.1:7860"
|
| 21 |
+
|
| 22 |
|
| 23 |
# Set up the webhook listeners
|
| 24 |
|
| 25 |
# Create a webhook for record events
|
| 26 |
+
@rg.webhook_listener(events=["record.created", "record.updated", "record.deleted", "record.completed"])
|
| 27 |
+
async def record_events(record: rg.Record, type: str, timestamp: datetime):
|
| 28 |
+
print(f"Received event type {type} at {timestamp}: ", record)
|
|
|
|
| 29 |
|
| 30 |
incoming_events.put(record)
|
| 31 |
|
| 32 |
|
| 33 |
# Create a webhook for dataset events
|
| 34 |
+
@rg.webhook_listener(events=["dataset.created", "dataset.updated", "dataset.deleted", "dataset.published"])
|
| 35 |
+
async def dataset_events(dataset: rg.Dataset, type: str, timestamp: datetime):
|
| 36 |
+
print(f"Received event type {type} at {timestamp}: ", dataset)
|
| 37 |
|
| 38 |
incoming_events.put((type, dataset))
|
| 39 |
|
| 40 |
|
| 41 |
# Create a webhook for response events
|
| 42 |
@rg.webhook_listener(events=["response.created", "response.updated"])
|
| 43 |
+
async def response_events(response: rg.UserResponse, type: str, timestamp: datetime):
|
| 44 |
+
print(f"Received event type {type} at {timestamp}: ", response)
|
| 45 |
|
| 46 |
incoming_events.put(response)
|
| 47 |
|
| 48 |
|
| 49 |
+
def read_next_event():
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 50 |
event = incoming_events.get()
|
| 51 |
|
| 52 |
return event
|
| 53 |
|
| 54 |
+
|
| 55 |
with gr.Blocks() as demo:
|
| 56 |
argilla_server = client.http_client.base_url
|
| 57 |
gr.Markdown("## Argilla Events")
|
| 58 |
gr.Markdown(f"This demo shows the incoming events from the [Argilla Server]({argilla_server}).")
|
| 59 |
+
json_component = gr.JSON(label="Incoming argilla events:", value={})
|
| 60 |
+
gr.Timer(1, active=True).tick(read_next_event, outputs=json_component)
|
| 61 |
|
| 62 |
gr.mount_gradio_app(server, demo, path="/")
|
start.sh
CHANGED
|
@@ -1 +1,2 @@
|
|
| 1 |
-
|
|
|
|
|
|
| 1 |
+
uvicorn main:server --host 0.0.0.0 --port 7860
|
| 2 |
+
|