2022-12-01 05:33:20 +00:00
|
|
|
# Copyright (c) 2022 Kyle Schouviller (https://github.com/kyle0654)
|
|
|
|
|
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
from queue import Queue
|
|
|
|
|
|
|
|
|
|
|
|
# TODO: make this serializable
|
|
|
|
class InvocationQueueItem:
|
2023-03-03 06:02:00 +00:00
|
|
|
# session_id: str
|
2022-12-01 05:33:20 +00:00
|
|
|
graph_execution_state_id: str
|
|
|
|
invocation_id: str
|
|
|
|
invoke_all: bool
|
|
|
|
|
2023-03-03 06:02:00 +00:00
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
# session_id: str,
|
2022-12-01 05:33:20 +00:00
|
|
|
graph_execution_state_id: str,
|
|
|
|
invocation_id: str,
|
2023-03-03 06:02:00 +00:00
|
|
|
invoke_all: bool = False,
|
|
|
|
):
|
|
|
|
# self.session_id = session_id
|
2022-12-01 05:33:20 +00:00
|
|
|
self.graph_execution_state_id = graph_execution_state_id
|
|
|
|
self.invocation_id = invocation_id
|
|
|
|
self.invoke_all = invoke_all
|
|
|
|
|
|
|
|
|
|
|
|
class InvocationQueueABC(ABC):
|
|
|
|
"""Abstract base class for all invocation queues"""
|
2023-03-03 06:02:00 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
@abstractmethod
|
|
|
|
def get(self) -> InvocationQueueItem:
|
|
|
|
pass
|
2023-03-03 06:02:00 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
@abstractmethod
|
2023-03-03 06:02:00 +00:00
|
|
|
def put(self, item: InvocationQueueItem | None) -> None:
|
2022-12-01 05:33:20 +00:00
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class MemoryInvocationQueue(InvocationQueueABC):
|
|
|
|
__queue: Queue
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
self.__queue = Queue()
|
2023-03-03 06:02:00 +00:00
|
|
|
|
2022-12-01 05:33:20 +00:00
|
|
|
def get(self) -> InvocationQueueItem:
|
|
|
|
return self.__queue.get()
|
2023-03-03 06:02:00 +00:00
|
|
|
|
|
|
|
def put(self, item: InvocationQueueItem | None) -> None:
|
2022-12-01 05:33:20 +00:00
|
|
|
self.__queue.put(item)
|