mirror of
https://github.com/onyx-and-iris/streamlabs-socketio-py
synced 2024-11-23 07:40:49 +00:00
lazy load tomllib/tomli
raise SteamlabsSIOConnectionError on connection error Path.home() / ".config" / "streamlabsio" / "config.toml" added to config filepaths raw kwarg added. module level logger added.
This commit is contained in:
parent
37ca764806
commit
5dc69cc655
@ -1,22 +1,21 @@
|
|||||||
import logging
|
import logging
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
import socketio
|
import socketio
|
||||||
from observable import Observable
|
from observable import Observable
|
||||||
|
|
||||||
try:
|
from .error import SteamlabsSIOConnectionError
|
||||||
import tomllib
|
|
||||||
except ModuleNotFoundError:
|
|
||||||
import tomli as tomllib
|
|
||||||
|
|
||||||
from .models import as_dataclass
|
from .models import as_dataclass
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class Client:
|
class Client:
|
||||||
logger = logging.getLogger("socketio.client")
|
def __init__(self, token=None, raw=False):
|
||||||
|
self.logger = logger.getChild(self.__class__.__name__)
|
||||||
def __init__(self, token=None):
|
|
||||||
self.token = token or self._token_from_toml()
|
self.token = token or self._token_from_toml()
|
||||||
|
self._raw = raw
|
||||||
self.sio = socketio.Client()
|
self.sio = socketio.Client()
|
||||||
self.sio.on("connect", self.connect_handler)
|
self.sio.on("connect", self.connect_handler)
|
||||||
self.sio.on("event", self.event_handler)
|
self.sio.on("event", self.event_handler)
|
||||||
@ -27,15 +26,43 @@ class Client:
|
|||||||
self.youtube = ("follow", "subscription", "superchat")
|
self.youtube = ("follow", "subscription", "superchat")
|
||||||
|
|
||||||
def __enter__(self):
|
def __enter__(self):
|
||||||
|
try:
|
||||||
self.sio.connect(f"https://sockets.streamlabs.com?token={self.token}")
|
self.sio.connect(f"https://sockets.streamlabs.com?token={self.token}")
|
||||||
|
except socketio.exceptions.ConnectionError as e:
|
||||||
|
self.logger.exception(f"{type(e).__name__}: {e}")
|
||||||
|
raise SteamlabsSIOConnectionError(
|
||||||
|
"no connection could be established to the Streamlabs SIO server"
|
||||||
|
) from e
|
||||||
return self
|
return self
|
||||||
|
|
||||||
def _token_from_toml(self) -> str:
|
def _token_from_toml(self) -> str:
|
||||||
filepath = Path.cwd() / "config.toml"
|
try:
|
||||||
|
import tomllib
|
||||||
|
except ModuleNotFoundError:
|
||||||
|
import tomli as tomllib
|
||||||
|
|
||||||
|
def get_filepath() -> Optional[Path]:
|
||||||
|
filepaths = (
|
||||||
|
Path.cwd() / "config.toml",
|
||||||
|
Path.home() / ".config" / "streamlabsio" / "config.toml",
|
||||||
|
)
|
||||||
|
for filepath in filepaths:
|
||||||
|
if filepath.exists():
|
||||||
|
return filepath
|
||||||
|
|
||||||
|
try:
|
||||||
|
filepath = get_filepath()
|
||||||
|
if not filepath:
|
||||||
|
raise FileNotFoundError("config.toml was not found")
|
||||||
with open(filepath, "rb") as f:
|
with open(filepath, "rb") as f:
|
||||||
conn = tomllib.load(f)
|
conn = tomllib.load(f)
|
||||||
assert "token" in conn.get("streamlabs")
|
assert "token" in conn.get(
|
||||||
|
"streamlabs"
|
||||||
|
), "token not found in config.toml"
|
||||||
return conn["streamlabs"].get("token")
|
return conn["streamlabs"].get("token")
|
||||||
|
except (FileNotFoundError, tomllib.TOMLDecodeError) as e:
|
||||||
|
self.logger.error(f"{type(e).__name__}: {e}")
|
||||||
|
raise
|
||||||
|
|
||||||
def connect_handler(self):
|
def connect_handler(self):
|
||||||
self.logger.info("Connected to Streamlabs Socket API")
|
self.logger.info("Connected to Streamlabs Socket API")
|
||||||
@ -47,8 +74,9 @@ class Client:
|
|||||||
self.obs.trigger(
|
self.obs.trigger(
|
||||||
data["for"],
|
data["for"],
|
||||||
data["type"],
|
data["type"],
|
||||||
as_dataclass(data["type"], *data["message"]),
|
data if self._raw else as_dataclass(data["type"], *data["message"]),
|
||||||
)
|
)
|
||||||
|
self.logger.debug(data)
|
||||||
|
|
||||||
def disconnect_handler(self):
|
def disconnect_handler(self):
|
||||||
self.logger.info("Disconnected from Streamlabs Socket API")
|
self.logger.info("Disconnected from Streamlabs Socket API")
|
||||||
|
2
streamlabsio/error.py
Normal file
2
streamlabsio/error.py
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
class SteamlabsSIOConnectionError(Exception):
|
||||||
|
"""Exception raised when connection errors occur"""
|
Loading…
Reference in New Issue
Block a user