2022-12-01 05:33:20 +00:00
|
|
|
# Copyright (c) 2022 Kyle Schouviller (https://github.com/kyle0654)
|
|
|
|
|
|
|
|
from typing import Any, Dict
|
|
|
|
|
|
|
|
|
|
|
|
class EventServiceBase:
|
2023-03-03 06:02:00 +00:00
|
|
|
session_event: str = "session_event"
|
2022-12-01 05:33:20 +00:00
|
|
|
|
|
|
|
"""Basic event bus, to have an empty stand-in when not needed"""
|
2023-03-03 06:02:00 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
def dispatch(self, event_name: str, payload: Any) -> None:
|
|
|
|
pass
|
|
|
|
|
2023-03-03 06:02:00 +00:00
|
|
|
def __emit_session_event(self, event_name: str, payload: Dict) -> None:
|
2022-12-01 05:33:20 +00:00
|
|
|
self.dispatch(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name=EventServiceBase.session_event,
|
|
|
|
payload=dict(event=event_name, data=payload),
|
2022-12-01 05:33:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Define events here for every event in the system.
|
|
|
|
# This will make them easier to integrate until we find a schema generator.
|
2023-03-03 06:02:00 +00:00
|
|
|
def emit_generator_progress(
|
|
|
|
self,
|
2022-12-01 05:33:20 +00:00
|
|
|
graph_execution_state_id: str,
|
|
|
|
invocation_id: str,
|
|
|
|
step: int,
|
2023-03-03 06:02:00 +00:00
|
|
|
percent: float,
|
2022-12-01 05:33:20 +00:00
|
|
|
) -> None:
|
|
|
|
"""Emitted when there is generation progress"""
|
|
|
|
self.__emit_session_event(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name="generator_progress",
|
|
|
|
payload=dict(
|
|
|
|
graph_execution_state_id=graph_execution_state_id,
|
|
|
|
invocation_id=invocation_id,
|
|
|
|
step=step,
|
|
|
|
percent=percent,
|
|
|
|
),
|
2022-12-01 05:33:20 +00:00
|
|
|
)
|
|
|
|
|
2023-03-03 06:02:00 +00:00
|
|
|
def emit_invocation_complete(
|
|
|
|
self, graph_execution_state_id: str, invocation_id: str, result: Dict
|
2022-12-01 05:33:20 +00:00
|
|
|
) -> None:
|
|
|
|
"""Emitted when an invocation has completed"""
|
|
|
|
self.__emit_session_event(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name="invocation_complete",
|
|
|
|
payload=dict(
|
|
|
|
graph_execution_state_id=graph_execution_state_id,
|
|
|
|
invocation_id=invocation_id,
|
|
|
|
result=result,
|
|
|
|
),
|
2022-12-01 05:33:20 +00:00
|
|
|
)
|
2023-03-03 06:02:00 +00:00
|
|
|
|
|
|
|
def emit_invocation_error(
|
|
|
|
self, graph_execution_state_id: str, invocation_id: str, error: str
|
2023-02-27 18:01:07 +00:00
|
|
|
) -> None:
|
|
|
|
"""Emitted when an invocation has completed"""
|
|
|
|
self.__emit_session_event(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name="invocation_error",
|
|
|
|
payload=dict(
|
|
|
|
graph_execution_state_id=graph_execution_state_id,
|
|
|
|
invocation_id=invocation_id,
|
|
|
|
error=error,
|
|
|
|
),
|
2023-02-27 18:01:07 +00:00
|
|
|
)
|
2022-12-01 05:33:20 +00:00
|
|
|
|
2023-03-03 06:02:00 +00:00
|
|
|
def emit_invocation_started(
|
|
|
|
self, graph_execution_state_id: str, invocation_id: str
|
2022-12-01 05:33:20 +00:00
|
|
|
) -> None:
|
|
|
|
"""Emitted when an invocation has started"""
|
|
|
|
self.__emit_session_event(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name="invocation_started",
|
|
|
|
payload=dict(
|
|
|
|
graph_execution_state_id=graph_execution_state_id,
|
|
|
|
invocation_id=invocation_id,
|
|
|
|
),
|
2022-12-01 05:33:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
def emit_graph_execution_complete(self, graph_execution_state_id: str) -> None:
|
|
|
|
"""Emitted when a session has completed all invocations"""
|
|
|
|
self.__emit_session_event(
|
2023-03-03 06:02:00 +00:00
|
|
|
event_name="graph_execution_state_complete",
|
|
|
|
payload=dict(graph_execution_state_id=graph_execution_state_id),
|
2022-12-01 05:33:20 +00:00
|
|
|
)
|