mirror of
https://github.com/andvikt/mega_hacs.git
synced 2025-12-12 17:44:28 +05:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5b86ceefe4 | ||
|
|
8cf000beae | ||
|
|
99317da9f6 | ||
|
|
97911d0241 | ||
|
|
d9925a2de0 |
13
.github/ISSUE_TEMPLATE/bug-report.md
vendored
13
.github/ISSUE_TEMPLATE/bug-report.md
vendored
@@ -8,19 +8,26 @@ assignees: ''
|
|||||||
---
|
---
|
||||||
|
|
||||||
**Описание**
|
**Описание**
|
||||||
A clear and concise description of what the bug is.
|
Описание проблемы
|
||||||
|
|
||||||
**Версии систем**
|
**Версии систем**
|
||||||
Enviroment: raspberry/linux/windows/macos/docker
|
Enviroment: raspberry/linux/windows/macos/docker
|
||||||
HA version:
|
HA version:
|
||||||
mega_hacs version:
|
mega_hacs version:
|
||||||
megad firmware version:
|
megad firmware version:
|
||||||
|
используется mqtt: true/false
|
||||||
|
|
||||||
**Ожидаемое поведение**
|
**Ожидаемое поведение**
|
||||||
A clear and concise description of what you expected to happen.
|
Описание правильного поведения
|
||||||
|
|
||||||
**Screenshots**
|
**Screenshots**
|
||||||
If applicable, add screenshots to help explain your problem.
|
If applicable, add screenshots to help explain your problem.
|
||||||
|
|
||||||
**LOG**
|
**LOG**
|
||||||
Прочитайте в документации как включить подробный лог интеграции и приложите его здесь
|
Просьба прикладывать детальный лог, который можно включить в конфиге так:
|
||||||
|
```yaml
|
||||||
|
logger:
|
||||||
|
default: info
|
||||||
|
logs:
|
||||||
|
custom_components.mega: debug
|
||||||
|
```
|
||||||
|
|||||||
@@ -75,7 +75,7 @@ async def async_setup(hass: HomeAssistant, config: dict):
|
|||||||
hass.services.async_register(
|
hass.services.async_register(
|
||||||
DOMAIN, 'get_port', partial(_get_port, hass), schema=vol.Schema({
|
DOMAIN, 'get_port', partial(_get_port, hass), schema=vol.Schema({
|
||||||
vol.Optional('mega_id'): str,
|
vol.Optional('mega_id'): str,
|
||||||
vol.Optional('port'): int,
|
vol.Optional('port'): vol.Any(int, [int]),
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
hass.services.async_register(
|
hass.services.async_register(
|
||||||
@@ -208,17 +208,23 @@ async def _get_port(hass: HomeAssistant, call: ServiceCall):
|
|||||||
if mega_id:
|
if mega_id:
|
||||||
hub: MegaD = hass.data[DOMAIN][mega_id]
|
hub: MegaD = hass.data[DOMAIN][mega_id]
|
||||||
if port is None:
|
if port is None:
|
||||||
await hub.get_all_ports()
|
await hub.get_all_ports(check_skip=True)
|
||||||
else:
|
elif isinstance(port, int):
|
||||||
await hub.get_port(port)
|
await hub.get_port(port)
|
||||||
|
elif isinstance(port, list):
|
||||||
|
for x in port:
|
||||||
|
await hub.get_port(x)
|
||||||
else:
|
else:
|
||||||
for hub in hass.data[DOMAIN].values():
|
for hub in hass.data[DOMAIN].values():
|
||||||
if not isinstance(hub, MegaD):
|
if not isinstance(hub, MegaD):
|
||||||
continue
|
continue
|
||||||
if port is None:
|
if port is None:
|
||||||
await hub.get_all_ports()
|
await hub.get_all_ports(check_skip=True)
|
||||||
else:
|
elif isinstance(port, int):
|
||||||
await hub.get_port(port)
|
await hub.get_port(port)
|
||||||
|
elif isinstance(port, list):
|
||||||
|
for x in port:
|
||||||
|
await hub.get_port(x)
|
||||||
|
|
||||||
|
|
||||||
@bind_hass
|
@bind_hass
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ from homeassistant.const import DEVICE_CLASS_TEMPERATURE, DEVICE_CLASS_HUMIDITY
|
|||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
from .const import TEMP, HUM, PATT_SPLIT, DOMAIN, CONF_HTTP, EVENT_BINARY_SENSOR
|
from .const import TEMP, HUM, PATT_SPLIT, DOMAIN, CONF_HTTP, EVENT_BINARY_SENSOR, CONF_CUSTOM, CONF_SKIP
|
||||||
from .entities import set_events_off
|
from .entities import set_events_off
|
||||||
from .exceptions import CannotConnect
|
from .exceptions import CannotConnect
|
||||||
from .tools import make_ints
|
from .tools import make_ints
|
||||||
@@ -91,6 +91,7 @@ class MegaD:
|
|||||||
self.last_update = datetime.now()
|
self.last_update = datetime.now()
|
||||||
self._callbacks: typing.DefaultDict[int, typing.List[typing.Callable[[dict], typing.Coroutine]]] = defaultdict(list)
|
self._callbacks: typing.DefaultDict[int, typing.List[typing.Callable[[dict], typing.Coroutine]]] = defaultdict(list)
|
||||||
self._loop = loop
|
self._loop = loop
|
||||||
|
self._customize = None
|
||||||
self.values = {}
|
self.values = {}
|
||||||
self.last_port = None
|
self.last_port = None
|
||||||
self.updater = DataUpdateCoordinator(
|
self.updater = DataUpdateCoordinator(
|
||||||
@@ -138,6 +139,14 @@ class MegaD:
|
|||||||
await self.get_port(x.port, force_http=True, http_cmd=x.http_cmd)
|
await self.get_port(x.port, force_http=True, http_cmd=x.http_cmd)
|
||||||
ports.append(x.port)
|
ports.append(x.port)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def customize(self):
|
||||||
|
if self._customize is None:
|
||||||
|
c = self.hass.data.get(DOMAIN, {}).get(CONF_CUSTOM) or {}
|
||||||
|
c = c.get(self.id) or {}
|
||||||
|
self._customize = c
|
||||||
|
return self._customize
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_online(self):
|
def is_online(self):
|
||||||
return (datetime.now() - self.last_update).total_seconds() < (self.poll_interval + 10)
|
return (datetime.now() - self.last_update).total_seconds() < (self.poll_interval + 10)
|
||||||
@@ -259,14 +268,20 @@ class MegaD:
|
|||||||
except asyncio.TimeoutError:
|
except asyncio.TimeoutError:
|
||||||
self.lg.error(f'timeout when getting port {port}')
|
self.lg.error(f'timeout when getting port {port}')
|
||||||
|
|
||||||
async def get_all_ports(self, only_out=False):
|
async def get_all_ports(self, only_out=False, check_skip=False):
|
||||||
if not self.mqtt_inputs:
|
if not self.mqtt_inputs:
|
||||||
ret = await self.request(cmd='all')
|
ret = await self.request(cmd='all')
|
||||||
for port, x in enumerate(ret.split(';')):
|
for port, x in enumerate(ret.split(';')):
|
||||||
|
if check_skip:
|
||||||
|
if self.customize.get(port, {}).get(CONF_SKIP, False):
|
||||||
|
continue
|
||||||
ret = self.parse_response(x)
|
ret = self.parse_response(x)
|
||||||
self.values[port] = ret
|
self.values[port] = ret
|
||||||
else:
|
else:
|
||||||
for x in range(self.nports + 1):
|
for x in range(self.nports + 1):
|
||||||
|
if check_skip:
|
||||||
|
if self.customize.get(x, {}).get(CONF_SKIP, False):
|
||||||
|
continue
|
||||||
await self.get_port(x)
|
await self.get_port(x)
|
||||||
|
|
||||||
async def reboot(self, save=True):
|
async def reboot(self, save=True):
|
||||||
@@ -376,7 +391,7 @@ class MegaD:
|
|||||||
m = m.find(selected=True)['value']
|
m = m.find(selected=True)['value']
|
||||||
self._scanned[port] = (pty, m)
|
self._scanned[port] = (pty, m)
|
||||||
return pty, m
|
return pty, m
|
||||||
elif pty == '2':
|
elif pty in ('2', '4'): # эта часть не очень проработана, тут есть i2c который может работать неправильно
|
||||||
self._scanned[port] = (pty, '0')
|
self._scanned[port] = (pty, '0')
|
||||||
return pty, '0'
|
return pty, '0'
|
||||||
|
|
||||||
@@ -394,7 +409,7 @@ class MegaD:
|
|||||||
ret['binary_sensor'][port].append({})
|
ret['binary_sensor'][port].append({})
|
||||||
elif pty == "1" and (m in ['0', '1', '3'] or m is None):
|
elif pty == "1" and (m in ['0', '1', '3'] or m is None):
|
||||||
ret['light'][port].append({'dimmer': m == '1'})
|
ret['light'][port].append({'dimmer': m == '1'})
|
||||||
elif pty in ('3', '2'):
|
elif pty in ('3', '2', '4'):
|
||||||
try:
|
try:
|
||||||
http_cmd = 'get'
|
http_cmd = 'get'
|
||||||
values = await self.get_port(port, force_http=True)
|
values = await self.get_port(port, force_http=True)
|
||||||
|
|||||||
@@ -15,5 +15,5 @@
|
|||||||
"@andvikt"
|
"@andvikt"
|
||||||
],
|
],
|
||||||
"issue_tracker": "https://github.com/andvikt/mega_hacs/issues",
|
"issue_tracker": "https://github.com/andvikt/mega_hacs/issues",
|
||||||
"version": "v0.3.12"
|
"version": "v0.3.13"
|
||||||
}
|
}
|
||||||
@@ -15,7 +15,7 @@ get_port:
|
|||||||
description: ID меги, можно оставить пустым, тогда будут сохранены все зарегистрированные меги
|
description: ID меги, можно оставить пустым, тогда будут сохранены все зарегистрированные меги
|
||||||
example: "mega"
|
example: "mega"
|
||||||
port:
|
port:
|
||||||
description: Номер порта (если не заполнять, будут запрошены все порты сразу)
|
description: Номер порта или список портов (если не заполнять, будут запрошены все порты сразу)
|
||||||
example: 1
|
example: 1
|
||||||
|
|
||||||
run_cmd:
|
run_cmd:
|
||||||
|
|||||||
@@ -155,12 +155,15 @@ mega:
|
|||||||
```
|
```
|
||||||
Возможные варианты поля `type`:
|
Возможные варианты поля `type`:
|
||||||
- `long`: долгое нажатие
|
- `long`: долгое нажатие
|
||||||
- `release`: размыкание (с гарантией что не было долгого нажатия)
|
- `release`: размыкание (с гарантией** что не было долгого нажатия)
|
||||||
- `long_release`: размыкание после долгого нажатия
|
- `long_release`: размыкание после долгого нажатия
|
||||||
- `press`: замыкание
|
- `press`: замыкание
|
||||||
- `single`: одинарный клик (в режиме кликов)
|
- `single`: одинарный клик (в режиме кликов)
|
||||||
- `double`: двойной клик
|
- `double`: двойной клик
|
||||||
|
|
||||||
|
**гарантия есть только при использовании http-метода синхронизации, mqtt не гарантирует порядок доставки сообщений, хотя
|
||||||
|
маловероятно, что порядок будет нарушен, но все же сам протокол не дает таких гарантий.
|
||||||
|
|
||||||
Чтобы понять, какие события происходят, лучше всего воспользоваться панелью разработчика и подписаться
|
Чтобы понять, какие события происходят, лучше всего воспользоваться панелью разработчика и подписаться
|
||||||
на вкладке события на событие `mega.sensor`, понажимать кнопки.
|
на вкладке события на событие `mega.sensor`, понажимать кнопки.
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user