mirror of
https://github.com/home-assistant/core.git
synced 2025-07-27 07:07:28 +00:00
Add device class attribute to modbus sensors (#30030)
This commit is contained in:
parent
6604680793
commit
0fc92928a4
@ -1,10 +1,15 @@
|
|||||||
"""Support for Modbus Coil sensors."""
|
"""Support for Modbus Coil sensors."""
|
||||||
import logging
|
import logging
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant.components.binary_sensor import PLATFORM_SCHEMA, BinarySensorDevice
|
from homeassistant.components.binary_sensor import (
|
||||||
from homeassistant.const import CONF_NAME, CONF_SLAVE
|
DEVICE_CLASSES_SCHEMA,
|
||||||
|
PLATFORM_SCHEMA,
|
||||||
|
BinarySensorDevice,
|
||||||
|
)
|
||||||
|
from homeassistant.const import CONF_DEVICE_CLASS, CONF_NAME, CONF_SLAVE
|
||||||
from homeassistant.helpers import config_validation as cv
|
from homeassistant.helpers import config_validation as cv
|
||||||
|
|
||||||
from . import CONF_HUB, DEFAULT_HUB, DOMAIN as MODBUS_DOMAIN
|
from . import CONF_HUB, DEFAULT_HUB, DOMAIN as MODBUS_DOMAIN
|
||||||
@ -20,6 +25,7 @@ PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|||||||
{
|
{
|
||||||
vol.Required(CONF_COIL): cv.positive_int,
|
vol.Required(CONF_COIL): cv.positive_int,
|
||||||
vol.Required(CONF_NAME): cv.string,
|
vol.Required(CONF_NAME): cv.string,
|
||||||
|
vol.Optional(CONF_DEVICE_CLASS): DEVICE_CLASSES_SCHEMA,
|
||||||
vol.Optional(CONF_HUB, default=DEFAULT_HUB): cv.string,
|
vol.Optional(CONF_HUB, default=DEFAULT_HUB): cv.string,
|
||||||
vol.Optional(CONF_SLAVE): cv.positive_int,
|
vol.Optional(CONF_SLAVE): cv.positive_int,
|
||||||
}
|
}
|
||||||
@ -35,7 +41,11 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
|
|||||||
hub = hass.data[MODBUS_DOMAIN][coil.get(CONF_HUB)]
|
hub = hass.data[MODBUS_DOMAIN][coil.get(CONF_HUB)]
|
||||||
sensors.append(
|
sensors.append(
|
||||||
ModbusCoilSensor(
|
ModbusCoilSensor(
|
||||||
hub, coil.get(CONF_NAME), coil.get(CONF_SLAVE), coil.get(CONF_COIL)
|
hub,
|
||||||
|
coil.get(CONF_NAME),
|
||||||
|
coil.get(CONF_SLAVE),
|
||||||
|
coil.get(CONF_COIL),
|
||||||
|
coil.get(CONF_DEVICE_CLASS),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -45,12 +55,13 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
|
|||||||
class ModbusCoilSensor(BinarySensorDevice):
|
class ModbusCoilSensor(BinarySensorDevice):
|
||||||
"""Modbus coil sensor."""
|
"""Modbus coil sensor."""
|
||||||
|
|
||||||
def __init__(self, hub, name, slave, coil):
|
def __init__(self, hub, name, slave, coil, device_class):
|
||||||
"""Initialize the Modbus coil sensor."""
|
"""Initialize the Modbus coil sensor."""
|
||||||
self._hub = hub
|
self._hub = hub
|
||||||
self._name = name
|
self._name = name
|
||||||
self._slave = int(slave) if slave else None
|
self._slave = int(slave) if slave else None
|
||||||
self._coil = int(coil)
|
self._coil = int(coil)
|
||||||
|
self._device_class = device_class
|
||||||
self._value = None
|
self._value = None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -63,6 +74,11 @@ class ModbusCoilSensor(BinarySensorDevice):
|
|||||||
"""Return the state of the sensor."""
|
"""Return the state of the sensor."""
|
||||||
return self._value
|
return self._value
|
||||||
|
|
||||||
|
@property
|
||||||
|
def device_class(self) -> Optional[str]:
|
||||||
|
"""Return the device class of the sensor."""
|
||||||
|
return self._device_class
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""Update the state of the sensor."""
|
"""Update the state of the sensor."""
|
||||||
result = self._hub.read_coils(self._slave, self._coil, 1)
|
result = self._hub.read_coils(self._slave, self._coil, 1)
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
"""Support for Modbus Register sensors."""
|
"""Support for Modbus Register sensors."""
|
||||||
import logging
|
import logging
|
||||||
import struct
|
import struct
|
||||||
from typing import Any, Union
|
from typing import Any, Optional, Union
|
||||||
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
from homeassistant.components.sensor import DEVICE_CLASSES_SCHEMA, PLATFORM_SCHEMA
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
|
CONF_DEVICE_CLASS,
|
||||||
CONF_NAME,
|
CONF_NAME,
|
||||||
CONF_OFFSET,
|
CONF_OFFSET,
|
||||||
CONF_SLAVE,
|
CONF_SLAVE,
|
||||||
@ -67,6 +68,7 @@ PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|||||||
vol.Optional(CONF_DATA_TYPE, default=DATA_TYPE_INT): vol.In(
|
vol.Optional(CONF_DATA_TYPE, default=DATA_TYPE_INT): vol.In(
|
||||||
[DATA_TYPE_INT, DATA_TYPE_UINT, DATA_TYPE_FLOAT, DATA_TYPE_CUSTOM]
|
[DATA_TYPE_INT, DATA_TYPE_UINT, DATA_TYPE_FLOAT, DATA_TYPE_CUSTOM]
|
||||||
),
|
),
|
||||||
|
vol.Optional(CONF_DEVICE_CLASS): DEVICE_CLASSES_SCHEMA,
|
||||||
vol.Optional(CONF_HUB, default=DEFAULT_HUB): cv.string,
|
vol.Optional(CONF_HUB, default=DEFAULT_HUB): cv.string,
|
||||||
vol.Optional(CONF_OFFSET, default=0): number,
|
vol.Optional(CONF_OFFSET, default=0): number,
|
||||||
vol.Optional(CONF_PRECISION, default=0): cv.positive_int,
|
vol.Optional(CONF_PRECISION, default=0): cv.positive_int,
|
||||||
@ -139,6 +141,7 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
|
|||||||
register.get(CONF_OFFSET),
|
register.get(CONF_OFFSET),
|
||||||
structure,
|
structure,
|
||||||
register.get(CONF_PRECISION),
|
register.get(CONF_PRECISION),
|
||||||
|
register.get(CONF_DEVICE_CLASS),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -164,6 +167,7 @@ class ModbusRegisterSensor(RestoreEntity):
|
|||||||
offset,
|
offset,
|
||||||
structure,
|
structure,
|
||||||
precision,
|
precision,
|
||||||
|
device_class,
|
||||||
):
|
):
|
||||||
"""Initialize the modbus register sensor."""
|
"""Initialize the modbus register sensor."""
|
||||||
self._hub = hub
|
self._hub = hub
|
||||||
@ -178,6 +182,7 @@ class ModbusRegisterSensor(RestoreEntity):
|
|||||||
self._offset = offset
|
self._offset = offset
|
||||||
self._precision = precision
|
self._precision = precision
|
||||||
self._structure = structure
|
self._structure = structure
|
||||||
|
self._device_class = device_class
|
||||||
self._value = None
|
self._value = None
|
||||||
|
|
||||||
async def async_added_to_hass(self):
|
async def async_added_to_hass(self):
|
||||||
@ -202,6 +207,11 @@ class ModbusRegisterSensor(RestoreEntity):
|
|||||||
"""Return the unit of measurement."""
|
"""Return the unit of measurement."""
|
||||||
return self._unit_of_measurement
|
return self._unit_of_measurement
|
||||||
|
|
||||||
|
@property
|
||||||
|
def device_class(self) -> Optional[str]:
|
||||||
|
"""Return the device class of the sensor."""
|
||||||
|
return self._device_class
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""Update the state of the sensor."""
|
"""Update the state of the sensor."""
|
||||||
if self._register_type == REGISTER_TYPE_INPUT:
|
if self._register_type == REGISTER_TYPE_INPUT:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user