From 331be7bcbd55b2de5bee18413f109b6002d5249b Mon Sep 17 00:00:00 2001 From: Jenny Date: Mon, 19 Oct 2020 22:26:47 +0100 Subject: [PATCH] Fixes broken live attribute again (#12) --- custom_components/youtube/sensor.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/custom_components/youtube/sensor.py b/custom_components/youtube/sensor.py index 525af68..a14fad2 100644 --- a/custom_components/youtube/sensor.py +++ b/custom_components/youtube/sensor.py @@ -19,7 +19,6 @@ ICON = 'mdi:youtube' BASE_URL = 'https://www.youtube.com/feeds/videos.xml?channel_id={}' -BASE_URL_LIVE = "https://www.youtube.com/channel/{}" PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({ vol.Required(CONF_CHANNEL_ID): cv.string, @@ -71,7 +70,7 @@ async def async_update(self): info.split('')[2].split('</')[0]) url = info.split('<link rel="alternate" href="')[2].split('"/>')[0] if self.live or url != self.url: - self.live = await is_live(self.channel_id, self._name, self.hass, self.session) + self.live = await is_live(url, self._name, self.hass, self.session) else: _LOGGER.debug('%s - Skipping live check', self._name) self.url = url @@ -111,17 +110,16 @@ def device_state_attributes(self): 'live': self.live} -async def is_live(channel_id, name, hass, session): +async def is_live(url, name, hass, session): """Return bool if channel is live""" returnvalue = False - url = BASE_URL_LIVE.format(channel_id) try: async with async_timeout.timeout(10, loop=hass.loop): response = await session.get(url) info = await response.text() - if 'BADGE_STYLE_TYPE_LIVE_NOW' in info: + if '{"key":"is_viewed_live","value":"True"}' in info: returnvalue = True - _LOGGER.debug('%s - Channel is live', name) + _LOGGER.debug('%s - Latest Video is live', name) except Exception as error: # pylint: disable=broad-except _LOGGER.debug('%s - Could not update - %s', name, error) return returnvalue