core/homeassistant/components/fleetgo/device_tracker.py

90 lines
2.7 KiB
Python
Raw Normal View History

2019-07-12 14:14:58 +00:00
"""Support for FleetGO Platform."""
import logging
import requests
from ritassist import API
import voluptuous as vol
from homeassistant.components.device_tracker import PLATFORM_SCHEMA
from homeassistant.const import (
CONF_CLIENT_ID,
CONF_CLIENT_SECRET,
CONF_INCLUDE,
CONF_PASSWORD,
CONF_USERNAME,
)
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.event import track_utc_time_change
_LOGGER = logging.getLogger(__name__)
2019-07-31 19:25:30 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
{
vol.Required(CONF_USERNAME): cv.string,
vol.Required(CONF_PASSWORD): cv.string,
vol.Required(CONF_CLIENT_ID): cv.string,
vol.Required(CONF_CLIENT_SECRET): cv.string,
vol.Optional(CONF_INCLUDE, default=[]): vol.All(cv.ensure_list, [cv.string]),
}
)
def setup_scanner(hass, config: dict, see, discovery_info=None):
"""Set up the DeviceScanner and check if login is valid."""
2019-07-12 14:14:58 +00:00
scanner = FleetGoDeviceScanner(config, see)
if not scanner.login(hass):
2019-07-31 19:25:30 +00:00
_LOGGER.error("FleetGO authentication failed")
return False
return True
2019-07-12 14:14:58 +00:00
class FleetGoDeviceScanner:
"""Define a scanner for the FleetGO platform."""
def __init__(self, config, see):
2019-07-12 14:14:58 +00:00
"""Initialize FleetGoDeviceScanner."""
self._include = config.get(CONF_INCLUDE)
self._see = see
2019-07-31 19:25:30 +00:00
self._api = API(
config.get(CONF_CLIENT_ID),
config.get(CONF_CLIENT_SECRET),
config.get(CONF_USERNAME),
config.get(CONF_PASSWORD),
)
def setup(self, hass):
2018-08-19 20:29:08 +00:00
"""Set up a timer and start gathering devices."""
self._refresh()
2019-07-31 19:25:30 +00:00
track_utc_time_change(
hass, lambda now: self._refresh(), second=range(0, 60, 30)
)
def login(self, hass):
2019-07-12 14:14:58 +00:00
"""Perform a login on the FleetGO API."""
if self._api.login():
self.setup(hass)
return True
return False
def _refresh(self) -> None:
"""Refresh device information from the platform."""
try:
devices = self._api.get_devices()
for device in devices:
2019-07-31 19:25:30 +00:00
if not self._include or device.license_plate in self._include:
if device.active or device.current_address is None:
device.get_map_details()
2019-07-31 19:25:30 +00:00
self._see(
dev_id=device.plate_as_id,
gps=(device.latitude, device.longitude),
attributes=device.state_attributes,
icon="mdi:car",
)
except requests.exceptions.ConnectionError:
2019-07-31 19:25:30 +00:00
_LOGGER.error("ConnectionError: Could not connect to FleetGO")