2016-01-24 08:02:14 +00:00
|
|
|
"""
|
|
|
|
Contains functionality to use a ZigBee device as a sensor.
|
|
|
|
|
2016-02-01 10:47:09 +00:00
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/sensor.zigbee/
|
|
|
|
|
|
|
|
"""
|
2016-01-24 08:02:14 +00:00
|
|
|
import logging
|
2016-01-29 16:43:01 +00:00
|
|
|
from binascii import hexlify
|
2016-01-24 08:02:14 +00:00
|
|
|
|
2016-02-19 05:27:50 +00:00
|
|
|
from homeassistant.components import zigbee
|
2016-01-24 08:02:14 +00:00
|
|
|
from homeassistant.const import TEMP_CELCIUS
|
2016-02-19 05:27:50 +00:00
|
|
|
from homeassistant.core import JobPriority
|
2016-01-24 08:02:14 +00:00
|
|
|
from homeassistant.helpers.entity import Entity
|
|
|
|
|
|
|
|
DEPENDENCIES = ["zigbee"]
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_entities, discovery_info=None):
|
|
|
|
"""
|
|
|
|
Uses the 'type' config value to work out which type of ZigBee sensor we're
|
|
|
|
dealing with and instantiates the relevant classes to handle it.
|
|
|
|
"""
|
|
|
|
typ = config.get("type", "").lower()
|
|
|
|
if not typ:
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Must include 'type' when configuring a ZigBee sensor.")
|
|
|
|
return
|
|
|
|
try:
|
|
|
|
sensor_class, config_class = TYPE_CLASSES[typ]
|
|
|
|
except KeyError:
|
|
|
|
_LOGGER.exception("Unknown ZigBee sensor type: %s", typ)
|
|
|
|
return
|
|
|
|
add_entities([sensor_class(hass, config_class(config))])
|
|
|
|
|
|
|
|
|
|
|
|
class ZigBeeTemperatureSensor(Entity):
|
2016-02-23 05:21:49 +00:00
|
|
|
"""Allows usage of an XBee Pro as a temperature sensor."""
|
2016-01-24 08:02:14 +00:00
|
|
|
def __init__(self, hass, config):
|
|
|
|
self._config = config
|
|
|
|
self._temp = None
|
2016-01-29 11:33:15 +00:00
|
|
|
# Get initial state
|
|
|
|
hass.pool.add_job(
|
|
|
|
JobPriority.EVENT_STATE, (self.update_ha_state, True))
|
2016-01-24 08:02:14 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2016-02-23 05:21:49 +00:00
|
|
|
"""The name of the sensor."""
|
2016-01-24 08:02:14 +00:00
|
|
|
return self._config.name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def state(self):
|
2016-02-23 05:21:49 +00:00
|
|
|
"""Returns the state of the sensor."""
|
2016-01-24 08:02:14 +00:00
|
|
|
return self._temp
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unit_of_measurement(self):
|
2016-02-23 05:21:49 +00:00
|
|
|
"""Unit the value is expressed in."""
|
2016-01-24 08:02:14 +00:00
|
|
|
return TEMP_CELCIUS
|
|
|
|
|
|
|
|
def update(self, *args):
|
2016-02-23 05:21:49 +00:00
|
|
|
"""Gets the latest data."""
|
2016-01-29 16:43:01 +00:00
|
|
|
try:
|
|
|
|
self._temp = zigbee.DEVICE.get_temperature(self._config.address)
|
|
|
|
except zigbee.ZIGBEE_TX_FAILURE:
|
|
|
|
_LOGGER.warning(
|
|
|
|
"Transmission failure when attempting to get sample from "
|
|
|
|
"ZigBee device at address: %s", hexlify(self._config.address))
|
|
|
|
except zigbee.ZIGBEE_EXCEPTION as exc:
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Unable to get sample from ZigBee device: %s", exc)
|
2016-01-24 08:02:14 +00:00
|
|
|
|
2016-01-29 12:00:53 +00:00
|
|
|
|
|
|
|
# This must be below the classes to which it refers.
|
2016-01-24 08:02:14 +00:00
|
|
|
TYPE_CLASSES = {
|
|
|
|
"temperature": (ZigBeeTemperatureSensor, zigbee.ZigBeeConfig),
|
|
|
|
"analog": (zigbee.ZigBeeAnalogIn, zigbee.ZigBeeAnalogInConfig)
|
|
|
|
}
|