core/homeassistant/components/hddtemp/sensor.py

136 lines
4.0 KiB
Python
Raw Normal View History

"""Support for getting the disk temperature of a host."""
from __future__ import annotations
2016-10-29 02:06:24 +00:00
from datetime import timedelta
import logging
import socket
from telnetlib import Telnet
2016-10-29 02:06:24 +00:00
import voluptuous as vol
from homeassistant.components.sensor import (
PLATFORM_SCHEMA,
SensorDeviceClass,
SensorEntity,
)
2016-10-29 02:06:24 +00:00
from homeassistant.const import (
CONF_DISKS,
2019-07-31 19:25:30 +00:00
CONF_HOST,
CONF_NAME,
2019-07-31 19:25:30 +00:00
CONF_PORT,
TEMP_CELSIUS,
TEMP_FAHRENHEIT,
)
from homeassistant.core import HomeAssistant
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
2016-10-29 02:06:24 +00:00
_LOGGER = logging.getLogger(__name__)
2019-07-31 19:25:30 +00:00
ATTR_DEVICE = "device"
ATTR_MODEL = "model"
2016-10-29 02:06:24 +00:00
2019-07-31 19:25:30 +00:00
DEFAULT_HOST = "localhost"
2016-10-29 02:06:24 +00:00
DEFAULT_PORT = 7634
2019-07-31 19:25:30 +00:00
DEFAULT_NAME = "HD Temperature"
2016-10-29 02:06:24 +00:00
DEFAULT_TIMEOUT = 5
SCAN_INTERVAL = timedelta(minutes=1)
2016-10-29 02:06:24 +00:00
2019-07-31 19:25:30 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
{
vol.Optional(CONF_DISKS, default=[]): vol.All(cv.ensure_list, [cv.string]),
vol.Optional(CONF_HOST, default=DEFAULT_HOST): cv.string,
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
}
)
2016-10-29 02:06:24 +00:00
def setup_platform(
hass: HomeAssistant,
config: ConfigType,
add_entities: AddEntitiesCallback,
discovery_info: DiscoveryInfoType | None = None,
) -> None:
"""Set up the HDDTemp sensor."""
2016-10-29 02:06:24 +00:00
name = config.get(CONF_NAME)
host = config.get(CONF_HOST)
port = config.get(CONF_PORT)
disks = config.get(CONF_DISKS)
2016-10-29 02:06:24 +00:00
hddtemp = HddTempData(host, port)
hddtemp.update()
if not disks:
2019-07-31 19:25:30 +00:00
disks = [next(iter(hddtemp.data)).split("|")[0]]
dev = []
for disk in disks:
dev.append(HddTempSensor(name, disk, hddtemp))
add_entities(dev, True)
2016-10-29 02:06:24 +00:00
class HddTempSensor(SensorEntity):
2016-10-29 02:06:24 +00:00
"""Representation of a HDDTemp sensor."""
_attr_device_class = SensorDeviceClass.TEMPERATURE
def __init__(self, name, disk, hddtemp):
2016-10-29 02:06:24 +00:00
"""Initialize a HDDTemp sensor."""
self.hddtemp = hddtemp
self.disk = disk
self._attr_name = f"{name} {disk}"
2016-10-29 02:06:24 +00:00
self._details = None
@property
def extra_state_attributes(self):
2016-10-29 02:06:24 +00:00
"""Return the state attributes of the sensor."""
if self._details is not None:
2019-07-31 19:25:30 +00:00
return {ATTR_DEVICE: self._details[0], ATTR_MODEL: self._details[1]}
2016-10-29 02:06:24 +00:00
def update(self):
"""Get the latest data from HDDTemp daemon and updates the state."""
self.hddtemp.update()
if self.hddtemp.data and self.disk in self.hddtemp.data:
2019-07-31 19:25:30 +00:00
self._details = self.hddtemp.data[self.disk].split("|")
self._attr_native_value = self._details[2]
2019-07-31 19:25:30 +00:00
if self._details is not None and self._details[3] == "F":
self._attr_native_unit_of_measurement = TEMP_FAHRENHEIT
else:
self._attr_native_unit_of_measurement = TEMP_CELSIUS
2016-10-29 02:06:24 +00:00
else:
self._attr_native_value = None
2016-10-29 02:06:24 +00:00
class HddTempData:
2016-10-29 02:06:24 +00:00
"""Get the latest data from HDDTemp and update the states."""
def __init__(self, host, port):
"""Initialize the data object."""
self.host = host
self.port = port
self.data = None
def update(self):
"""Get the latest data from HDDTemp running as daemon."""
2016-10-29 02:06:24 +00:00
try:
2019-07-31 19:25:30 +00:00
connection = Telnet(host=self.host, port=self.port, timeout=DEFAULT_TIMEOUT)
data = (
connection.read_all()
.decode("ascii")
.lstrip("|")
.rstrip("|")
.split("||")
)
self.data = {data[i].split("|")[0]: data[i] for i in range(0, len(data), 1)}
2016-10-29 02:06:24 +00:00
except ConnectionRefusedError:
2019-07-31 19:25:30 +00:00
_LOGGER.error("HDDTemp is not available at %s:%s", self.host, self.port)
self.data = None
except socket.gaierror:
_LOGGER.error("HDDTemp host not found %s:%s", self.host, self.port)
2016-10-29 02:06:24 +00:00
self.data = None