2019-04-03 15:40:03 +00:00
|
|
|
"""Support for monitoring an OpenEVSE Charger."""
|
2017-01-30 20:29:56 +00:00
|
|
|
import logging
|
|
|
|
|
2019-10-21 07:55:29 +00:00
|
|
|
import openevsewifi
|
2017-01-30 20:29:56 +00:00
|
|
|
from requests import RequestException
|
|
|
|
import voluptuous as vol
|
|
|
|
|
2021-03-22 18:46:46 +00:00
|
|
|
from homeassistant.components.sensor import PLATFORM_SCHEMA, SensorEntity
|
2019-03-13 01:46:41 +00:00
|
|
|
from homeassistant.const import (
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_HOST,
|
|
|
|
CONF_MONITORED_VARIABLES,
|
2019-10-21 07:55:29 +00:00
|
|
|
ENERGY_KILO_WATT_HOUR,
|
|
|
|
TEMP_CELSIUS,
|
2020-02-23 20:09:24 +00:00
|
|
|
TIME_MINUTES,
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-10-21 07:55:29 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2017-01-30 20:29:56 +00:00
|
|
|
|
2017-06-13 09:10:32 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2017-01-30 20:29:56 +00:00
|
|
|
SENSOR_TYPES = {
|
2019-07-31 19:25:30 +00:00
|
|
|
"status": ["Charging Status", None],
|
2020-02-23 20:09:24 +00:00
|
|
|
"charge_time": ["Charge Time Elapsed", TIME_MINUTES],
|
2019-07-31 19:25:30 +00:00
|
|
|
"ambient_temp": ["Ambient Temperature", TEMP_CELSIUS],
|
|
|
|
"ir_temp": ["IR Temperature", TEMP_CELSIUS],
|
|
|
|
"rtc_temp": ["RTC Temperature", TEMP_CELSIUS],
|
|
|
|
"usage_session": ["Usage this Session", ENERGY_KILO_WATT_HOUR],
|
|
|
|
"usage_total": ["Total Usage", ENERGY_KILO_WATT_HOUR],
|
2017-01-30 20:29:56 +00:00
|
|
|
}
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_HOST): cv.string,
|
|
|
|
vol.Optional(CONF_MONITORED_VARIABLES, default=["status"]): vol.All(
|
|
|
|
cv.ensure_list, [vol.In(SENSOR_TYPES)]
|
|
|
|
),
|
|
|
|
}
|
|
|
|
)
|
2017-01-30 20:29:56 +00:00
|
|
|
|
|
|
|
|
2018-08-24 14:37:30 +00:00
|
|
|
def setup_platform(hass, config, add_entities, discovery_info=None):
|
2017-02-11 19:29:37 +00:00
|
|
|
"""Set up the OpenEVSE sensor."""
|
2017-01-30 20:29:56 +00:00
|
|
|
host = config.get(CONF_HOST)
|
|
|
|
monitored_variables = config.get(CONF_MONITORED_VARIABLES)
|
|
|
|
|
|
|
|
charger = openevsewifi.Charger(host)
|
|
|
|
|
|
|
|
dev = []
|
|
|
|
for variable in monitored_variables:
|
|
|
|
dev.append(OpenEVSESensor(variable, charger))
|
|
|
|
|
2018-08-24 14:37:30 +00:00
|
|
|
add_entities(dev, True)
|
2017-01-30 20:29:56 +00:00
|
|
|
|
|
|
|
|
2021-03-22 18:46:46 +00:00
|
|
|
class OpenEVSESensor(SensorEntity):
|
2017-01-30 20:29:56 +00:00
|
|
|
"""Implementation of an OpenEVSE sensor."""
|
|
|
|
|
|
|
|
def __init__(self, sensor_type, charger):
|
|
|
|
"""Initialize the sensor."""
|
|
|
|
self._name = SENSOR_TYPES[sensor_type][0]
|
|
|
|
self.type = sensor_type
|
|
|
|
self._state = None
|
|
|
|
self.charger = charger
|
|
|
|
self._unit_of_measurement = SENSOR_TYPES[sensor_type][1]
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of the sensor."""
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def state(self):
|
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self._state
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unit_of_measurement(self):
|
|
|
|
"""Return the unit of measurement of this sensor."""
|
|
|
|
return self._unit_of_measurement
|
|
|
|
|
|
|
|
def update(self):
|
|
|
|
"""Get the monitored data from the charger."""
|
|
|
|
try:
|
2019-07-31 19:25:30 +00:00
|
|
|
if self.type == "status":
|
2017-01-30 20:29:56 +00:00
|
|
|
self._state = self.charger.getStatus()
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "charge_time":
|
2017-02-11 19:29:37 +00:00
|
|
|
self._state = self.charger.getChargeTimeElapsed() / 60
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "ambient_temp":
|
2017-01-30 20:29:56 +00:00
|
|
|
self._state = self.charger.getAmbientTemperature()
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "ir_temp":
|
2017-01-30 20:29:56 +00:00
|
|
|
self._state = self.charger.getIRTemperature()
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "rtc_temp":
|
2017-01-30 20:29:56 +00:00
|
|
|
self._state = self.charger.getRTCTemperature()
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "usage_session":
|
2017-02-11 19:29:37 +00:00
|
|
|
self._state = float(self.charger.getUsageSession()) / 1000
|
2019-07-31 19:25:30 +00:00
|
|
|
elif self.type == "usage_total":
|
2017-02-11 19:29:37 +00:00
|
|
|
self._state = float(self.charger.getUsageTotal()) / 1000
|
2017-01-30 20:29:56 +00:00
|
|
|
else:
|
2019-07-31 19:25:30 +00:00
|
|
|
self._state = "Unknown"
|
2017-01-30 20:29:56 +00:00
|
|
|
except (RequestException, ValueError, KeyError):
|
2017-02-11 19:29:37 +00:00
|
|
|
_LOGGER.warning("Could not update status for %s", self.name)
|