2019-07-12 14:14:58 +00:00
|
|
|
"""Support for FleetGO Platform."""
|
2018-08-02 05:01:40 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
import requests
|
2019-12-04 14:15:30 +00:00
|
|
|
from ritassist import API
|
2018-08-02 05:01:40 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.components.device_tracker import PLATFORM_SCHEMA
|
2020-05-30 15:27:20 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_CLIENT_ID,
|
|
|
|
CONF_CLIENT_SECRET,
|
2021-02-08 10:47:30 +00:00
|
|
|
CONF_INCLUDE,
|
2020-05-30 15:27:20 +00:00
|
|
|
CONF_PASSWORD,
|
|
|
|
CONF_USERNAME,
|
|
|
|
)
|
2019-12-04 14:15:30 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2018-08-02 05:01:40 +00:00
|
|
|
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]),
|
|
|
|
}
|
|
|
|
)
|
2018-08-02 05:01:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
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)
|
2018-08-02 05:01:40 +00:00
|
|
|
if not scanner.login(hass):
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.error("FleetGO authentication failed")
|
2018-08-02 05:01:40 +00:00
|
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2019-07-12 14:14:58 +00:00
|
|
|
class FleetGoDeviceScanner:
|
|
|
|
"""Define a scanner for the FleetGO platform."""
|
2018-08-02 05:01:40 +00:00
|
|
|
|
|
|
|
def __init__(self, config, see):
|
2019-07-12 14:14:58 +00:00
|
|
|
"""Initialize FleetGoDeviceScanner."""
|
2018-08-02 05:01:40 +00:00
|
|
|
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),
|
|
|
|
)
|
2018-08-02 05:01:40 +00:00
|
|
|
|
|
|
|
def setup(self, hass):
|
2018-08-19 20:29:08 +00:00
|
|
|
"""Set up a timer and start gathering devices."""
|
2018-08-02 05:01:40 +00:00
|
|
|
self._refresh()
|
2019-07-31 19:25:30 +00:00
|
|
|
track_utc_time_change(
|
|
|
|
hass, lambda now: self._refresh(), second=range(0, 60, 30)
|
|
|
|
)
|
2018-08-02 05:01:40 +00:00
|
|
|
|
|
|
|
def login(self, hass):
|
2019-07-12 14:14:58 +00:00
|
|
|
"""Perform a login on the FleetGO API."""
|
2018-08-02 05:01:40 +00:00
|
|
|
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:
|
2018-08-18 07:40:29 +00:00
|
|
|
|
|
|
|
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",
|
|
|
|
)
|
2018-08-02 05:01:40 +00:00
|
|
|
|
|
|
|
except requests.exceptions.ConnectionError:
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.error("ConnectionError: Could not connect to FleetGO")
|