mirror of
https://github.com/tomaae/homeassistant-mikrotik_router.git
synced 2025-07-13 19:04:30 +02:00
fixed possible issue in environment sensor
This commit is contained in:
parent
5a2df12ced
commit
a8f196f974
2 changed files with 17 additions and 39 deletions
|
@ -32,7 +32,6 @@ from .const import (
|
||||||
CONF_SCAN_INTERVAL,
|
CONF_SCAN_INTERVAL,
|
||||||
DEFAULT_SCAN_INTERVAL,
|
DEFAULT_SCAN_INTERVAL,
|
||||||
DEFAULT_UNIT_OF_MEASUREMENT,
|
DEFAULT_UNIT_OF_MEASUREMENT,
|
||||||
CONF_TRACK_HOSTS_TIMEOUT,
|
|
||||||
CONF_SENSOR_PORT_TRAFFIC,
|
CONF_SENSOR_PORT_TRAFFIC,
|
||||||
DEFAULT_SENSOR_PORT_TRAFFIC,
|
DEFAULT_SENSOR_PORT_TRAFFIC,
|
||||||
CONF_SENSOR_CLIENT_TRAFFIC,
|
CONF_SENSOR_CLIENT_TRAFFIC,
|
||||||
|
|
|
@ -144,6 +144,16 @@ SENSOR_TYPES = {
|
||||||
ATTR_PATH: "accounting",
|
ATTR_PATH: "accounting",
|
||||||
ATTR_ATTR: "wan-rx",
|
ATTR_ATTR: "wan-rx",
|
||||||
},
|
},
|
||||||
|
"environment": {
|
||||||
|
ATTR_DEVICE_CLASS: None,
|
||||||
|
ATTR_ICON: "mdi:clipboard-list",
|
||||||
|
ATTR_LABEL: "",
|
||||||
|
ATTR_UNIT: "",
|
||||||
|
# ATTR_UNIT_ATTR: "value",
|
||||||
|
ATTR_GROUP: "Environment",
|
||||||
|
ATTR_PATH: "environment",
|
||||||
|
ATTR_ATTR: "value",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
DEVICE_ATTRIBUTES_ACCOUNTING = ["address", "mac-address", "host-name"]
|
DEVICE_ATTRIBUTES_ACCOUNTING = ["address", "mac-address", "host-name"]
|
||||||
|
@ -241,7 +251,7 @@ def update_items(inst, config_entry, mikrotik_controller, async_add_entities, se
|
||||||
|
|
||||||
for uid in mikrotik_controller.data["environment"]:
|
for uid in mikrotik_controller.data["environment"]:
|
||||||
item_id = (
|
item_id = (
|
||||||
f"{inst}-{sensor}-{mikrotik_controller.data['environment'][uid]['name']}"
|
f"{inst}-environment-{mikrotik_controller.data['environment'][uid]['name']}"
|
||||||
)
|
)
|
||||||
_LOGGER.debug("Updating sensor %s", item_id)
|
_LOGGER.debug("Updating sensor %s", item_id)
|
||||||
if item_id in sensors:
|
if item_id in sensors:
|
||||||
|
@ -252,7 +262,7 @@ def update_items(inst, config_entry, mikrotik_controller, async_add_entities, se
|
||||||
sensors[item_id] = MikrotikControllerEnvironmentSensor(
|
sensors[item_id] = MikrotikControllerEnvironmentSensor(
|
||||||
mikrotik_controller=mikrotik_controller,
|
mikrotik_controller=mikrotik_controller,
|
||||||
inst=inst,
|
inst=inst,
|
||||||
sensor=sensor,
|
sensor="environment",
|
||||||
uid=uid,
|
uid=uid,
|
||||||
)
|
)
|
||||||
new_sensors.append(sensors[item_id])
|
new_sensors.append(sensors[item_id])
|
||||||
|
@ -484,22 +494,17 @@ class MikrotikControllerEnvironmentSensor(MikrotikControllerSensor):
|
||||||
super().__init__(mikrotik_controller, inst, sensor)
|
super().__init__(mikrotik_controller, inst, sensor)
|
||||||
self._uid = uid
|
self._uid = uid
|
||||||
self._data = mikrotik_controller.data["environment"][uid]
|
self._data = mikrotik_controller.data["environment"][uid]
|
||||||
self._attr = "value"
|
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self):
|
|
||||||
"""Return the name."""
|
|
||||||
return f"{self._inst} {self._data['name']}"
|
|
||||||
|
|
||||||
@property
|
|
||||||
def unit_of_measurement(self):
|
|
||||||
"""Return the unit the value is expressed in."""
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def unique_id(self):
|
def unique_id(self):
|
||||||
"""Return a unique_id for this entity."""
|
"""Return a unique_id for this entity."""
|
||||||
return f"{self._inst.lower()}-environment-{self._uid}"
|
return f"{self._inst.lower()}-environment-{self._uid}"
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
"""Return the name."""
|
||||||
|
return f"{self._inst} {self._data['name']}"
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def state(self):
|
def state(self):
|
||||||
"""Return the state."""
|
"""Return the state."""
|
||||||
|
@ -509,32 +514,6 @@ class MikrotikControllerEnvironmentSensor(MikrotikControllerSensor):
|
||||||
|
|
||||||
return val
|
return val
|
||||||
|
|
||||||
@property
|
|
||||||
def icon(self):
|
|
||||||
"""Return the icon."""
|
|
||||||
self._icon = "mdi:clipboard-list"
|
|
||||||
return self._icon
|
|
||||||
|
|
||||||
@property
|
|
||||||
def device_info(self):
|
|
||||||
"""Return a port description for device registry."""
|
|
||||||
info = {
|
|
||||||
"manufacturer": self._ctrl.data["resource"]["platform"],
|
|
||||||
"model": self._ctrl.data["resource"]["board-name"],
|
|
||||||
"name": f"{self._inst} Environment",
|
|
||||||
"identifiers": {
|
|
||||||
(
|
|
||||||
DOMAIN,
|
|
||||||
"serial-number",
|
|
||||||
self._ctrl.data["routerboard"]["serial-number"],
|
|
||||||
"switch",
|
|
||||||
"environment",
|
|
||||||
)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
return info
|
|
||||||
|
|
||||||
async def async_added_to_hass(self):
|
async def async_added_to_hass(self):
|
||||||
"""Port entity created."""
|
"""Port entity created."""
|
||||||
_LOGGER.debug(
|
_LOGGER.debug(
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue