Source code for bacommon.net

# Released under the MIT License. See LICENSE for details.
#
"""Network related data and functionality."""

from __future__ import annotations

import datetime
from typing import TYPE_CHECKING, Any, Annotated
from dataclasses import dataclass, field

from efro.dataclassio import ioprepped, IOAttrs

if TYPE_CHECKING:
    pass


[docs] @ioprepped @dataclass class ServerNodeEntry: """Information about a specific server.""" zone: str # TODO: Remove soft_default after all master-servers upgraded. latlong: tuple[float, float] | None address: str port: int
[docs] @ioprepped @dataclass class ServerNodeQueryResponse: """A response to a query about server-nodes.""" # The current utc time on the master server. time: datetime.datetime # Where the master server sees the query as coming from. latlong: tuple[float, float] | None ping_per_dist: float max_dist: float debug_log_seconds: float | None = None # If present, something went wrong, and this describes it. error: str | None = None # The set of servernodes. servers: list[ServerNodeEntry] = field(default_factory=list)
[docs] @ioprepped @dataclass class PrivateHostingState: """Combined state of whether we're hosting, whether we can, etc.""" unavailable_error: str | None = None party_code: str | None = None tickets_to_host_now: int = 0 tokens_to_host_now: int = 0 minutes_until_free_host: float | None = None free_host_minutes_remaining: float | None = None
[docs] @ioprepped @dataclass class PrivateHostingConfig: """Config provided when hosting a private party.""" session_type: str = 'ffa' playlist_name: str = 'Unknown' randomize: bool = False tutorial: bool = False custom_team_names: tuple[str, str] | None = None custom_team_colors: ( tuple[tuple[float, float, float], tuple[float, float, float]] | None ) = None playlist: list[dict[str, Any]] | None = None exit_minutes: float = 120.0 exit_minutes_unclean: float = 180.0 exit_minutes_idle: float = 10.0
[docs] @ioprepped @dataclass class PrivatePartyConnectResult: """Info about a server we get back when connecting.""" error: str | None = None address4: str | None = None address6: str | None = None port: int | None = None password: str | None = None
# Docs-generation hack; import some stuff that we likely only forward-declared # in our actual source code so that docs tools can find it. from typing import (Coroutine, Any, Literal, Callable, Generator, Awaitable, Sequence, Self) import asyncio from concurrent.futures import Future