core/homeassistant/components/pocketcasts/sensor.py

70 lines
1.9 KiB
Python
Raw Normal View History

"""Support for Pocket Casts."""
2017-02-18 21:52:37 +00:00
from datetime import timedelta
import logging
2017-02-18 21:52:37 +00:00
from pycketcasts import pocketcasts
2017-02-18 21:52:37 +00:00
import voluptuous as vol
from homeassistant.components.sensor import PLATFORM_SCHEMA
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.entity import Entity
2017-02-18 21:52:37 +00:00
_LOGGER = logging.getLogger(__name__)
2017-02-18 21:52:37 +00:00
2019-07-31 19:25:30 +00:00
ICON = "mdi:rss"
2019-07-31 19:25:30 +00:00
SENSOR_NAME = "Pocketcasts unlistened episodes"
2017-02-18 21:52:37 +00:00
SCAN_INTERVAL = timedelta(minutes=5)
2019-07-31 19:25:30 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
{vol.Required(CONF_PASSWORD): cv.string, vol.Required(CONF_USERNAME): cv.string}
)
2017-02-18 21:52:37 +00:00
def setup_platform(hass, config, add_entities, discovery_info=None):
"""Set up the pocketcasts platform for sensors."""
username = config.get(CONF_USERNAME)
password = config.get(CONF_PASSWORD)
2017-02-18 21:52:37 +00:00
try:
api = pocketcasts.PocketCast(email=username, password=password)
_LOGGER.debug("Found %d podcasts", len(api.subscriptions))
add_entities([PocketCastsSensor(api)], True)
2017-02-18 21:52:37 +00:00
except OSError as err:
_LOGGER.error("Connection to server failed: %s", err)
2017-02-18 21:52:37 +00:00
return False
class PocketCastsSensor(Entity):
"""Representation of a pocket casts sensor."""
def __init__(self, api):
"""Initialize the sensor."""
self._api = api
self._state = None
@property
def name(self):
"""Return the name of the sensor."""
return SENSOR_NAME
@property
def state(self):
"""Return the sensor state."""
return self._state
@property
def icon(self):
"""Return the icon for the sensor."""
return ICON
def update(self):
"""Update sensor values."""
try:
self._state = len(self._api.new_releases)
_LOGGER.debug("Found %d new episodes", self._state)
except OSError as err:
_LOGGER.warning("Failed to contact server: %s", err)