Add Social Blade Sensor (#14060)
* Adding Dominion Energy Sensor * Update : remove white spacves and set the update time to be daily * Update : update spacing as per hound suggestions, Move imports * Update : Fix Travis CI build errors * Update Documentations on method levels * Update Documentations on method levels * Update Documentations on method levels * Add Exception Handeling if login failed, add PLATFORM_SCHEMA * Add Exception Handeling if login failed, add PLATFORM_SCHEMA * Add Exception Handeling if login failed, add PLATFORM_SCHEMA * Update dominionenergy.py * Adding Selenium to requirements_all.txt * Checking the username/password while setup * Checking the username/password while setup * removing extra white space * Update : Adding the Platform only if credentials works * Update : Add PlatformNotReady exception * Update : Add PlatformNotReady exception * Update .coveragerc * Remove change * Adding USCIS component * Adding Line after the class DOC * Update : Extract USCIS logic code to Component * Update : Extract USCIS logic code to Component * Adding CURRENT_STATUS * Change Error handling, remove date from attributes * Update the Version for USCIS * Add Social Blade Sensor * Update class documentation * Update coverage and requirements_all * Update : houndci error with intent * Update : Add coverage * Update uscis.py * Add comments * Add comments * Delete dominionenergy.py * Update requirements_all.txt * Update .coveragerc * Update .coveragerc * Update .coveragerc * Update : update after code review * Fix remaining issues
This commit is contained in:
parent
c2d00be91e
commit
6453ea4e61
3 changed files with 94 additions and 0 deletions
|
@ -661,6 +661,7 @@ omit =
|
|||
homeassistant/components/sensor/sma.py
|
||||
homeassistant/components/sensor/snmp.py
|
||||
homeassistant/components/sensor/sochain.py
|
||||
homeassistant/components/sensor/socialblade.py
|
||||
homeassistant/components/sensor/sonarr.py
|
||||
homeassistant/components/sensor/speedtest.py
|
||||
homeassistant/components/sensor/spotcrime.py
|
||||
|
|
90
homeassistant/components/sensor/socialblade.py
Normal file
90
homeassistant/components/sensor/socialblade.py
Normal file
|
@ -0,0 +1,90 @@
|
|||
"""
|
||||
Support for Social Blade.
|
||||
|
||||
For more details about this platform, please refer to the documentation at
|
||||
https://home-assistant.io/components/sensor.socialblade/
|
||||
"""
|
||||
from datetime import timedelta
|
||||
import logging
|
||||
|
||||
import voluptuous as vol
|
||||
|
||||
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
||||
from homeassistant.const import CONF_NAME
|
||||
from homeassistant.helpers import config_validation as cv
|
||||
from homeassistant.helpers.entity import Entity
|
||||
from homeassistant.util import Throttle
|
||||
|
||||
_LOGGER = logging.getLogger(__name__)
|
||||
|
||||
REQUIREMENTS = ['socialbladeclient==0.2']
|
||||
|
||||
CHANNEL_ID = 'channel_id'
|
||||
|
||||
DEFAULT_NAME = "Social Blade"
|
||||
|
||||
MIN_TIME_BETWEEN_UPDATES = timedelta(hours=2)
|
||||
|
||||
SUBSCRIBERS = 'subscribers'
|
||||
|
||||
TOTAL_VIEWS = 'total_views'
|
||||
|
||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
||||
vol.Required(CHANNEL_ID): cv.string,
|
||||
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
||||
})
|
||||
|
||||
|
||||
def setup_platform(hass, config, add_devices, discovery_info=None):
|
||||
"""Set up the Social Blade sensor."""
|
||||
social_blade = SocialBladeSensor(
|
||||
config[CHANNEL_ID], config[CONF_NAME])
|
||||
|
||||
social_blade.update()
|
||||
if social_blade.valid_channel_id is False:
|
||||
return
|
||||
|
||||
add_devices([social_blade])
|
||||
|
||||
|
||||
class SocialBladeSensor(Entity):
|
||||
"""Representation of a Social Blade Sensor."""
|
||||
|
||||
def __init__(self, case, name):
|
||||
"""Initialize the Social Blade sensor."""
|
||||
self._state = None
|
||||
self.channel_id = case
|
||||
self._attributes = None
|
||||
self.valid_channel_id = None
|
||||
self._name = name
|
||||
|
||||
@property
|
||||
def name(self):
|
||||
"""Return the name."""
|
||||
return self._name
|
||||
|
||||
@property
|
||||
def state(self):
|
||||
"""Return the state."""
|
||||
return self._state
|
||||
|
||||
@property
|
||||
def device_state_attributes(self):
|
||||
"""Return the state attributes."""
|
||||
if self._attributes:
|
||||
return self._attributes
|
||||
|
||||
@Throttle(MIN_TIME_BETWEEN_UPDATES)
|
||||
def update(self):
|
||||
"""Get the latest data from Social Blade."""
|
||||
import socialbladeclient
|
||||
try:
|
||||
data = socialbladeclient.get_data(self.channel_id)
|
||||
self._attributes = {TOTAL_VIEWS: data[TOTAL_VIEWS]}
|
||||
self._state = data[SUBSCRIBERS]
|
||||
self.valid_channel_id = True
|
||||
|
||||
except (ValueError, IndexError):
|
||||
_LOGGER.error("Unable to find valid channel ID")
|
||||
self.valid_channel_id = False
|
||||
self._attributes = None
|
|
@ -1203,6 +1203,9 @@ smappy==0.2.15
|
|||
# homeassistant.components.media_player.snapcast
|
||||
snapcast==2.0.8
|
||||
|
||||
# homeassistant.components.sensor.socialblade
|
||||
socialbladeclient==0.2
|
||||
|
||||
# homeassistant.components.climate.honeywell
|
||||
somecomfort==0.5.2
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue