Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

disbaled-buggy-Stable7 7.1.13 #1749

Closed
wants to merge 151 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
151 commits
Select commit Hold shift + click to select a range
bdbe16b
zclCluster decode the value and an int is provided. Allow to check st…
pipiche38 Jun 1, 2024
7c53e6d
Fix profalux tilt (#1746)
pipiche38 Jun 8, 2024
549786d
fix mistake in the way to Update or not Timedout flag on domoticz (#1…
pipiche38 Jun 8, 2024
9506c5b
WebUI update to display RSSI if available (#1739)
pipiche38 Jun 8, 2024
1650c9b
Remove disabled function, optimize and use time() only once (#1738)
pipiche38 Jun 8, 2024
e52a7b0
cleaning up logs messages / refactor submit request (#1745)
pipiche38 Jun 8, 2024
d81bd82
make sure that requests is part of the python3 modules (#1747)
pipiche38 Jun 9, 2024
a43eefc
when seting Device timedout make sure to read the correspoding unit (…
pipiche38 Jun 9, 2024
7e24445
Logging to track python module loading (#1741)
pipiche38 Jun 17, 2024
7909631
Do not push Ack/Nack when Ack is disable
pipiche38 Jun 19, 2024
0cc9e05
fix python3 module check against constraints.txt instead of requireme…
pipiche38 Jun 22, 2024
e97465f
in case check_requirements return True meaning problem, stop the plugin
pipiche38 Jun 22, 2024
3459a07
better decoding of the heiman door bel (#1744)
pipiche38 Jun 22, 2024
350e398
Make WebUI on dedicated thread (#1751)
pipiche38 Jun 26, 2024
7db6caa
do not make error if certificate path do not exists
pipiche38 Jun 26, 2024
1f0aaed
Do not check the path for SSL certificate and private key when loadin…
pipiche38 Jun 26, 2024
3fc8359
before starting WebUI check that the port is not already in use
pipiche38 Jun 28, 2024
e5c5c56
prevent forcing Level to 1 for Profalux blinds (#1754)
pipiche38 Jul 8, 2024
6bd0e8e
disable checking against security issue Possible binding to all inte…
pipiche38 Jul 8, 2024
dfaea6c
Merge remote-tracking branch 'refs/remotes/origin/wip-stable7-7.1.13'…
pipiche38 Jul 8, 2024
170a2ae
Fix lvlcontrol (#1756)
pipiche38 Jul 10, 2024
46cc3b4
return value from 0 to 100 for all Blind and Venetian widgets
pipiche38 Jul 13, 2024
efb294b
add Sunricher PIR/Motion Manufacturer specific parameters (#1753)
pipiche38 Jul 13, 2024
ea3128b
remove checking the adress is already bind
pipiche38 Jul 17, 2024
e1ebba1
fix formating issue
pipiche38 Jul 17, 2024
3bbedc3
do not send default response, as zigpy layer is taking care of it
pipiche38 Jul 17, 2024
9def20a
enable Keep alive
pipiche38 Jul 17, 2024
958a69a
fix Error 200, when doing Auto Provisioning ( #1760)
pipiche38 Jul 17, 2024
78a89c6
Implement Polling and other Tuya specific command for the Tuya Temper…
pipiche38 Jul 29, 2024
a32b7a1
Fix schneider zoning path file (#1762)
badzz Jul 29, 2024
fbb574a
Rawaps for 0201 cluster (#1763)
badzz Jul 29, 2024
9623885
Temp piscine (#1764)
pipiche38 Jul 29, 2024
a9b1c45
read all data in case of any Verb
pipiche38 Jul 30, 2024
51bcf93
disable for now Chunk
pipiche38 Jul 30, 2024
f42e30b
add more debug
pipiche38 Jul 30, 2024
d22752c
making sure that we read all frame
pipiche38 Jul 30, 2024
9f44c8c
increase Chunk size to 8KB
pipiche38 Jul 30, 2024
a290534
rename MAX_BLOCK_SIZE
pipiche38 Jul 31, 2024
275cb90
refactor get_deviceconf_parameter_value()
pipiche38 Aug 3, 2024
2fd1929
simplify ts0601_instant_power() code
pipiche38 Aug 3, 2024
a22688e
update for Door/Vibration sensor from Lexman
pipiche38 Aug 5, 2024
3dcf409
Fix argument error when updating in case of Vibration
pipiche38 Aug 5, 2024
69a36f9
adding update of BatteryPercentage widget if exist
pipiche38 Aug 5, 2024
5edb7ad
implement BatteryPercentage widget
pipiche38 Aug 5, 2024
a56eb7e
create a dedicated function for _ldsenk08_zone_status_change
pipiche38 Aug 6, 2024
fbae736
fix error
pipiche38 Aug 6, 2024
954bac1
fix error
pipiche38 Aug 6, 2024
b82d7f2
Move Log to Debug and fix issue on BatteryPercentage widget
pipiche38 Aug 6, 2024
f58b826
force to send default response if needed (hack for Tuya)
pipiche38 Aug 6, 2024
4aa9713
fix issue on BatteryPercentage
pipiche38 Aug 6, 2024
08dbdea
use HighPriority to send default response
pipiche38 Aug 6, 2024
6cd3600
cosmetic
pipiche38 Aug 7, 2024
99822f4
Make additional query optional
pipiche38 Aug 7, 2024
c991c47
fix f-string missing statement
pipiche38 Aug 7, 2024
b7c17a7
fix several issue in polling calculation
pipiche38 Aug 7, 2024
f092714
change default consecutive polling and elapsed time
pipiche38 Aug 8, 2024
73dad9b
Polling widget implemntation (#1765)
pipiche38 Aug 9, 2024
de7e0fd
Polling widget (#1766)
pipiche38 Aug 9, 2024
f4be5dc
adding PollingControlV2
pipiche38 Aug 12, 2024
8b117a2
adding PollingControlV2
pipiche38 Aug 12, 2024
38cf6eb
adding PollingControlV2
pipiche38 Aug 12, 2024
ef5a7c1
adding PollingControlV2
pipiche38 Aug 12, 2024
14a1f4a
Prevent WidgetType Tamper and ClusterType =! "Alarm"
pipiche38 Aug 13, 2024
d1d4f16
fixing mistake
pipiche38 Aug 13, 2024
b46d97f
Enable NodOn Firmware update
pipiche38 Aug 15, 2024
acc320d
define generic function for TS0601 curtain ( https://github.com/zigbe…
pipiche38 Aug 16, 2024
be540b0
during onStop, check if self.log exist before using it
pipiche38 Aug 16, 2024
2debd7e
Convert percentage to analog before updqting the widget
pipiche38 Aug 16, 2024
6f5b3dc
Merge remote-tracking branch 'refs/remotes/origin/wip-stable7-7.1.13'…
pipiche38 Aug 16, 2024
d6def0c
Actuatoir based on TS0601 DP
pipiche38 Aug 16, 2024
9a606aa
On is 2
pipiche38 Aug 16, 2024
576c42e
update
pipiche38 Aug 16, 2024
cc9ebf5
fix codefactor - 2 spaces
pipiche38 Aug 17, 2024
71afeea
Curtain state is using data type 0x04 (bitmap) and not 0x01 (boolean)
pipiche38 Aug 17, 2024
c41184d
Invert Open/Close for Tuya Curtain actionator
pipiche38 Aug 18, 2024
18fc141
Update to handle Open/Close
pipiche38 Aug 20, 2024
521d20e
Add SwitchCalibration
pipiche38 Aug 20, 2024
c9ff52b
Use bitmap instead of boolean for Calibration
pipiche38 Aug 22, 2024
e42006c
refactor and simplify
pipiche38 Aug 22, 2024
5bd5c51
differentiate command from response
pipiche38 Aug 22, 2024
fe5ad50
update data type
pipiche38 Aug 24, 2024
f751ca0
fix syntax issue
pipiche38 Aug 24, 2024
d60cde5
Use dp 0x07 for Calibration instead of 0x03
pipiche38 Aug 24, 2024
dfd22ca
Update widget Calibration when On/Off
pipiche38 Aug 24, 2024
7dc4ac7
Update ts0601_curtain_level to report %
pipiche38 Aug 24, 2024
e3cc921
When receiving Open/Closed for Blind correctly handle the widget update
pipiche38 Aug 26, 2024
d23554c
Update LevelControl handling for Curtain
pipiche38 Aug 27, 2024
615fb6a
fix syntax issue
pipiche38 Aug 29, 2024
0d9cb43
fix mistake from previous commit
pipiche38 Aug 29, 2024
c690d43
Add quick calibration command
pipiche38 Aug 30, 2024
0a99910
make sure the object exist
pipiche38 Sep 2, 2024
bd05c48
Convert to int if the Tuya Baterry attribute is str
pipiche38 Sep 2, 2024
4314dd2
make the code more resilient
pipiche38 Sep 2, 2024
b821e69
make sure that modelname is not a dict
pipiche38 Sep 2, 2024
c23e0d5
looks like we can get device_id as {}
pipiche38 Sep 2, 2024
af151d5
test only if not None
pipiche38 Sep 3, 2024
f3aa842
enhance and allow debug BatteryManagement
pipiche38 Sep 6, 2024
4423178
function to store Battery timestamp
pipiche38 Sep 8, 2024
92816be
Disabled Analytics
pipiche38 Sep 8, 2024
958d1a2
Timestamp when receiving Battery voltage or percentage
pipiche38 Sep 8, 2024
b11449b
Timestamp when receiving Voltage or Percentage
pipiche38 Sep 8, 2024
3638cf6
prioritize with timestamp to take Percentage or Voltage
pipiche38 Sep 8, 2024
960a865
remove multiple spaces after keyword
pipiche38 Sep 8, 2024
9594af1
decoding more Timestamp in WebUI Tools
pipiche38 Sep 8, 2024
21ab1fc
implement functionality for the TS0207 Rain and Lux sensor
pipiche38 Sep 10, 2024
1c7a062
add RainIntensity
pipiche38 Sep 10, 2024
156946d
cosmetic
pipiche38 Sep 10, 2024
341a8aa
adding illuminance 20min average for Tuya Rain/Lux sensor
pipiche38 Sep 11, 2024
d072ba7
update the Tuya attribute for illuminance on 20min average
pipiche38 Sep 11, 2024
eb16bec
Handle TS0601 TempHumi
pipiche38 Sep 13, 2024
c2746aa
Fine tune integration of TRV BAB-1413Pro-E ( https://github.com/zigbe…
pipiche38 Sep 13, 2024
bc0a4c4
Fix Valve (Pi Heating) reporting in Vale% widget
pipiche38 Sep 14, 2024
2667932
Some time the Boolean can come with a different value than 0x00 or 0x…
pipiche38 Sep 16, 2024
4bcae86
refactor Update Switch/LvlControl
pipiche38 Sep 16, 2024
f2218a8
Fix logging (#1769)
badzz Oct 12, 2024
2ae8e96
fix function signature issue: no idea what are the consequence but th…
badzz Oct 16, 2024
b1f97a3
Revert "fix function signature issue: no idea what are the consequenc…
pipiche38 Oct 16, 2024
18be38f
when filter nwkid on logging, we can see that some function dont log …
badzz Oct 16, 2024
8c6d2c5
fix miss-alignement in signature of tuya_eTRV_registration. See ( ##1…
pipiche38 Oct 18, 2024
9e6a3b5
Upgrade zigpy libraries 7 1 13 stable7 (#1757)
pipiche38 Oct 18, 2024
659d020
Adding bindingDelay parameter, which allow to specify a waiting time …
pipiche38 Oct 18, 2024
c5619c1
retreive bindingDelay and use it when sending the command
pipiche38 Oct 18, 2024
d8fb468
adding delayAfterSent to the zigpy_raw_APS_request signature
pipiche38 Oct 18, 2024
4ae904d
implement the use of delayAfterSent to do a asyncio.sleep after a com…
pipiche38 Oct 18, 2024
af8fed7
reverting the disabling of Plugin Analytics, as it has some side effect
pipiche38 Oct 18, 2024
7b853ae
fine tune Moes Curtain calibration ( https://github.com/zigbeefordomo…
pipiche38 Oct 18, 2024
d66f90c
prevent trying to extract delayAfterSent, when it is empty
pipiche38 Oct 18, 2024
fdf9740
Disable Tamper if disabled in Config file
pipiche38 Oct 19, 2024
f604842
enable plugin device database to be writen in Domoticz sqlite db duri…
pipiche38 Oct 20, 2024
05036f4
remove un-necessary log
pipiche38 Oct 20, 2024
feb86b0
Use Datapoint 0x03 for Moes Curtain Switch Accurate calibration and n…
pipiche38 Oct 20, 2024
5fa065e
cosmetic in log message
pipiche38 Oct 20, 2024
540b4e6
cosmetic
pipiche38 Oct 28, 2024
ec2d13d
correct log message
pipiche38 Oct 28, 2024
3c82632
cosmetic
pipiche38 Oct 28, 2024
2ad0d09
do not forward 0x0019 OTA packets to zigpy layer
pipiche38 Oct 28, 2024
10f7f3d
better manage quote
pipiche38 Oct 28, 2024
5b5002f
update zigpy libs
pipiche38 Oct 28, 2024
a7eb4e0
update zigpy libs
pipiche38 Oct 29, 2024
136dc75
Backup coordinator infos to Domoticz and makes the all Domoticz backu…
pipiche38 Oct 30, 2024
bebfdc2
makes function more resilient
pipiche38 Oct 30, 2024
315430d
make functions more resilient
pipiche38 Oct 30, 2024
264c659
disable DeviceList storage/read in domoticz for now
pipiche38 Oct 30, 2024
20be7ee
Store in Domoticz only if storeDomoticzDatabase is enabled
pipiche38 Oct 30, 2024
f57cd04
refactor _open_image_file()
pipiche38 Oct 30, 2024
95fc966
refactor test and make storeDomoticzDatabase or useDomoticzDatabase t…
pipiche38 Oct 30, 2024
e2043f9
enable possibility of race memory allocations with tracemalloc
pipiche38 Oct 30, 2024
d7f7091
resilience of database load
pipiche38 Oct 31, 2024
2b98d7b
fixing
pipiche38 Oct 31, 2024
1836e95
Use contextlib instead of try/except
pipiche38 Nov 2, 2024
41e65dd
Revert domoticz storage (#1776)
pipiche38 Nov 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Backup coordinator infos to Domoticz and makes the all Domoticz backu…
…p/restore more resilient (#1773)


* implement coordinator backup towards Domoticz sqlite Db

* Makes a version2 of Domoticz backup storage. make sure to encode UTF8 and serialized

* refactor some of the functions

* make sure to initialize the IEEE2NWK dict after loading plugin db from Domoticz

* refactor DeviceExist
  • Loading branch information
pipiche38 authored Oct 30, 2024
commit 136dc7594a7792bccb6b88dfc4f641275a12e798
28 changes: 13 additions & 15 deletions Classes/AdminWidgets.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
"""
Class: AdminWidget.py

Description: Manage the Admistration Widget available on Domoticz

"""
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

from Modules.domoticzAbstractLayer import (
FreeUnit, domo_create_api, domo_read_nValue_sValue, domo_update_api,
@@ -32,11 +32,11 @@ def _get_switch_selector_options(self, ):
}

return {
"LevelActions": "|||||||",
"LevelNames": "Off|Purge Reports|Soft Reset|One Time Enrolmennt|Perm. Enrollment|Interf Scan|LQI Report",
"LevelOffHidden": "true",
"SelectorStyle": "0",
}
"LevelActions": "|||||||",
"LevelNames": "Off|Purge Reports|Soft Reset|One Time Enrolmennt|Perm. Enrollment|Interf Scan|LQI Report",
"LevelOffHidden": "true",
"SelectorStyle": "0",
}

class AdminWidgets:
def __init__(self, log, PluginConf, pluginParameters, ListOfDomoticzWidget, Devices, ListOfDevices, HardwareID, IEEE2NWK):
@@ -146,5 +146,3 @@ def updateNotificationWidget(self, Devices, notification):

def handleCommand(self, Command):
return


20 changes: 10 additions & 10 deletions Classes/DomoticzDB.py
Original file line number Diff line number Diff line change
@@ -1,26 +1,26 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
"""
Module: z_DomoticzDico.py

Description: Retreive & Build Domoticz Dictionary

"""
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license


import base64
import binascii
import json
import socket
import ssl
import time
import urllib.request
import ssl

from Modules.restartPlugin import restartPluginViaDomoticzJsonApi
from Classes.LoggingManagement import LoggingManagement
from Modules.restartPlugin import restartPluginViaDomoticzJsonApi
from Modules.tools import is_domoticz_new_API

CACHE_TIMEOUT = (15 * 60) + 15 # num seconds
14 changes: 8 additions & 6 deletions Classes/IAS.py
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
"""
Module: z_IAS.py
Description: IAS Zone management
"""
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license


import struct
11 changes: 9 additions & 2 deletions Classes/NetworkEnergy.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,15 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

#
# Module: NetworkEnergy.py
#
16 changes: 11 additions & 5 deletions Classes/NetworkMap.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

# Module: NetworkMap.py
#
# Description: Network Mapping based on LQI
@@ -26,12 +32,12 @@

import json
import os.path
from pathlib import Path
import time
from datetime import datetime
from pathlib import Path

from Modules.zb_tables_management import (mgmt_rtg, start_new_table_scan,
update_merge_new_device_to_last_entry)
from Modules.zb_tables_management import (
mgmt_rtg, start_new_table_scan, update_merge_new_device_to_last_entry)
from Zigbee.zdpCommands import zdp_NWK_address_request, zdp_nwk_lqi_request


1 change: 1 addition & 0 deletions Classes/OTA.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
#
49 changes: 29 additions & 20 deletions Classes/PluginConf.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,15 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license


"""
Class PluginConf
@@ -530,9 +537,9 @@ def write_Settings(self):
with open(pluginConfFile, "wt") as handle:
json.dump(write_pluginConf, handle, sort_keys=True, indent=2)


if is_domoticz_db_available(self) and (self.pluginConf["useDomoticzDatabase"] or self.pluginConf["storeDomoticzDatabase"]):
setConfigItem(Key="PluginConf", Value={"TimeStamp": time.time(), "b64Settings": write_pluginConf})
Domoticz.Status("+ Saving Plugin Configuration into Domoticz")
setConfigItem(Key="PluginConf", Attribute="b64Settings", Value={"TimeStamp": time.time(), "b64Settings": write_pluginConf})


def _load_Settings(self):
@@ -541,14 +548,13 @@ def _load_Settings(self):

dz_timestamp = 0
if is_domoticz_db_available(self):
_domoticz_pluginConf = getConfigItem(Key="PluginConf")
_domoticz_pluginConf = getConfigItem(Key="PluginConf", Attribute="b64Settings")

if "TimeStamp" in _domoticz_pluginConf:
dz_timestamp = _domoticz_pluginConf["TimeStamp"]
_domoticz_pluginConf = _domoticz_pluginConf["b64Settings"]
Domoticz.Log(
"Plugin data loaded where saved on %s"
% (time.strftime("%A, %Y-%m-%d %H:%M:%S", time.localtime(dz_timestamp)))
)
Domoticz.Log( "Plugin data loaded where saved on %s" % (
time.strftime("%A, %Y-%m-%d %H:%M:%S", time.localtime(dz_timestamp))) )
if not isinstance(_domoticz_pluginConf, dict):
_domoticz_pluginConf = {}

@@ -574,22 +580,25 @@ def _load_Settings(self):
self.pluginConf[param] = _pluginConf[param]

# Check Load
if is_domoticz_db_available(self) and self.pluginConf["useDomoticzDatabase"]:
Domoticz.Log("PluginConf Loaded from Dz: %s from Json: %s" % (len(_domoticz_pluginConf), len(_pluginConf)))
if _domoticz_pluginConf:
for x in _pluginConf:
if x not in _domoticz_pluginConf:
Domoticz.Error("-- %s is missing in Dz" % x)
elif _pluginConf[x] != _domoticz_pluginConf[x]:
Domoticz.Error(
"++ %s is different in Dz: %s from Json: %s" % (x, _domoticz_pluginConf[x], _pluginConf[x])
)
if is_domoticz_db_available(self):
Domoticz.Log("==> Sanity check : PluginConf Loaded. %s entries from Domoticz, %s from Json" % (
len(_domoticz_pluginConf), len(_pluginConf)))

if is_domoticz_db_available(self) and self.pluginConf["useDomoticzDatabase"] and _domoticz_pluginConf:
for x in _pluginConf:
if x not in _domoticz_pluginConf:
Domoticz.Error("-- %s is missing in Dz" % x)
elif _pluginConf[x] != _domoticz_pluginConf[x]:
Domoticz.Error(
"++ %s is different in Dz: %s from Json: %s" % (x, _domoticz_pluginConf[x], _pluginConf[x])
)

# Overwrite Zigpy parameters if we are running native Zigate
if self.zigbee_communication != "zigpy":
# Force to 0 as this parameter is only relevant to Zigpy
self.pluginConf["ZigpyTopologyReport"] = False


def _load_oldfashon(self, homedir, hardwareid):
# Import PluginConf.txt
# Migration
@@ -701,7 +710,7 @@ def zigpy_setup(self):
"Advanced": True,
}


def setup_folder_parameters(self, homedir):

for theme in SETTINGS:
11 changes: 8 additions & 3 deletions Classes/TransportStats.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#

# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

import json
from time import time
13 changes: 10 additions & 3 deletions Classes/WebServer/WebServer.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,15 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license


import json
import mimetypes
@@ -25,7 +32,7 @@
domoticz_log_api,
domoticz_status_api)
from Modules.sendZigateCommand import sendZigateCmd
from Modules.tools import is_hex, get_device_nickname
from Modules.tools import get_device_nickname, is_hex
from Modules.txPower import set_TxPower
from Modules.zigateCommands import zigate_set_mode
from Modules.zigateConsts import (CERTIFICATION_CODE, ZCL_CLUSTERS_LIST,
17 changes: 12 additions & 5 deletions Classes/WebServer/rest_recreateWidget.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: zaraki673 & pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
from time import time
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

import json
from time import time

from Classes.WebServer.headerResponse import (prepResponseMessage,
setupHeadersResponse)
@@ -42,13 +49,13 @@ def rest_recreate_widgets(self, verb, data, parameters):
domoticz_error_api("rest_recreate_widgets - Unknown device %s " % key)
return _response
nwkid = self.IEEE2NWK[key]
_response["Data"] = json.dumps({"Status": "Ok", "Status": "IEEE %s set to Provisioning Requested at %s" % (key, int(time()))})
_response["Data"] = json.dumps({"Status": "Ok", "ExtraInfo": "IEEE %s set to Provisioning Requested at %s" % (key, int(time()))})
else:
nwkid = data["NWKID"]
if nwkid not in self.ListOfDevices:
domoticz_error_api("rest_recreate_widgets - Unknown device %s " % nwkid)
return _response
_response["Data"] = json.dumps({"Status": "Ok", "Status": "NwkId %s set to Provisioning Requested at %s" % (nwkid, int(time()))})
_response["Data"] = json.dumps({"Status": "Ok", "ExtraInfo": "NwkId %s set to Provisioning Requested at %s" % (nwkid, int(time()))})

over_write_type_from_deviceconf( self, self.Devices, nwkid)
self.ListOfDevices[nwkid]["Status"] = "CreateDB"
2 changes: 1 addition & 1 deletion Classes/ZigpyTopology.py
Original file line number Diff line number Diff line change
@@ -12,9 +12,9 @@

import json
import os.path
import time
import traceback
from pathlib import Path
import time

import zigpy.types as t

3 changes: 2 additions & 1 deletion Classes/ZigpyTransport/AppGeneric.py
Original file line number Diff line number Diff line change
@@ -87,8 +87,9 @@ async def initialize(self, *, auto_form: bool = False, force_form: bool = False)

# Retreive Last Backup
_retreived_backup = _retreive_previous_backup(self)
self.log.logging( "Zigpy", "Debug","++ retreived backup (%s) %s" %(type(_retreived_backup), _retreived_backup))

# If We need to Creat a new Zigbee network annd restore the last backup
# If We need to Create a new Zigbee network annd restore the last backup
if force_form:
with contextlib.suppress(Exception):
if _retreived_backup is None:
13 changes: 10 additions & 3 deletions Classes/ZigpyTransport/Transport.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,14 @@
# coding: utf-8 -*-
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
#
# Author: pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

import json
import time
@@ -156,4 +163,4 @@ def loadTransmit(self):
_queue = sum(self._currently_waiting_requests_list[device] + 1 for device in list(self._currently_waiting_requests_list) if self._concurrent_requests_semaphores_list[device].locked())
_ret_value = max(_queue - 1, 0) + self.writer_queue.qsize()
self.log.logging("Transport", "Debug", "Load: PluginQueue: %3s ZigpyQueue: %3s => %s" %(self.writer_queue.qsize(), _queue, _ret_value ))
return _ret_value
return _ret_value
10 changes: 8 additions & 2 deletions Classes/ZigpyTransport/forwarderThread.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,14 @@
#!/usr/bin/env python3
# coding: utf-8 -*-
# -*- coding: utf-8 -*-
#
# Author: pipiche38
# Implementation of Zigbee for Domoticz plugin.
#
# This file is part of Zigbee for Domoticz plugin. https://github.com/zigbeefordomoticz/Domoticz-Zigbee
# (C) 2015-2024
#
# Initial authors: zaraki673 & pipiche38
#
# SPDX-License-Identifier: GPL-3.0 license

import queue
from threading import Thread
Loading
Loading