2019-04-03 15:40:03 +00:00
|
|
|
"""Support for EE Brightbox router."""
|
2019-01-22 08:16:35 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.components.device_tracker import (
|
2019-07-31 19:25:30 +00:00
|
|
|
DOMAIN,
|
|
|
|
PLATFORM_SCHEMA,
|
|
|
|
DeviceScanner,
|
|
|
|
)
|
2019-01-22 08:16:35 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_PASSWORD, CONF_USERNAME
|
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_VERSION = "version"
|
2019-01-22 08:16:35 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_DEFAULT_IP = "192.168.1.1"
|
|
|
|
CONF_DEFAULT_USERNAME = "admin"
|
2019-01-22 08:16:35 +00:00
|
|
|
CONF_DEFAULT_VERSION = 2
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_VERSION, default=CONF_DEFAULT_VERSION): cv.positive_int,
|
|
|
|
vol.Required(CONF_HOST, default=CONF_DEFAULT_IP): cv.string,
|
|
|
|
vol.Required(CONF_USERNAME, default=CONF_DEFAULT_USERNAME): cv.string,
|
|
|
|
vol.Required(CONF_PASSWORD): cv.string,
|
|
|
|
}
|
|
|
|
)
|
2019-01-22 08:16:35 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_scanner(hass, config):
|
|
|
|
"""Return a router scanner instance."""
|
|
|
|
scanner = EEBrightBoxScanner(config[DOMAIN])
|
|
|
|
|
|
|
|
return scanner if scanner.check_config() else None
|
|
|
|
|
|
|
|
|
|
|
|
class EEBrightBoxScanner(DeviceScanner):
|
|
|
|
"""Scan EE Brightbox router."""
|
|
|
|
|
|
|
|
def __init__(self, config):
|
|
|
|
"""Initialise the scanner."""
|
|
|
|
self.config = config
|
|
|
|
self.devices = {}
|
|
|
|
|
|
|
|
def check_config(self):
|
|
|
|
"""Check if provided configuration and credentials are correct."""
|
|
|
|
from eebrightbox import EEBrightBox, EEBrightBoxException
|
|
|
|
|
|
|
|
try:
|
|
|
|
with EEBrightBox(self.config) as ee_brightbox:
|
|
|
|
return bool(ee_brightbox.get_devices())
|
|
|
|
except EEBrightBoxException:
|
|
|
|
_LOGGER.exception("Failed to connect to the router")
|
|
|
|
return False
|
|
|
|
|
|
|
|
def scan_devices(self):
|
|
|
|
"""Scan for devices."""
|
|
|
|
from eebrightbox import EEBrightBox
|
|
|
|
|
|
|
|
with EEBrightBox(self.config) as ee_brightbox:
|
2019-07-31 19:25:30 +00:00
|
|
|
self.devices = {d["mac"]: d for d in ee_brightbox.get_devices()}
|
2019-01-22 08:16:35 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
macs = [d["mac"] for d in self.devices.values() if d["activity_ip"]]
|
2019-01-22 08:16:35 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.debug("Scan devices %s", macs)
|
2019-01-22 08:16:35 +00:00
|
|
|
|
|
|
|
return macs
|
|
|
|
|
|
|
|
def get_device_name(self, device):
|
|
|
|
"""Get the name of a device from hostname."""
|
|
|
|
if device in self.devices:
|
2019-07-31 19:25:30 +00:00
|
|
|
return self.devices[device]["hostname"] or None
|
2019-01-22 08:16:35 +00:00
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
def get_extra_attributes(self, device):
|
|
|
|
"""
|
|
|
|
Get the extra attributes of a device.
|
|
|
|
|
|
|
|
Extra attributes include:
|
|
|
|
- ip
|
|
|
|
- mac
|
|
|
|
- port - ethX or wifiX
|
|
|
|
- last_active
|
|
|
|
"""
|
|
|
|
port_map = {
|
2019-07-31 19:25:30 +00:00
|
|
|
"wl1": "wifi5Ghz",
|
|
|
|
"wl0": "wifi2.4Ghz",
|
|
|
|
"eth0": "eth0",
|
|
|
|
"eth1": "eth1",
|
|
|
|
"eth2": "eth2",
|
|
|
|
"eth3": "eth3",
|
2019-01-22 08:16:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if device in self.devices:
|
|
|
|
return {
|
2019-07-31 19:25:30 +00:00
|
|
|
"ip": self.devices[device]["ip"],
|
|
|
|
"mac": self.devices[device]["mac"],
|
|
|
|
"port": port_map[self.devices[device]["port"]],
|
|
|
|
"last_active": self.devices[device]["time_last_active"],
|
2019-01-22 08:16:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return {}
|