mirror of
https://github.com/home-assistant/core.git
synced 2025-07-24 21:57:51 +00:00
Add support for multiple disks to be monitored. (#9977)
* Add support for multiple disks. * Fix LINT error. * Make disk config optional to not break existing installations. * Change state handling as per request by @fabaff.
This commit is contained in:
parent
51a65ee8e9
commit
789929d445
@ -22,6 +22,8 @@ _LOGGER = logging.getLogger(__name__)
|
|||||||
ATTR_DEVICE = 'device'
|
ATTR_DEVICE = 'device'
|
||||||
ATTR_MODEL = 'model'
|
ATTR_MODEL = 'model'
|
||||||
|
|
||||||
|
CONF_DISKS = 'disks'
|
||||||
|
|
||||||
DEFAULT_HOST = 'localhost'
|
DEFAULT_HOST = 'localhost'
|
||||||
DEFAULT_PORT = 7634
|
DEFAULT_PORT = 7634
|
||||||
DEFAULT_NAME = 'HD Temperature'
|
DEFAULT_NAME = 'HD Temperature'
|
||||||
@ -30,6 +32,8 @@ DEFAULT_TIMEOUT = 5
|
|||||||
SCAN_INTERVAL = timedelta(minutes=1)
|
SCAN_INTERVAL = timedelta(minutes=1)
|
||||||
|
|
||||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
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_HOST, default=DEFAULT_HOST): cv.string,
|
||||||
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
||||||
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
||||||
@ -41,25 +45,37 @@ def setup_platform(hass, config, add_devices, discovery_info=None):
|
|||||||
name = config.get(CONF_NAME)
|
name = config.get(CONF_NAME)
|
||||||
host = config.get(CONF_HOST)
|
host = config.get(CONF_HOST)
|
||||||
port = config.get(CONF_PORT)
|
port = config.get(CONF_PORT)
|
||||||
|
disks = config.get(CONF_DISKS)
|
||||||
|
|
||||||
hddtemp = HddTempData(host, port)
|
try:
|
||||||
hddtemp.update()
|
hddtemp = HddTempData(host, port)
|
||||||
|
hddtemp.update()
|
||||||
if hddtemp.data is None:
|
except RuntimeError:
|
||||||
_LOGGER.error("Unable to fetch the data from %s:%s", host, port)
|
_LOGGER.error("Unable to fetch the data from %s:%s", host, port)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
add_devices([HddTempSensor(name, hddtemp)], True)
|
if not disks:
|
||||||
|
disks = [next(iter(hddtemp.data)).split('|')[0]]
|
||||||
|
|
||||||
|
dev = []
|
||||||
|
for disk in disks:
|
||||||
|
if disk in hddtemp.data:
|
||||||
|
dev.append(HddTempSensor(name, disk, hddtemp))
|
||||||
|
else:
|
||||||
|
continue
|
||||||
|
|
||||||
|
add_devices(dev, True)
|
||||||
|
|
||||||
|
|
||||||
class HddTempSensor(Entity):
|
class HddTempSensor(Entity):
|
||||||
"""Representation of a HDDTemp sensor."""
|
"""Representation of a HDDTemp sensor."""
|
||||||
|
|
||||||
def __init__(self, name, hddtemp):
|
def __init__(self, name, disk, hddtemp):
|
||||||
"""Initialize a HDDTemp sensor."""
|
"""Initialize a HDDTemp sensor."""
|
||||||
self.hddtemp = hddtemp
|
self.hddtemp = hddtemp
|
||||||
self._name = name
|
self.disk = disk
|
||||||
self._state = False
|
self._name = '{} {}'.format(name, disk)
|
||||||
|
self._state = None
|
||||||
self._details = None
|
self._details = None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -75,7 +91,7 @@ class HddTempSensor(Entity):
|
|||||||
@property
|
@property
|
||||||
def unit_of_measurement(self):
|
def unit_of_measurement(self):
|
||||||
"""Return the unit the value is expressed in."""
|
"""Return the unit the value is expressed in."""
|
||||||
if self._details[4] == 'C':
|
if self._details[3] == 'C':
|
||||||
return TEMP_CELSIUS
|
return TEMP_CELSIUS
|
||||||
return TEMP_FAHRENHEIT
|
return TEMP_FAHRENHEIT
|
||||||
|
|
||||||
@ -83,17 +99,17 @@ class HddTempSensor(Entity):
|
|||||||
def device_state_attributes(self):
|
def device_state_attributes(self):
|
||||||
"""Return the state attributes of the sensor."""
|
"""Return the state attributes of the sensor."""
|
||||||
return {
|
return {
|
||||||
ATTR_DEVICE: self._details[1],
|
ATTR_DEVICE: self._details[0],
|
||||||
ATTR_MODEL: self._details[2],
|
ATTR_MODEL: self._details[1],
|
||||||
}
|
}
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""Get the latest data from HDDTemp daemon and updates the state."""
|
"""Get the latest data from HDDTemp daemon and updates the state."""
|
||||||
self.hddtemp.update()
|
self.hddtemp.update()
|
||||||
|
|
||||||
if self.hddtemp.data is not None:
|
if self.disk in self.hddtemp.data:
|
||||||
self._details = self.hddtemp.data.split('|')
|
self._details = self.hddtemp.data[self.disk].split('|')
|
||||||
self._state = self._details[3]
|
self._state = self._details[2]
|
||||||
else:
|
else:
|
||||||
self._state = STATE_UNKNOWN
|
self._state = STATE_UNKNOWN
|
||||||
|
|
||||||
@ -112,7 +128,10 @@ class HddTempData(object):
|
|||||||
try:
|
try:
|
||||||
connection = Telnet(
|
connection = Telnet(
|
||||||
host=self.host, port=self.port, timeout=DEFAULT_TIMEOUT)
|
host=self.host, port=self.port, timeout=DEFAULT_TIMEOUT)
|
||||||
self.data = connection.read_all().decode('ascii')
|
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)}
|
||||||
except ConnectionRefusedError:
|
except ConnectionRefusedError:
|
||||||
_LOGGER.error(
|
_LOGGER.error(
|
||||||
"HDDTemp is not available at %s:%s", self.host, self.port)
|
"HDDTemp is not available at %s:%s", self.host, self.port)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user