core/homeassistant/components/asuswrt/device_tracker.py

53 lines
1.7 KiB
Python
Raw Normal View History

"""Support for ASUSWRT routers."""
import logging
from homeassistant.components.device_tracker import DeviceScanner
from . import DATA_ASUSWRT
_LOGGER = logging.getLogger(__name__)
async def async_get_scanner(hass, config):
2016-03-07 20:18:53 +00:00
"""Validate the configuration and return an ASUS-WRT scanner."""
scanner = AsusWrtDeviceScanner(hass.data[DATA_ASUSWRT])
await scanner.async_connect()
return scanner if scanner.success_init else None
2016-11-19 05:47:59 +00:00
class AsusWrtDeviceScanner(DeviceScanner):
2016-03-07 20:18:53 +00:00
"""This class queries a router running ASUSWRT firmware."""
# Eighth attribute needed for mode (AP mode vs router mode)
def __init__(self, api):
2016-03-07 20:18:53 +00:00
"""Initialize the scanner."""
self.last_results = {}
self.success_init = False
self.connection = api
async def async_connect(self):
"""Initialize connection to the router."""
2016-03-07 20:18:53 +00:00
# Test the router is accessible.
data = await self.connection.async_get_connected_devices()
self.success_init = data is not None
async def async_scan_devices(self):
2016-03-07 20:18:53 +00:00
"""Scan for new devices and return a list with found device IDs."""
await self.async_update_info()
return list(self.last_results.keys())
async def async_get_device_name(self, device):
2016-03-07 20:18:53 +00:00
"""Return the name of the given device or None if we don't know."""
if device not in self.last_results:
return None
return self.last_results[device].name
async def async_update_info(self):
2016-03-07 20:18:53 +00:00
"""Ensure the information from the ASUSWRT router is up to date.
Return boolean if scanning successful.
"""
2019-07-31 19:25:30 +00:00
_LOGGER.debug("Checking Devices")
self.last_results = await self.connection.async_get_connected_devices()