2019-03-17 03:44:05 +00:00
|
|
|
"""The nzbget component."""
|
2019-09-15 00:44:19 +00:00
|
|
|
from datetime import timedelta
|
|
|
|
import logging
|
|
|
|
|
|
|
|
import pynzbgetapi
|
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_HOST,
|
|
|
|
CONF_NAME,
|
|
|
|
CONF_PASSWORD,
|
|
|
|
CONF_PORT,
|
|
|
|
CONF_SCAN_INTERVAL,
|
|
|
|
CONF_SSL,
|
|
|
|
CONF_USERNAME,
|
|
|
|
)
|
|
|
|
from homeassistant.helpers import config_validation as cv
|
|
|
|
from homeassistant.helpers.dispatcher import dispatcher_send
|
|
|
|
from homeassistant.helpers.event import track_time_interval
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
DOMAIN = "nzbget"
|
|
|
|
DATA_NZBGET = "data_nzbget"
|
|
|
|
DATA_UPDATED = "nzbget_data_updated"
|
|
|
|
|
|
|
|
DEFAULT_NAME = "NZBGet"
|
|
|
|
DEFAULT_PORT = 6789
|
|
|
|
|
|
|
|
DEFAULT_SCAN_INTERVAL = timedelta(seconds=5)
|
|
|
|
|
|
|
|
CONFIG_SCHEMA = vol.Schema(
|
|
|
|
{
|
|
|
|
DOMAIN: vol.Schema(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_HOST): cv.string,
|
|
|
|
vol.Optional(CONF_PASSWORD): cv.string,
|
|
|
|
vol.Optional(CONF_USERNAME): cv.string,
|
|
|
|
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
|
|
|
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
|
|
|
vol.Optional(
|
|
|
|
CONF_SCAN_INTERVAL, default=DEFAULT_SCAN_INTERVAL
|
|
|
|
): cv.time_period,
|
|
|
|
vol.Optional(CONF_SSL, default=False): cv.boolean,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
},
|
|
|
|
extra=vol.ALLOW_EXTRA,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def setup(hass, config):
|
|
|
|
"""Set up the NZBGet sensors."""
|
|
|
|
host = config[DOMAIN][CONF_HOST]
|
|
|
|
port = config[DOMAIN][CONF_PORT]
|
|
|
|
ssl = "s" if config[DOMAIN][CONF_SSL] else ""
|
|
|
|
name = config[DOMAIN][CONF_NAME]
|
|
|
|
username = config[DOMAIN].get(CONF_USERNAME)
|
|
|
|
password = config[DOMAIN].get(CONF_PASSWORD)
|
|
|
|
scan_interval = config[DOMAIN][CONF_SCAN_INTERVAL]
|
|
|
|
|
|
|
|
try:
|
|
|
|
nzbget_api = pynzbgetapi.NZBGetAPI(host, username, password, ssl, ssl, port)
|
|
|
|
nzbget_api.version()
|
|
|
|
except pynzbgetapi.NZBGetAPIException as conn_err:
|
|
|
|
_LOGGER.error("Error setting up NZBGet API: %s", conn_err)
|
|
|
|
return False
|
|
|
|
|
|
|
|
_LOGGER.debug("Successfully validated NZBGet API connection")
|
|
|
|
|
|
|
|
nzbget_data = hass.data[DATA_NZBGET] = NZBGetData(hass, nzbget_api)
|
|
|
|
nzbget_data.update()
|
|
|
|
|
|
|
|
def refresh(event_time):
|
|
|
|
"""Get the latest data from NZBGet."""
|
|
|
|
nzbget_data.update()
|
|
|
|
|
|
|
|
track_time_interval(hass, refresh, scan_interval)
|
|
|
|
|
|
|
|
sensorconfig = {"client_name": name}
|
|
|
|
|
|
|
|
hass.helpers.discovery.load_platform("sensor", DOMAIN, sensorconfig, config)
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
class NZBGetData:
|
|
|
|
"""Get the latest data and update the states."""
|
|
|
|
|
|
|
|
def __init__(self, hass, api):
|
|
|
|
"""Initialize the NZBGet RPC API."""
|
|
|
|
self.hass = hass
|
|
|
|
self.status = None
|
|
|
|
self.available = True
|
|
|
|
self._api = api
|
|
|
|
|
|
|
|
def update(self):
|
|
|
|
"""Get the latest data from NZBGet instance."""
|
|
|
|
try:
|
|
|
|
self.status = self._api.status()
|
|
|
|
self.available = True
|
|
|
|
dispatcher_send(self.hass, DATA_UPDATED)
|
2019-09-16 05:06:21 +00:00
|
|
|
except pynzbgetapi.NZBGetAPIException:
|
2019-09-15 00:44:19 +00:00
|
|
|
self.available = False
|
|
|
|
_LOGGER.error("Unable to refresh NZBGet data")
|