Config entry and device for Coolmaster integration (#27925)
* Config entry and device for Coolmaster integration * Lint/isort/flake/etc... * Black formatting * Code review fixes * Config flow tests for coolmaster * Add pycoolmaster requirement to test * Remove port selection from Coolmaster config flow * Update config_flow.py * More idoimatic hash concat
This commit is contained in:
parent
b6fd191dc4
commit
1412862f2a
11 changed files with 265 additions and 33 deletions
|
@ -3,9 +3,8 @@
|
|||
import logging
|
||||
|
||||
from pycoolmasternet import CoolMasterNet
|
||||
import voluptuous as vol
|
||||
|
||||
from homeassistant.components.climate import PLATFORM_SCHEMA, ClimateDevice
|
||||
from homeassistant.components.climate import ClimateDevice
|
||||
from homeassistant.components.climate.const import (
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_DRY,
|
||||
|
@ -23,21 +22,11 @@ from homeassistant.const import (
|
|||
TEMP_CELSIUS,
|
||||
TEMP_FAHRENHEIT,
|
||||
)
|
||||
import homeassistant.helpers.config_validation as cv
|
||||
|
||||
from .const import CONF_SUPPORTED_MODES, DOMAIN
|
||||
|
||||
SUPPORT_FLAGS = SUPPORT_TARGET_TEMPERATURE | SUPPORT_FAN_MODE
|
||||
|
||||
DEFAULT_PORT = 10102
|
||||
|
||||
AVAILABLE_MODES = [
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_DRY,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
HVAC_MODE_FAN_ONLY,
|
||||
]
|
||||
|
||||
CM_TO_HA_STATE = {
|
||||
"heat": HVAC_MODE_HEAT,
|
||||
"cool": HVAC_MODE_COOL,
|
||||
|
@ -50,17 +39,6 @@ HA_STATE_TO_CM = {value: key for key, value in CM_TO_HA_STATE.items()}
|
|||
|
||||
FAN_MODES = ["low", "med", "high", "auto"]
|
||||
|
||||
CONF_SUPPORTED_MODES = "supported_modes"
|
||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
||||
{
|
||||
vol.Required(CONF_HOST): cv.string,
|
||||
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
||||
vol.Optional(CONF_SUPPORTED_MODES, default=AVAILABLE_MODES): vol.All(
|
||||
cv.ensure_list, [vol.In(AVAILABLE_MODES)]
|
||||
),
|
||||
}
|
||||
)
|
||||
|
||||
_LOGGER = logging.getLogger(__name__)
|
||||
|
||||
|
||||
|
@ -69,18 +47,17 @@ def _build_entity(device, supported_modes):
|
|||
return CoolmasterClimate(device, supported_modes)
|
||||
|
||||
|
||||
def setup_platform(hass, config, add_entities, discovery_info=None):
|
||||
async def async_setup_entry(hass, config_entry, async_add_devices):
|
||||
"""Set up the CoolMasterNet climate platform."""
|
||||
|
||||
supported_modes = config.get(CONF_SUPPORTED_MODES)
|
||||
host = config[CONF_HOST]
|
||||
port = config[CONF_PORT]
|
||||
supported_modes = config_entry.data.get(CONF_SUPPORTED_MODES)
|
||||
host = config_entry.data[CONF_HOST]
|
||||
port = config_entry.data[CONF_PORT]
|
||||
cool = CoolMasterNet(host, port=port)
|
||||
devices = cool.devices()
|
||||
devices = await hass.async_add_executor_job(cool.devices)
|
||||
|
||||
all_devices = [_build_entity(device, supported_modes) for device in devices]
|
||||
|
||||
add_entities(all_devices, True)
|
||||
async_add_devices(all_devices, True)
|
||||
|
||||
|
||||
class CoolmasterClimate(ClimateDevice):
|
||||
|
@ -118,6 +95,16 @@ class CoolmasterClimate(ClimateDevice):
|
|||
else:
|
||||
self._unit = TEMP_FAHRENHEIT
|
||||
|
||||
@property
|
||||
def device_info(self):
|
||||
"""Return device info for this device."""
|
||||
return {
|
||||
"identifiers": {(DOMAIN, self.unique_id)},
|
||||
"name": self.name,
|
||||
"manufacturer": "CoolAutomation",
|
||||
"model": "CoolMasterNet",
|
||||
}
|
||||
|
||||
@property
|
||||
def unique_id(self):
|
||||
"""Return unique ID for this device."""
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue