mirror of
https://github.com/andvikt/mega_hacs.git
synced 2025-12-12 01:24:29 +05:00
Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ff6225a959 | ||
|
|
57f355d479 | ||
|
|
7d6273539e |
@@ -25,7 +25,7 @@ STEP_USER_DATA_SCHEMA = vol.Schema(
|
|||||||
vol.Optional(CONF_PORT_TO_SCAN, default=0): int,
|
vol.Optional(CONF_PORT_TO_SCAN, default=0): int,
|
||||||
vol.Optional(CONF_MQTT_INPUTS, default=True): bool,
|
vol.Optional(CONF_MQTT_INPUTS, default=True): bool,
|
||||||
vol.Optional(CONF_NPORTS, default=37): int,
|
vol.Optional(CONF_NPORTS, default=37): int,
|
||||||
vol.Optional(CONF_UPDATE_ALL, default=True): bool,
|
# vol.Optional(CONF_UPDATE_ALL, default=True): bool,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -123,10 +123,16 @@ class MegaD:
|
|||||||
async with self.lck:
|
async with self.lck:
|
||||||
self.entities.append(ent)
|
self.entities.append(ent)
|
||||||
|
|
||||||
async def get_sensors(self):
|
async def get_sensors(self, only_list=False):
|
||||||
self.lg.debug(self.sensors)
|
self.lg.debug(self.sensors)
|
||||||
|
ports = []
|
||||||
for x in self.sensors:
|
for x in self.sensors:
|
||||||
await self.get_port(x)
|
if only_list and x.http_cmd != 'list':
|
||||||
|
continue
|
||||||
|
if x.port in ports:
|
||||||
|
continue
|
||||||
|
await self.get_port(x.port, force_http=True, http_cmd=x.http_cmd)
|
||||||
|
ports.append(x.port)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_online(self):
|
def is_online(self):
|
||||||
@@ -157,6 +163,7 @@ class MegaD:
|
|||||||
self.lg.debug('poll')
|
self.lg.debug('poll')
|
||||||
if self.mqtt is None:
|
if self.mqtt is None:
|
||||||
await self.get_all_ports()
|
await self.get_all_ports()
|
||||||
|
await self.get_sensors(only_list=True)
|
||||||
return
|
return
|
||||||
if len(self.sensors) > 0:
|
if len(self.sensors) > 0:
|
||||||
await self.get_sensors()
|
await self.get_sensors()
|
||||||
@@ -188,7 +195,9 @@ class MegaD:
|
|||||||
self.lg.warning('%s returned %s (%s)', url, req.status, await req.text())
|
self.lg.warning('%s returned %s (%s)', url, req.status, await req.text())
|
||||||
return None
|
return None
|
||||||
else:
|
else:
|
||||||
return await req.text()
|
ret = await req.text()
|
||||||
|
self.lg.debug('response %s', ret)
|
||||||
|
return ret
|
||||||
|
|
||||||
async def save(self):
|
async def save(self):
|
||||||
await self.send_command(cmd='s')
|
await self.send_command(cmd='s')
|
||||||
@@ -209,15 +218,20 @@ class MegaD:
|
|||||||
ret = {'value': ret}
|
ret = {'value': ret}
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
async def get_port(self, port, force_http=False):
|
async def get_port(self, port, force_http=False, http_cmd='get'):
|
||||||
"""
|
"""
|
||||||
Запрос состояния порта. Состояние всегда возвращается в виде объекта, всегда сохраняется в центральное
|
Запрос состояния порта. Состояние всегда возвращается в виде объекта, всегда сохраняется в центральное
|
||||||
хранилище values
|
хранилище values
|
||||||
"""
|
"""
|
||||||
self.lg.debug(f'get port %s', port)
|
self.lg.debug(f'get port %s', port)
|
||||||
if self.mqtt is None or force_http:
|
if self.mqtt is None or force_http:
|
||||||
ret = await self.request(pt=port, cmd='get')
|
ret = await self.request(pt=port, cmd=http_cmd)
|
||||||
ret = self.parse_response(ret)
|
ret = self.parse_response(ret)
|
||||||
|
self.lg.debug('parsed: %s', ret)
|
||||||
|
if http_cmd == 'list' and isinstance(ret, dict) and 'value' in ret:
|
||||||
|
await asyncio.sleep(1)
|
||||||
|
ret = await self.request(pt=port, http_cmd=http_cmd)
|
||||||
|
ret = self.parse_response(ret)
|
||||||
self.values[port] = ret
|
self.values[port] = ret
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
@@ -361,7 +375,11 @@ class MegaD:
|
|||||||
ret['light'][port].append({'dimmer': m == '1'})
|
ret['light'][port].append({'dimmer': m == '1'})
|
||||||
elif pty == '3':
|
elif pty == '3':
|
||||||
try:
|
try:
|
||||||
|
http_cmd = 'get'
|
||||||
values = await self.get_port(port, force_http=True)
|
values = await self.get_port(port, force_http=True)
|
||||||
|
if values is None or (isinstance(values, dict) and str(values.get('value')) in ('', 'None')):
|
||||||
|
values = await self.get_port(port, force_http=True, http_cmd='list')
|
||||||
|
http_cmd = 'list'
|
||||||
except asyncio.TimeoutError:
|
except asyncio.TimeoutError:
|
||||||
self.lg.warning(f'timout on port {port}')
|
self.lg.warning(f'timout on port {port}')
|
||||||
continue
|
continue
|
||||||
@@ -382,6 +400,7 @@ class MegaD:
|
|||||||
unit_of_measurement=UNITS.get(key, UNITS[TEMP]),
|
unit_of_measurement=UNITS.get(key, UNITS[TEMP]),
|
||||||
device_class=CLASSES.get(key, CLASSES[TEMP]),
|
device_class=CLASSES.get(key, CLASSES[TEMP]),
|
||||||
id_suffix=key,
|
id_suffix=key,
|
||||||
|
http_cmd=http_cmd,
|
||||||
))
|
))
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
|
|||||||
@@ -101,6 +101,7 @@ class Mega1WSensor(MegaPushEntity):
|
|||||||
unit_of_measurement,
|
unit_of_measurement,
|
||||||
device_class,
|
device_class,
|
||||||
key=None,
|
key=None,
|
||||||
|
http_cmd='get',
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
):
|
):
|
||||||
@@ -115,8 +116,8 @@ class Mega1WSensor(MegaPushEntity):
|
|||||||
self.key = key
|
self.key = key
|
||||||
self._device_class = device_class
|
self._device_class = device_class
|
||||||
self._unit_of_measurement = unit_of_measurement
|
self._unit_of_measurement = unit_of_measurement
|
||||||
if self.port not in self.mega.sensors:
|
self.mega.sensors.append(self)
|
||||||
self.mega.sensors.append(self.port)
|
self.http_cmd = http_cmd
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def unit_of_measurement(self):
|
def unit_of_measurement(self):
|
||||||
@@ -143,12 +144,24 @@ class Mega1WSensor(MegaPushEntity):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def state(self):
|
def state(self):
|
||||||
|
ret = None
|
||||||
if self.key:
|
if self.key:
|
||||||
ret = self.mega.values.get(self.port, {}).get('value', {}).get(self.key)
|
try:
|
||||||
|
ret = self.mega.values.get(self.port, {})
|
||||||
|
if isinstance(ret, dict):
|
||||||
|
ret = ret.get(self.key)
|
||||||
|
except:
|
||||||
|
self.lg.error(self.mega.values.get(self.port, {}).get('value', {}))
|
||||||
|
return
|
||||||
else:
|
else:
|
||||||
ret = self.mega.values.get(self.port, {}).get('value')
|
ret = self.mega.values.get(self.port, {}).get('value')
|
||||||
if ret is None and self._state is not None:
|
if ret is None and self._state is not None:
|
||||||
ret = self._state.state
|
ret = self._state.state
|
||||||
|
try:
|
||||||
|
ret = float(ret)
|
||||||
|
ret = str(ret)
|
||||||
|
except:
|
||||||
|
ret = None
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|||||||
@@ -37,7 +37,8 @@
|
|||||||
"reload": "[%key:common::config_flow::data::reload%]",
|
"reload": "[%key:common::config_flow::data::reload%]",
|
||||||
"invert": "[%key:common::config_flow::data::invert%]",
|
"invert": "[%key:common::config_flow::data::invert%]",
|
||||||
"mqtt_inputs": "[%key:common::config_flow::data::mqtt_inputs%]",
|
"mqtt_inputs": "[%key:common::config_flow::data::mqtt_inputs%]",
|
||||||
"nports": "[%key:common::config_flow::data::nports%]"
|
"nports": "[%key:common::config_flow::data::nports%]",
|
||||||
|
"update_all": "[%key:common::config_flow::data::update_all%]"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,8 @@
|
|||||||
"scan_interval": "Scan interval (sec), 0 - don't update",
|
"scan_interval": "Scan interval (sec), 0 - don't update",
|
||||||
"port_to_scan": "Port to poll aliveness (needed only if no sensors used)",
|
"port_to_scan": "Port to poll aliveness (needed only if no sensors used)",
|
||||||
"nports": "Number of ports",
|
"nports": "Number of ports",
|
||||||
"update_all": "Update all outs when input"
|
"update_all": "Update all outs when input",
|
||||||
|
"mqtt_inputs": "Use MQTT"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user