2016-02-04 20:01:45 +00:00
|
|
|
"""
|
2016-02-06 07:23:30 +00:00
|
|
|
Support the sensor of a BloomSky weather station.
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
2016-02-06 07:23:30 +00:00
|
|
|
https://home-assistant.io/components/sensor.bloomsky/
|
2016-02-04 20:01:45 +00:00
|
|
|
"""
|
|
|
|
import logging
|
2016-02-19 05:27:50 +00:00
|
|
|
|
2016-09-02 04:31:32 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
|
|
|
from homeassistant.const import (TEMP_FAHRENHEIT, CONF_MONITORED_CONDITIONS)
|
2016-02-04 20:01:45 +00:00
|
|
|
from homeassistant.helpers.entity import Entity
|
2016-02-19 05:27:50 +00:00
|
|
|
from homeassistant.loader import get_component
|
2016-09-02 04:31:32 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2016-02-04 20:01:45 +00:00
|
|
|
|
2016-09-02 04:31:32 +00:00
|
|
|
DEPENDENCIES = ['bloomsky']
|
2016-02-04 20:01:45 +00:00
|
|
|
|
2016-02-06 07:23:30 +00:00
|
|
|
# These are the available sensors
|
2016-09-02 04:31:32 +00:00
|
|
|
SENSOR_TYPES = ['Temperature',
|
|
|
|
'Humidity',
|
|
|
|
'Pressure',
|
|
|
|
'Luminance',
|
|
|
|
'UVIndex',
|
|
|
|
'Voltage']
|
2016-02-04 20:01:45 +00:00
|
|
|
|
2016-02-06 07:23:30 +00:00
|
|
|
# Sensor units - these do not currently align with the API documentation
|
2016-09-02 04:31:32 +00:00
|
|
|
SENSOR_UNITS = {'Temperature': TEMP_FAHRENHEIT,
|
|
|
|
'Humidity': '%',
|
|
|
|
'Pressure': 'inHg',
|
|
|
|
'Luminance': 'cd/m²',
|
|
|
|
'Voltage': 'mV'}
|
2016-02-04 20:01:45 +00:00
|
|
|
|
2016-02-06 07:23:30 +00:00
|
|
|
# Which sensors to format numerically
|
2016-09-02 04:31:32 +00:00
|
|
|
FORMAT_NUMBERS = ['Temperature', 'Pressure', 'Voltage']
|
|
|
|
|
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
|
|
|
vol.Optional(CONF_MONITORED_CONDITIONS, default=SENSOR_TYPES):
|
|
|
|
vol.All(cv.ensure_list, [vol.In(SENSOR_TYPES)]),
|
|
|
|
})
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
# pylint: disable=unused-argument
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Set up the available BloomSky weather sensors."""
|
2016-02-18 21:10:25 +00:00
|
|
|
bloomsky = get_component('bloomsky')
|
2016-09-10 16:12:24 +00:00
|
|
|
# Default needed in case of discovery
|
|
|
|
sensors = config.get(CONF_MONITORED_CONDITIONS, SENSOR_TYPES)
|
2016-02-04 20:01:45 +00:00
|
|
|
|
2016-02-20 07:21:56 +00:00
|
|
|
for device in bloomsky.BLOOMSKY.devices.values():
|
|
|
|
for variable in sensors:
|
2016-09-02 04:31:32 +00:00
|
|
|
add_devices([BloomSkySensor(bloomsky.BLOOMSKY, device, variable)])
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
class BloomSkySensor(Entity):
|
2016-03-08 15:46:34 +00:00
|
|
|
"""Representation of a single sensor in a BloomSky device."""
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
def __init__(self, bs, device, sensor_name):
|
2016-09-02 04:31:32 +00:00
|
|
|
"""Initialize a BloomSky sensor."""
|
2016-02-04 20:01:45 +00:00
|
|
|
self._bloomsky = bs
|
2016-09-02 04:31:32 +00:00
|
|
|
self._device_id = device['DeviceID']
|
2016-02-04 20:01:45 +00:00
|
|
|
self._sensor_name = sensor_name
|
2016-09-02 04:31:32 +00:00
|
|
|
self._name = '{} {}'.format(device['DeviceName'], sensor_name)
|
|
|
|
self._unique_id = 'bloomsky_sensor {}'.format(self._name)
|
2016-02-20 07:21:56 +00:00
|
|
|
self.update()
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Return the name of the BloomSky device and this sensor."""
|
2016-02-20 07:21:56 +00:00
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self):
|
2016-03-08 15:46:34 +00:00
|
|
|
"""Return the unique ID for this sensor."""
|
2016-02-20 07:21:56 +00:00
|
|
|
return self._unique_id
|
2016-02-04 20:01:45 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def state(self):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Return the current state, eg. value, of this sensor."""
|
2016-02-04 20:01:45 +00:00
|
|
|
return self._state
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unit_of_measurement(self):
|
2016-02-20 07:21:56 +00:00
|
|
|
"""Return the sensor units."""
|
2016-02-04 20:01:45 +00:00
|
|
|
return SENSOR_UNITS.get(self._sensor_name, None)
|
|
|
|
|
|
|
|
def update(self):
|
2016-02-20 07:21:56 +00:00
|
|
|
"""Request an update from the BloomSky API."""
|
2016-02-04 20:01:45 +00:00
|
|
|
self._bloomsky.refresh_devices()
|
2016-02-20 07:21:56 +00:00
|
|
|
|
|
|
|
state = \
|
2016-09-02 04:31:32 +00:00
|
|
|
self._bloomsky.devices[self._device_id]['Data'][self._sensor_name]
|
2016-02-20 07:21:56 +00:00
|
|
|
|
|
|
|
if self._sensor_name in FORMAT_NUMBERS:
|
2016-09-02 04:31:32 +00:00
|
|
|
self._state = '{0:.2f}'.format(state)
|
2016-02-04 20:01:45 +00:00
|
|
|
else:
|
2016-02-20 07:21:56 +00:00
|
|
|
self._state = state
|