iobroker.zigbee 1.7.6 → 1.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +368 -381
  3. package/admin/admin.js +2951 -2927
  4. package/admin/i18n/de/translations.json +108 -0
  5. package/admin/i18n/en/translations.json +108 -0
  6. package/admin/i18n/es/translations.json +102 -0
  7. package/admin/i18n/fr/translations.json +108 -0
  8. package/admin/i18n/it/translations.json +102 -0
  9. package/admin/i18n/nl/translations.json +108 -0
  10. package/admin/i18n/pl/translations.json +108 -0
  11. package/admin/i18n/pt/translations.json +102 -0
  12. package/admin/i18n/ru/translations.json +108 -0
  13. package/admin/i18n/uk/translations.json +108 -0
  14. package/admin/i18n/zh-cn/translations.json +102 -0
  15. package/admin/img/philips_hue_lom001.png +0 -0
  16. package/admin/index.html +159 -159
  17. package/admin/index_m.html +1161 -1161
  18. package/admin/moment.min.js +1 -1
  19. package/admin/shuffle.min.js +2 -2
  20. package/admin/tab_m.html +985 -944
  21. package/admin/vis-network.min.css +1 -1
  22. package/admin/vis-network.min.js +27 -27
  23. package/admin/words.js +110 -110
  24. package/docs/de/img/CC2531.png +0 -0
  25. package/docs/de/img/CC2538_CC2592_PA.PNG +0 -0
  26. package/docs/de/img/CC2591.png +0 -0
  27. package/docs/de/img/boards.jpg +0 -0
  28. package/docs/de/img/cc26x2r.PNG +0 -0
  29. package/docs/de/img/results.jpg +0 -0
  30. package/docs/de/img/sku_429478_2.png +0 -0
  31. package/docs/de/img/sku_429601_2.png +0 -0
  32. package/docs/de/readme.md +27 -0
  33. package/docs/en/img/CC2531.png +0 -0
  34. package/docs/en/img/CC2591.png +0 -0
  35. package/docs/en/img/deconz.png +0 -0
  36. package/docs/en/img/sku_429478_2.png +0 -0
  37. package/docs/en/img/sku_429601_2.png +0 -0
  38. package/docs/en/readme.md +30 -0
  39. package/docs/flashing_via_arduino_(en).md +110 -0
  40. package/docs/ru/img/CC2531.png +0 -0
  41. package/docs/ru/img/CC2591.png +0 -0
  42. package/docs/ru/img/sku_429478_2.png +0 -0
  43. package/docs/ru/img/sku_429601_2.png +0 -0
  44. package/docs/ru/readme.md +28 -0
  45. package/docs/tutorial/CC2530_20190425.zip +0 -0
  46. package/docs/tutorial/CC2530_CC2591_20190515.zip +0 -0
  47. package/docs/tutorial/CC2530_CC2592_20190515.zip +0 -0
  48. package/docs/tutorial/CC2531_20190425.zip +0 -0
  49. package/docs/tutorial/adm5_1.PNG +0 -0
  50. package/docs/tutorial/adm5_2.PNG +0 -0
  51. package/docs/tutorial/cat.PNG +0 -0
  52. package/docs/tutorial/groups-1.png +0 -0
  53. package/docs/tutorial/groups-2.png +0 -0
  54. package/docs/tutorial/inst.PNG +0 -0
  55. package/docs/tutorial/reflash-finish.PNG +0 -0
  56. package/docs/tutorial/reflash-step0.png +0 -0
  57. package/docs/tutorial/reflash-step1.PNG +0 -0
  58. package/docs/tutorial/reflash-step2.PNG +0 -0
  59. package/docs/tutorial/settings.png +0 -0
  60. package/docs/tutorial/tab-dev-1.png +0 -0
  61. package/docs/tutorial/zigbee.png +0 -0
  62. package/docs/tutorial/zigbee15.png +0 -0
  63. package/io-package.json +335 -370
  64. package/lib/backup.js +171 -171
  65. package/lib/binding.js +320 -325
  66. package/lib/colors.js +465 -460
  67. package/lib/commands.js +510 -501
  68. package/lib/developer.js +145 -148
  69. package/lib/devices.js +3135 -3145
  70. package/lib/exclude.js +162 -168
  71. package/lib/exposes.js +828 -804
  72. package/lib/groups.js +340 -342
  73. package/lib/json.js +59 -60
  74. package/lib/networkmap.js +55 -56
  75. package/lib/ota.js +195 -179
  76. package/lib/rgb.js +297 -255
  77. package/lib/seriallist.js +48 -37
  78. package/lib/states.js +6405 -6416
  79. package/lib/statescontroller.js +693 -670
  80. package/lib/tools.js +54 -54
  81. package/lib/utils.js +152 -151
  82. package/lib/zbBaseExtension.js +36 -36
  83. package/lib/zbDelayedAction.js +144 -152
  84. package/lib/zbDeviceAvailability.js +319 -315
  85. package/lib/zbDeviceConfigure.js +147 -159
  86. package/lib/zbDeviceEvent.js +48 -49
  87. package/lib/zigbeecontroller.js +957 -951
  88. package/main.js +163 -147
  89. package/package.json +33 -19
  90. package/support/docgen.js +93 -93
  91. package/.eslintignore +0 -2
  92. package/.eslintrc.json +0 -37
  93. package/.github/FUNDING.yml +0 -3
  94. package/.github/stale.yml +0 -13
  95. package/.github/workflows/test-and-release.yml +0 -151
  96. package/.travis/wiki.sh +0 -28
  97. package/admin/adapter-settings.js +0 -244
