Source code for mode.types.services

"""Type classes for :mod:`mode.services`."""
import abc
import asyncio
from typing import (
    Any,
    Awaitable,
    ContextManager,
    Coroutine,
    MutableMapping,
    Optional,
    Set,
    Type,
    TypeVar,
    Union,
)

from mode.utils.contexts import AsyncExitStack, ExitStack
from mode.utils.types.trees import NodeT
from mode.utils.typing import AsyncContextManager

from .supervisors import SupervisorStrategyT

__all__ = [
    "DiagT",
    "ServiceT",
]

T = TypeVar("T")

AsyncFun = Union[Awaitable[T], Coroutine[Any, Any, T]]


class DiagT(abc.ABC):
    """Diag keeps track of a services diagnostic flags."""

    flags: Set[str]
    last_transition: MutableMapping[str, float]

    @abc.abstractmethod
    def __init__(self, service: "ServiceT") -> None:
        ...

    @abc.abstractmethod
    def set_flag(self, flag: str) -> None:
        ...

    @abc.abstractmethod
    def unset_flag(self, flag: str) -> None:
        ...


[docs]class ServiceT(AsyncContextManager): """Abstract type for an asynchronous service that can be started/stopped. See Also: :class:`mode.Service`. """ Diag: Type[DiagT] diag: DiagT async_exit_stack: AsyncExitStack exit_stack: ExitStack shutdown_timeout: float wait_for_shutdown = False _loop: Optional[asyncio.AbstractEventLoop] restart_count: int = 0 supervisor: Optional[SupervisorStrategyT] = None @abc.abstractmethod def __init__( self, *, beacon: NodeT = None, loop: asyncio.AbstractEventLoop = None ) -> None: ...
[docs] @abc.abstractmethod def add_dependency(self, service: "ServiceT") -> "ServiceT": ...
[docs] @abc.abstractmethod async def add_runtime_dependency(self, service: "ServiceT") -> "ServiceT": ...
[docs] @abc.abstractmethod async def add_async_context(self, context: AsyncContextManager) -> Any: ...
[docs] @abc.abstractmethod def add_context(self, context: ContextManager) -> Any: ...
[docs] @abc.abstractmethod async def start(self) -> None: ...
[docs] @abc.abstractmethod async def maybe_start(self) -> bool: ...
[docs] @abc.abstractmethod async def crash(self, reason: BaseException) -> None: ...
@abc.abstractmethod def _crash(self, reason: BaseException) -> None: ...
[docs] @abc.abstractmethod async def stop(self) -> None: ...
[docs] @abc.abstractmethod def service_reset(self) -> None: ...
[docs] @abc.abstractmethod async def restart(self) -> None: ...
[docs] @abc.abstractmethod async def wait_until_stopped(self) -> None: ...
[docs] @abc.abstractmethod def set_shutdown(self) -> None: ...
@abc.abstractmethod def _repr_info(self) -> str: ... @property @abc.abstractmethod def started(self) -> bool: ... @property @abc.abstractmethod def crashed(self) -> bool: ... @property @abc.abstractmethod def should_stop(self) -> bool: ... @property @abc.abstractmethod def state(self) -> str: ... @property @abc.abstractmethod def label(self) -> str: ... @property @abc.abstractmethod def shortlabel(self) -> str: ... @property def beacon(self) -> NodeT: ... @beacon.setter def beacon(self, beacon: NodeT) -> None: ... @property @abc.abstractmethod def loop(self) -> asyncio.AbstractEventLoop: ... @loop.setter def loop(self, loop: Optional[asyncio.AbstractEventLoop]) -> None: ... @property @abc.abstractmethod def crash_reason(self) -> Optional[BaseException]: ... @crash_reason.setter def crash_reason(self, reason: Optional[BaseException]) -> None: ...