import logging import voluptuous as vol from homeassistant.components.websocket_api import websocket_command, result_message, event_message, async_register_command from .mod_view import setup_view DOMAIN = "browser_mod" FRONTEND_SCRIPT_URL = "/browser_mod.js" _LOGGER = logging.getLogger(__name__) async def async_setup(hass, config): _LOGGER.error(f"Setting up browser_mod") setup_view(hass, FRONTEND_SCRIPT_URL) _LOGGER.error(f"Registered frontend script") async_register_command(hass, handle_connect) _LOGGER.error(f"Registered connect ws command") _LOGGER.error(f"Config") _LOGGER.error(config) aliases = {} for d in config[DOMAIN].get("devices", {}): name = config[DOMAIN]["devices"][d].get("name", None) if name: aliases[name] = d _LOGGER.error(aliases) hass.data[DOMAIN] = { "devices": {}, "aliases": aliases, } return True @websocket_command({ vol.Required("type"): "browser_mod/connect", vol.Required("deviceID"): str, }) def handle_connect(hass, connection, msg): _LOGGER.error(f"Got connection {msg}") connection.send_message(result_message(msg["id"])) connection.send_message(event_message(msg["id"], {"command": "update"})) @websocket_command({ vol.Required("type"): "browser_mod/update", vol.Required("deviceID"): str, vol.Optional("browser"): dict, vol.Optional("player"): dict, }) def handle_update(hass, connection, msg): pass