twitch sensor
This commit is contained in:
parent
d3a21bee82
commit
0e9c51a479
2 changed files with 32 additions and 36 deletions
|
@ -97,6 +97,7 @@ omit =
|
||||||
homeassistant/components/sensor/temper.py
|
homeassistant/components/sensor/temper.py
|
||||||
homeassistant/components/sensor/time_date.py
|
homeassistant/components/sensor/time_date.py
|
||||||
homeassistant/components/sensor/transmission.py
|
homeassistant/components/sensor/transmission.py
|
||||||
|
homeassistant/components/sensor/twitch.py
|
||||||
homeassistant/components/sensor/worldclock.py
|
homeassistant/components/sensor/worldclock.py
|
||||||
homeassistant/components/switch/arest.py
|
homeassistant/components/switch/arest.py
|
||||||
homeassistant/components/switch/command_switch.py
|
homeassistant/components/switch/command_switch.py
|
||||||
|
|
|
@ -1,16 +1,20 @@
|
||||||
"""
|
"""
|
||||||
homeassistant.components.media_player.twitch
|
homeassistant.components.sensor.twitch
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
Twitch stream status.
|
Twitch stream status.
|
||||||
|
|
||||||
For more details about this platform, please refer to the documentation at
|
For more details about this platform, please refer to the documentation at
|
||||||
https://home-assistant.io/components/media_player.twitch/
|
https://home-assistant.io/components/sensor.twitch/
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from homeassistant.const import STATE_PLAYING, STATE_OFF
|
from homeassistant.helpers.entity import Entity
|
||||||
|
from homeassistant.const import ATTR_ENTITY_PICTURE
|
||||||
|
|
||||||
from homeassistant.components.media_player import (
|
STATE_STREAMING = 'streaming'
|
||||||
MediaPlayerDevice, MEDIA_TYPE_CHANNEL)
|
STATE_OFFLINE = 'offline'
|
||||||
|
ATTR_GAME = 'game'
|
||||||
|
ATTR_TITLE = 'title'
|
||||||
|
ICON = 'mdi:twitch'
|
||||||
|
|
||||||
REQUIREMENTS = ['python-twitch==1.2.0']
|
REQUIREMENTS = ['python-twitch==1.2.0']
|
||||||
DOMAIN = 'twitch'
|
DOMAIN = 'twitch'
|
||||||
|
@ -20,28 +24,34 @@ DOMAIN = 'twitch'
|
||||||
def setup_platform(hass, config, add_devices, discovery_info=None):
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
||||||
""" Sets up the Twitch platform. """
|
""" Sets up the Twitch platform. """
|
||||||
add_devices(
|
add_devices(
|
||||||
[TwitchDevice(channel) for channel in config.get('channels', [])])
|
[TwitchSensor(channel) for channel in config.get('channels', [])])
|
||||||
|
|
||||||
|
|
||||||
class TwitchDevice(MediaPlayerDevice):
|
class TwitchSensor(Entity):
|
||||||
""" Represents an Twitch channel. """
|
""" Represents an Twitch channel. """
|
||||||
|
|
||||||
# pylint: disable=abstract-method
|
# pylint: disable=abstract-method
|
||||||
def __init__(self, channel):
|
def __init__(self, channel):
|
||||||
self._channel = channel
|
self._channel = channel
|
||||||
self._state = STATE_OFF
|
self._state = STATE_OFFLINE
|
||||||
self._preview = None
|
self._preview = None
|
||||||
self._game = None
|
self._game = None
|
||||||
self._title = None
|
self._title = None
|
||||||
|
self.update()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def should_poll(self):
|
def should_poll(self):
|
||||||
""" Device should be polled. """
|
""" Device should be polled. """
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
""" Returns the name of the device. """
|
||||||
|
return self._channel
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def state(self):
|
def state(self):
|
||||||
""" State of the player. """
|
""" State of the sensor. """
|
||||||
return self._state
|
return self._state
|
||||||
|
|
||||||
# pylint: disable=no-member
|
# pylint: disable=no-member
|
||||||
|
@ -53,35 +63,20 @@ class TwitchDevice(MediaPlayerDevice):
|
||||||
self._game = stream.get('channel').get('game')
|
self._game = stream.get('channel').get('game')
|
||||||
self._title = stream.get('channel').get('status')
|
self._title = stream.get('channel').get('status')
|
||||||
self._preview = stream.get('preview').get('small')
|
self._preview = stream.get('preview').get('small')
|
||||||
self._state = STATE_PLAYING
|
self._state = STATE_STREAMING
|
||||||
else:
|
else:
|
||||||
self._state = STATE_OFF
|
self._state = STATE_OFFLINE
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def name(self):
|
def state_attributes(self):
|
||||||
""" Channel name. """
|
""" Returns the state attributes. """
|
||||||
return self._channel
|
if self._state == STATE_STREAMING:
|
||||||
|
return {
|
||||||
|
ATTR_GAME: self._game,
|
||||||
|
ATTR_TITLE: self._title,
|
||||||
|
ATTR_ENTITY_PICTURE: self._preview
|
||||||
|
}
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def media_title(self):
|
def icon(self):
|
||||||
""" Channel title. """
|
return ICON
|
||||||
return self._title
|
|
||||||
|
|
||||||
@property
|
|
||||||
def app_name(self):
|
|
||||||
""" Game name. """
|
|
||||||
return self._game
|
|
||||||
|
|
||||||
@property
|
|
||||||
def media_image_url(self):
|
|
||||||
""" Image preview url of the live stream. """
|
|
||||||
return self._preview
|
|
||||||
|
|
||||||
@property
|
|
||||||
def media_content_type(self):
|
|
||||||
""" Media type (channel). """
|
|
||||||
return MEDIA_TYPE_CHANNEL
|
|
||||||
|
|
||||||
def media_pause(self):
|
|
||||||
""" Must implement because UI can pause. """
|
|
||||||
pass
|
|
Loading…
Add table
Reference in a new issue