@@ -1,159 +1,147 @@
1
- 'use strict';
2
-
3
- const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters');
4
- const BaseExtension = require('./zbBaseExtension');
5
-
6
- const forcedConfigureOnEachStart = [
7
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'V3-BTZB'),
8
- zigbeeHerdsmanConverters.devices.find((d) => d.model === '014G2461'),
9
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'SPZB0001'),
10
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'ZK03840')
11
- ];
12
-
13
-
14
-
15
- class DeviceConfigure extends BaseExtension {
16
- constructor(zigbee, options) {
17
- super(zigbee, options);
18
-
19
- this.configuring = new Set();
20
- this.attempts = {};
21
- this.name = "DeviceConfigure";
22
- }
23
-
24
- setOptions(options) {
25
- if (typeof(options) != 'object') return false;
26
- return true;
27
- }
28
-
29
- shouldConfigure(device, mappedDevice) {
30
- if (!device || !mappedDevice) {
31
- return false;
32
- }
33
- if (!mappedDevice || !mappedDevice.configure) {
34
- return false;
35
- }
36
- if (device.meta.hasOwnProperty('configured') &&
37
- zigbeeHerdsmanConverters.getConfigureKey(mappedDevice)) {
38
- return false;
39
- }
40
- if (device.interviewing === true) {
41
- return false;
42
- }
43
-
44
- return true;
45
- }
46
-
47
- async onZigbeeStarted() {
48
- try {
49
- this.coordinatorEndpoint = await this.zigbee.getDevicesByType('Coordinator')[0].endpoints[0];
50
-
51
- for (const device of await this.zigbee.getClients()) {
52
- const mappedDevice = zigbeeHerdsmanConverters.findByDevice(device);
53
-
54
- if (forcedConfigureOnEachStart.find((d) => d && d.hasOwnProperty('zigbeeModel') && d.zigbeeModel.includes(device.modelID))) {
55
- this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} forced by adapter config`);
56
- device.meta.configured = -1; // Force a reconfigure for this device
57
- }
58
- if (this.shouldConfigure(device, mappedDevice)) {
59
- this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} needed`);
60
- await this.configure(device, mappedDevice);
61
- } else {
62
- this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} not needed`);
63
- }
64
- }
65
- } catch (error) {
66
- this.sendError(error);
67
- this.error(
68
- `Failed to DeviceConfigure.onZigbeeStarted (${error.stack})`,
69
- );
70
- }
71
- }
72
-
73
- onZigbeeEvent(data, mappedDevice) {
74
- try {
75
- const device = data.device;
76
- if (this.shouldConfigure(device, mappedDevice)) {
77
- this.configure(device, mappedDevice);
78
- }
79
- } catch (error) {
80
- this.sendError(error);
81
- this.error(
82
- `Failed to DeviceConfigure.onZigbeeEvent (${error.stack})`,
83
- );
84
- }
85
- }
86
-
87
- onDeviceRemove(device){
88
- try {
89
- if (this.configuring.has(device.ieeeAddr)) {
90
- this.configuring.delete(device.ieeeAddr);
91
- }
92
-
93
- if (this.attempts.hasOwnProperty(device.ieeeAddr)) {
94
- delete this.attempts[device.ieeeAddr];
95
- }
96
- } catch (error) {
97
- this.sendError(error);
98
- this.error(
99
- `Failed to DeviceConfigure.onDeviceRemove (${error.stack})`,
100
- );
101
- }
102
- }
103
-
104
- onDeviceLeave(data, entity){
105
- if (entity) {
106
- this.onDeviceRemove(entity.device);
107
- } else {
108
- this.onDeviceRemove(data);
109
- }
110
- }
111
-
112
- async configure(device, mappedDevice) {
113
- try {
114
- if (this.configuring.has(device.ieeeAddr) || this.attempts[device.ieeeAddr] >= 5) {
115
- return false;
116
- }
117
-
118
- this.configuring.add(device.ieeeAddr);
119
-
120
- if (!this.attempts.hasOwnProperty(device.ieeeAddr)) {
121
- this.attempts[device.ieeeAddr] = 0;
122
- }
123
- try {
124
- await this.doConfigure(device, mappedDevice);
125
- } catch (error) {
126
- this.sendError(error);
127
- this.warn(
128
- `DeviceConfigure failed ${device.ieeeAddr} ${device.modelID}, ` +
129
- `attempt ${this.attempts[device.ieeeAddr] + 1} (${error.stack})`,
130
- );
131
- this.attempts[device.ieeeAddr]++;
132
- }
133
- this.configuring.delete(device.ieeeAddr);
134
- } catch (error) {
135
- this.sendError(error);
136
- this.error(
137
- `Failed to DeviceConfigure.configure ${device.ieeeAddr} ${device.modelID} (${error.stack})`,
138
- );
139
- }
140
- }
141
-
142
- async doConfigure(device, mappedDevice) {
143
- this.info(`Configuring ${device.ieeeAddr} ${device.modelID}`);
144
- const coordinatorEndpoint = await this.zigbee.getDevicesByType('Coordinator')[0].endpoints[0];
145
- try {
146
- await mappedDevice.configure(device, coordinatorEndpoint);
147
- device.meta.configured = zigbeeHerdsmanConverters.getConfigureKey(mappedDevice);
148
- device.save();
149
- this.info(`DeviceConfigure successful ${device.ieeeAddr} ${device.modelID}`);
150
- } catch (error) {
151
- this.sendError(error);
152
- this.error(
153
- `Failed to DeviceConfigure.configure ${device.ieeeAddr} ${device.modelID} (${error.stack})`,
154
- );
155
- }
156
- }
157
- }
158
-
159
- module.exports = DeviceConfigure;
1
+ 'use strict';
2
+
3
+ const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters');
4
+ const BaseExtension = require('./zbBaseExtension');
5
+
6
+ const forcedConfigureOnEachStart = [
7
+ zigbeeHerdsmanConverters.devices.find((d) => d.model === 'V3-BTZB'),
8
+ zigbeeHerdsmanConverters.devices.find((d) => d.model === '014G2461'),
9
+ zigbeeHerdsmanConverters.devices.find((d) => d.model === 'SPZB0001'),
10
+ zigbeeHerdsmanConverters.devices.find((d) => d.model === 'ZK03840')
11
+ ];
12
+
13
+ class DeviceConfigure extends BaseExtension {
14
+ constructor(zigbee, options) {
15
+ super(zigbee, options);
16
+
17
+ this.configuring = new Set();
18
+ this.attempts = {};
19
+ this.name = 'DeviceConfigure';
20
+ }
21
+
22
+ setOptions(options) {
23
+ return typeof options === 'object';
24
+ }
25
+
26
+ shouldConfigure(device, mappedDevice) {
27
+ if (!device || !mappedDevice) {
28
+ return false;
29
+ }
30
+ if (!mappedDevice || !mappedDevice.configure) {
31
+ return false;
32
+ }
33
+ if (device.meta.hasOwnProperty('configured') &&
34
+ zigbeeHerdsmanConverters.getConfigureKey(mappedDevice)) {
35
+ return false;
36
+ }
37
+
38
+ return device.interviewing !== true;
39
+ }
40
+
41
+ async onZigbeeStarted() {
42
+ try {
43
+ this.coordinatorEndpoint = await this.zigbee.getDevicesByType('Coordinator')[0].endpoints[0];
44
+
45
+ for (const device of await this.zigbee.getClients()) {
46
+ const mappedDevice = zigbeeHerdsmanConverters.findByDevice(device);
47
+
48
+ if (forcedConfigureOnEachStart.find((d) => d && d.hasOwnProperty('zigbeeModel') && d.zigbeeModel.includes(device.modelID))) {
49
+ this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} forced by adapter config`);
50
+ device.meta.configured = -1; // Force a reconfiguration for this device
51
+ }
52
+ if (this.shouldConfigure(device, mappedDevice)) {
53
+ this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} needed`);
54
+ await this.configure(device, mappedDevice);
55
+ } else {
56
+ this.debug(`DeviceConfigure ${device.ieeeAddr} ${device.modelID} not needed`);
57
+ }
58
+ }
59
+ } catch (error) {
60
+ this.sendError(error);
61
+ this.error(`Failed to DeviceConfigure.onZigbeeStarted (${error.stack})`);
62
+ }
63
+ }
64
+
65
+ onZigbeeEvent(data, mappedDevice) {
66
+ try {
67
+ const device = data.device;
68
+ if (this.shouldConfigure(device, mappedDevice)) {
69
+ this.configure(device, mappedDevice);
70
+ }
71
+ } catch (error) {
72
+ this.sendError(error);
73
+ this.error(`Failed to DeviceConfigure.onZigbeeEvent (${error.stack})`);
74
+ }
75
+ }
76
+
77
+ onDeviceRemove(device) {
78
+ try {
79
+ if (this.configuring.has(device.ieeeAddr)) {
80
+ this.configuring.delete(device.ieeeAddr);
81
+ }
82
+
83
+ if (this.attempts.hasOwnProperty(device.ieeeAddr)) {
84
+ delete this.attempts[device.ieeeAddr];
85
+ }
86
+ } catch (error) {
87
+ this.sendError(error);
88
+ this.error(`Failed to DeviceConfigure.onDeviceRemove (${error.stack})`);
89
+ }
90
+ }
91
+
92
+ onDeviceLeave(data, entity) {
93
+ if (entity) {
94
+ this.onDeviceRemove(entity.device);
95
+ } else {
96
+ this.onDeviceRemove(data);
97
+ }
98
+ }
99
+
100
+ async configure(device, mappedDevice) {
101
+ try {
102
+ if (this.configuring.has(device.ieeeAddr) || this.attempts[device.ieeeAddr] >= 5) {
103
+ return false;
104
+ }
105
+
106
+ this.configuring.add(device.ieeeAddr);
107
+
108
+ if (!this.attempts.hasOwnProperty(device.ieeeAddr)) {
109
+ this.attempts[device.ieeeAddr] = 0;
110
+ }
111
+ try {
112
+ await this.doConfigure(device, mappedDevice);
113
+ } catch (error) {
114
+ this.sendError(error);
115
+ this.warn(
116
+ `DeviceConfigure failed ${device.ieeeAddr} ${device.modelID}, ` +
117
+ `attempt ${this.attempts[device.ieeeAddr] + 1} (${error.stack})`,
118
+ );
119
+ this.attempts[device.ieeeAddr]++;
120
+ }
121
+ this.configuring.delete(device.ieeeAddr);
122
+ } catch (error) {
123
+ this.sendError(error);
124
+ this.error(
125
+ `Failed to DeviceConfigure.configure ${device.ieeeAddr} ${device.modelID} (${error.stack})`,
126
+ );
127
+ }
128
+ }
129
+
130
+ async doConfigure(device, mappedDevice) {
131
+ this.info(`Configuring ${device.ieeeAddr} ${device.modelID}`);
132
+ const coordinatorEndpoint = await this.zigbee.getDevicesByType('Coordinator')[0].endpoints[0];
133
+ try {
134
+ await mappedDevice.configure(device, coordinatorEndpoint);
135
+ device.meta.configured = zigbeeHerdsmanConverters.getConfigureKey(mappedDevice);
136
+ device.save();
137
+ this.info(`DeviceConfigure successful ${device.ieeeAddr} ${device.modelID}`);
138
+ } catch (error) {
139
+ this.sendError(error);
140
+ this.error(
141
+ `Failed to DeviceConfigure.configure ${device.ieeeAddr} ${device.modelID} (${error.stack})`,
142
+ );
143
+ }
144
+ }
145
+ }
146
+
147
+ module.exports = DeviceConfigure;
@@ -1,49 +1,48 @@
1
- 'use strict';
2
-
3
- const BaseExtension = require('./zbBaseExtension');
4
- const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters');
5
-
6
- class DeviceEvent extends BaseExtension {
7
- constructor(zigbee, options) {
8
- super(zigbee, options);
9
- this.name = "DeviceEvent";
10
- }
11
-
12
-
13
- async onZigbeeStarted() {
14
- for (const device of await this.zigbee.getClients()) {
15
- this.callOnEvent(device, 'start', {});
16
- }
17
- }
18
-
19
- setOptions(options) {
20
- if (typeof(options) != 'object') return false;
21
- return true;
22
- }
23
-
24
- onZigbeeEvent(data, mappedDevice) {
25
- if (data.device) {
26
- this.callOnEvent(data.device, data.type, data, mappedDevice);
27
- }
28
- }
29
-
30
- async stop() {
31
- if (this.zigbee.getClients() > 0) {
32
- for (const device of await this.zigbee.getClients()) {
33
- this.callOnEvent(device, 'stop', {});
34
- }
35
- }
36
- }
37
-
38
- callOnEvent(device, type, data, mappedDevice) {
39
- if (!mappedDevice) {
40
- mappedDevice = zigbeeHerdsmanConverters.findByDevice(device);
41
- }
42
-
43
- if (mappedDevice && mappedDevice.onEvent) {
44
- mappedDevice.onEvent(type, data, device);
45
- }
46
- }
47
- }
48
-
49
- module.exports = DeviceEvent;
1
+ 'use strict';
2
+
3
+ const BaseExtension = require('./zbBaseExtension');
4
+ const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters');
5
+
6
+ class DeviceEvent extends BaseExtension {
7
+ constructor(zigbee, options) {
8
+ super(zigbee, options);
9
+ this.name = 'DeviceEvent';
10
+ }
11
+
12
+ async onZigbeeStarted() {
13
+ for (const device of await this.zigbee.getClients()) {
14
+ this.callOnEvent(device, 'start', {});
15
+ }
16
+ }
17
+
18
+ setOptions(options) {
19
+ return typeof options === 'object';
20
+
21
+ }
22
+
23
+ onZigbeeEvent(data, mappedDevice) {
24
+ if (data.device) {
25
+ this.callOnEvent(data.device, data.type, data, mappedDevice);
26
+ }
27
+ }
28
+
29
+ async stop() {
30
+ if (this.zigbee.getClients() > 0) {
31
+ for (const device of await this.zigbee.getClients()) {
32
+ this.callOnEvent(device, 'stop', {});
33
+ }
34
+ }
35
+ }
36
+
37
+ callOnEvent(device, type, data, mappedDevice) {
38
+ if (!mappedDevice) {
39
+ mappedDevice = zigbeeHerdsmanConverters.findByDevice(device);
40
+ }
41
+
42
+ if (mappedDevice && mappedDevice.onEvent) {
43
+ mappedDevice.onEvent(type, data, device);
44
+ }
45
+ }
46
+ }
47
+
48
+ module.exports = DeviceEvent;