iobroker.zigbee 1.8.24 → 1.9.0

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.
package/io-package.json CHANGED
@@ -1,8 +1,60 @@
1
1
  {
2
2
  "common": {
3
3
  "name": "zigbee",
4
- "version": "1.8.24",
4
+ "version": "1.9.0",
5
5
  "news": {
6
+ "1.9.0": {
7
+ "en": "up to new zhc\nupdate dependency",
8
+ "de": "bis zum neuen zhc\naktualisierung abhängigkeit",
9
+ "ru": "до нового жк\nобновление зависимости",
10
+ "pt": "até novo zhc\ndependência de atualização",
11
+ "nl": "♪\nvertaling:",
12
+ "fr": "jusqu'au nouveau zhc\nmettre à jour la dépendance",
13
+ "it": "fino a nuovo zhc\ndipendenza da aggiornamento",
14
+ "es": "hasta nuevo zhc\nactualización de la dependencia",
15
+ "pl": "do nowego żc\nzależności",
16
+ "uk": "до нового жк\nоновлення залежності",
17
+ "zh-cn": "新的忠诚\n更新"
18
+ },
19
+ "1.8.27": {
20
+ "en": "update dependency",
21
+ "de": "aktualisierung abhängigkeit",
22
+ "ru": "обновление зависимости",
23
+ "pt": "dependência de atualização",
24
+ "nl": "vertaling:",
25
+ "fr": "mettre à jour la dépendance",
26
+ "it": "dipendenza da aggiornamento",
27
+ "es": "actualización de la dependencia",
28
+ "pl": "zależności",
29
+ "uk": "оновлення залежності",
30
+ "zh-cn": "更新"
31
+ },
32
+ "1.8.26": {
33
+ "en": "corr toZigbee message\nadd deviceManager",
34
+ "de": "corr toZigbee Nachricht\nadd-Gerät Manager",
35
+ "ru": "corr toZigbee сообщение\nдобавить устройство менеджер",
36
+ "pt": "mensagem de corrija\nadicionar dispositivo Gerente",
37
+ "nl": "vertaling:\nvoeg Manager",
38
+ "fr": "corr toZigbee message\najouter le dispositif Manager",
39
+ "it": "corr aZigbee messaggio\naggiungere dispositivo Manager",
40
+ "es": "corr toZigbee message\nañadir dispositivo Manager",
41
+ "pl": "kor toZigbee message\ndodać manager",
42
+ "uk": "corr toZigbee повідомлення\nдодати пристрій Менеджер",
43
+ "zh-cn": "信\n增加装置 管理人员"
44
+ },
45
+ "1.8.25": {
46
+ "en": "zhc 16.x \ncorr group from exclude dialog",
47
+ "de": "zhc 16.x\nkorr gruppe aus ausschluss dialog",
48
+ "ru": "жк 16.x\nгруппа корр от исключает диалог",
49
+ "pt": "zhc 16.x\ncorr grupo de excluir diálogo",
50
+ "nl": "zhc 16\ncorr groep uitgesloten dialog",
51
+ "fr": "zhc 16.x\ngroupe corr de l'exclusion du dialogue",
52
+ "it": "zhc 16.x\ngruppo corr da escludere finestra di dialogo",
53
+ "es": "zhc 16.x\ngrupo de corr de excluir diálogo",
54
+ "pl": "żc 16.x\ngrupa kor z wyłączeniem dialogu",
55
+ "uk": "жк 16.x\nгрупа з виключення діалогу",
56
+ "zh-cn": "页: 1\n集团排除了口号"
57
+ },
6
58
  "1.8.24": {
7
59
  "en": "switch to exposes tab for some Aqara Devices",
8
60
  "de": "schalter, um die Registerkarte für einige Aqara-Geräte freizusetzen",
@@ -41,58 +93,6 @@
41
93
  "pl": "w przypadku, gdy meta jest pusta",
42
94
  "uk": "аварійний випадок, коли мета",
43
95
  "zh-cn": "c 当元空时发生事故"
44
- },
45
- "1.8.21": {
46
- "en": "no converter found",
47
- "de": "kein konverter gefunden",
48
- "ru": "не найдено конвертер",
49
- "pt": "não encontrado",
50
- "nl": "geen converter gevonden",
51
- "fr": "aucun convertisseur trouvé",
52
- "it": "nessun convertitore trovato",
53
- "es": "no convertidor encontrado",
54
- "pl": "nie znaleziono konwerterów",
55
- "uk": "не знайдено",
56
- "zh-cn": "未找到转换器"
57
- },
58
- "1.8.20": {
59
- "en": "add log",
60
- "de": "log",
61
- "ru": "добавить лог",
62
- "pt": "adicionar log",
63
- "nl": "voeg logboek toe",
64
- "fr": "ajouter log",
65
- "it": "aggiungi log",
66
- "es": "añadir registro",
67
- "pl": "dodać",
68
- "uk": "увійти",
69
- "zh-cn": "增 编"
70
- },
71
- "1.8.19": {
72
- "en": "fix occupancy_timeout\nfix battery percentage and voltage",
73
- "de": "fix occupation_timeout\nbatterieanteil und spannung fixieren",
74
- "ru": "исправить occupancy_timeout\nисправить процент батареи и напряжение",
75
- "pt": "corrigir ocupação_timeout\ncorrigir a porcentagem da bateria e a tensão",
76
- "nl": "vertaling:\nvertaling:",
77
- "fr": "fix occupancy_timeout\nfixer le pourcentage de la batterie et la tension",
78
- "it": "fix occupazione_timeout\ncorreggere la percentuale della batteria e la tensione",
79
- "es": "arreglar ocupación_timeout\nfijar porcentaje de batería y tensión",
80
- "pl": "naprawa occupancy_time\nodsetek baterii i napięcia",
81
- "uk": "фіксувати occupancy_timeout\nфіксувати відсоток акумулятора і напруга",
82
- "zh-cn": "fix 占用:时间假\nfix 电池百分比和火山"
83
- },
84
- "1.8.18": {
85
- "en": "little fix sentry and error log\n",
86
- "de": "kleines fix-sende- und fehlerprotokoll\n",
87
- "ru": "мало исправлена отправка и ошибка журнала\n",
88
- "pt": "pequena correção sentinela e log de erro\n",
89
- "nl": "kleine herstellende sentimentele logboek\n",
90
- "fr": "petit journal de réparation et d'erreur\n",
91
- "it": "piccolo fix registro di errore\n",
92
- "es": "pequeño solucion centry y error log\n",
93
- "pl": "wadliwość i błąd\n",
94
- "uk": "маленька фіксація відправлень і журнал помилок\n",
95
- "zh-cn": "很少发送过材料和错误逻辑\n"
96
96
  }
97
97
  },
98
98
  "titleLang": {
@@ -145,6 +145,9 @@
145
145
  "loglevel": "info",
146
146
  "type": "hardware",
147
147
  "materialize": true,
148
+ "supportedMessages": {
149
+ "deviceManager": true
150
+ },
148
151
  "messagebox": true,
149
152
  "stopBeforeUpdate": true,
150
153
  "dataFolder": "zigbee_%INSTANCE%",
package/lib/developer.js CHANGED
@@ -100,17 +100,23 @@ class Developer {
100
100
  return;
101
101
  }
102
102
  const cfg = obj.message.hasOwnProperty('cfg') ? obj.message.cfg : null;
103
-
104
- const publishTarget = this.zbController.getDevice(devId) ? devId : this.zbController.getGroup(parseInt(devId));
105
- if (!publishTarget) {
106
- this.adapter.sendTo(obj.from, obj.command, {localErr: `Device or group ${devId} not found!`}, obj.callback);
107
- return;
103
+ let publishTarget;
104
+ try {
105
+ publishTarget = this.zbController.getDevice(devId) ? devId : this.zbController.getGroup(parseInt(devId));
106
+ if (!publishTarget) {
107
+ this.adapter.sendTo(obj.from, obj.command, {localErr: `Device or group ${devId} not found!`}, obj.callback);
108
+ return;
109
+ }
110
+ } catch (error) {
111
+ this.error(`SendToZigbee failed from publishTarget ${devId} (${error})`);
108
112
  }
113
+
109
114
  if (!cid || !cmd) {
110
115
  this.adapter.sendTo(obj.from, obj.command, {localErr: 'Incomplete data (cid or cmd)'}, obj.callback);
111
116
  return;
112
117
  }
113
118
  this.debug(`Ready to send (ep: ${ep}, cid: ${cid}, cmd ${cmd.name}, zcl: ${JSON.stringify(zclData)})`);
119
+
114
120
  try {
115
121
  await this.zbController.publish(publishTarget, cid, cmd.name, zclData, cfg, ep, cmdType, (err, msg) => {
116
122
  // map err and msg in one object for sendTo
@@ -0,0 +1,393 @@
1
+ const dmUtils = require('@jey-cee/dm-utils');
2
+ const humanizeDuration = require('humanize-duration');
3
+
4
+ class dmZigbee extends dmUtils.DeviceManagement {
5
+
6
+ async getInstanceInfo() {
7
+ const data = {
8
+ ...super.getInstanceInfo(),
9
+ apiVersion: 'v1',
10
+ actions: [
11
+ {
12
+ id: 'refresh',
13
+ icon: 'fas fa-redo-alt',
14
+ title: '',
15
+ description: {
16
+ en: 'Refresh device list',
17
+ de: 'Geräteliste aktualisieren',
18
+ ru: 'Обновить список устройств',
19
+ pt: 'Atualizar lista de dispositivos',
20
+ nl: 'Vernieuw apparaatlijst',
21
+ fr: 'Actualiser la liste des appareils',
22
+ it: 'Aggiorna elenco dispositivi',
23
+ es: 'Actualizar lista de dispositivos',
24
+ pl: 'Odśwież listę urządzeń',
25
+
26
+ uk: 'Оновити список пристроїв'
27
+ },
28
+ handler: this.handleRefresh.bind(this)
29
+ },
30
+ {
31
+ id: 'newDevice',
32
+ icon: 'fas fa-plus',
33
+ title: '',
34
+ description: {
35
+ en: 'Add new device to Zigbee',
36
+ de: 'Neues Gerät zu Zigbee hinzufügen',
37
+ ru: 'Добавить новое устройство в Zigbee',
38
+ pt: 'Adicionar novo dispositivo ao Zigbee',
39
+ nl: 'Voeg nieuw apparaat toe aan Zigbee',
40
+ fr: 'Ajouter un nouvel appareil à Zigbee',
41
+ it: 'Aggiungi nuovo dispositivo a Zigbee',
42
+ es: 'Agregar nuevo dispositivo a Zigbee',
43
+ pl: 'Dodaj nowe urządzenie do Zigbee',
44
+
45
+ uk: 'Додати новий пристрій до Zigbee'
46
+ },
47
+ handler: this.handleNewDevice.bind(this)
48
+ }
49
+ ],
50
+ };
51
+ return data;
52
+ }
53
+
54
+ async handleRefresh(context) {
55
+ this.adapter.log.info('handleRefresh');
56
+ return { refresh: true };
57
+ }
58
+
59
+ async handleNewDevice(context) {
60
+ this.adapter.log.info('handleNewDevice');
61
+
62
+ const res = await this.adapter.zbController.permitJoin(permitTime);
63
+
64
+ const permitTime = this.adapter.config.countDown;
65
+
66
+ const progress = await context.openProgress('Searching...', { label: '0%' });
67
+ await this.delay(500);
68
+ for (let i = 1; i <= permitTime; i += 1) {
69
+ await this.delay(300);
70
+ this.log.info(`Progress at ${i}%`);
71
+ await progress.update({ value: i, label: `${i}%` });
72
+ }
73
+
74
+ await this.delay(1000);
75
+ await progress.close();
76
+
77
+ return { refresh: true };
78
+ }
79
+
80
+
81
+
82
+ async listDevices() {
83
+ const devices = await this.adapter.getDevicesAsync();
84
+ const arrDevices = [];
85
+ for (const i in devices) {
86
+ const status = {};
87
+
88
+ if (devices[i].common.type == 'group') continue;
89
+
90
+ const available = await this.adapter.getStateAsync(`${devices[i]._id}.available`);
91
+ if(available !== null && available !== undefined) {
92
+ status.connection = available.val ? 'connected' : 'disconnected';
93
+ }
94
+
95
+ const link_quality = await this.adapter.getStateAsync(`${devices[i]._id}.link_quality`);
96
+ if(link_quality) {
97
+ status.rssi = link_quality.val;
98
+ }
99
+
100
+ const battery = await this.adapter.getStateAsync(`${devices[i]._id}.battery`);
101
+ if(battery) {
102
+ status.battery = battery.val;
103
+ }
104
+
105
+ let hastDetails = false;
106
+ // Check if device has native.Sender_ID
107
+ if(devices[i].native.id) {
108
+ hastDetails = true;
109
+ }
110
+
111
+ const deviceInfo = await this.adapter.zbController.getDevice('0x'+devices[i].native.id);
112
+
113
+ const res = {
114
+ id: devices[i]._id,
115
+ name: devices[i].common.name,
116
+ icon: devices[i].common.icon ? '/adapter/zigbee/' + devices[i].common.icon : null,
117
+ manufacturer: `${deviceInfo._manufacturerName}` ,
118
+ model: `${deviceInfo._modelID}`,
119
+ status: status,
120
+ hasDetails: hastDetails,
121
+ actions: [
122
+ /* {
123
+ id: 'delete',
124
+ icon: 'fa-solid fa-trash-can',
125
+ description: {
126
+ en: 'Delete this device',
127
+ de: 'Gerät löschen',
128
+ ru: 'Удалить это устройство',
129
+ pt: 'Excluir este dispositivo',
130
+ nl: 'Verwijder dit apparaat',
131
+ fr: 'Supprimer cet appareil',
132
+ it: 'Elimina questo dispositivo',
133
+ es: 'Eliminar este dispositivo',
134
+ pl: 'Usuń to urządzenie',
135
+ 'zh-cn': '删除此设备',
136
+ uk: 'Видалити цей пристрій'
137
+ },
138
+ handler: this.handleDeleteDevice.bind(this)
139
+ },*/
140
+ {
141
+ id: 'rename',
142
+ icon: 'fa-solid fa-pen',
143
+ description: {
144
+ en: 'Rename this device',
145
+ de: 'Gerät umbenennen',
146
+ ru: 'Переименовать это устройство',
147
+ pt: 'Renomear este dispositivo',
148
+ nl: 'Hernoem dit apparaat',
149
+ fr: 'Renommer cet appareil',
150
+ it: 'Rinomina questo dispositivo',
151
+ es: 'Renombrar este dispositivo',
152
+ pl: 'Zmień nazwę tego urządzenia',
153
+ 'zh-cn': '重命名此设备',
154
+ uk: 'Перейменуйте цей пристрій'
155
+ },
156
+ handler: this.handleRenameDevice.bind(this)
157
+ }
158
+ ]
159
+ };
160
+ // if id contains gateway remove res.actions
161
+ if(devices[i]._id.includes('gateway')) {
162
+ res.actions = [];
163
+ }
164
+ arrDevices.push(res);
165
+ }
166
+ return arrDevices;
167
+ }
168
+
169
+ async getDeviceDetails(id, action, context) {
170
+ this.adapter.log.info('getDeviceDetails');
171
+ const devices = await this.adapter.getDevicesAsync();
172
+ const device = devices.find(d => d._id === id);
173
+ if(!device) {
174
+ return {error: 'Device not found'};
175
+ }
176
+ if(!device.native.id) {
177
+ return null;
178
+ }
179
+
180
+ const deviceInfo = await this.adapter.zbController.getDevice('0x'+ device.native.id);
181
+ const lastSeen = await this.formatDate(deviceInfo._lastSeen);
182
+
183
+ const items = {};
184
+
185
+ for (const devInfo in deviceInfo._endpoints[0].inputClusters) {
186
+
187
+ const val = deviceInfo._endpoints[0].inputClusters[devInfo];
188
+ const valType = typeof val;
189
+
190
+ if (valType != 'object') {
191
+ const item = {
192
+ ['inputCluster'+devInfo]: {
193
+ type: 'staticText',
194
+ text: `inputCluster ${devInfo} : ${val}`,
195
+ newLine: true,
196
+ },
197
+ };
198
+ Object.assign(items,item);
199
+ }
200
+
201
+ }
202
+
203
+ const data = {
204
+ id: deviceInfo._ieeeAddr,
205
+ schema: {
206
+ type: 'tabs',
207
+ items: {
208
+ _tab_Start: {
209
+ type: 'panel',
210
+ label: 'Main',
211
+
212
+ items: {
213
+ header_Start: {
214
+ type: 'header',
215
+ text: `${device.common.name} ${deviceInfo._ieeeAddr}`,
216
+ size: 3,
217
+ },
218
+ _link: {
219
+ label: `Manufacturer: ${deviceInfo._manufacturerName}`,
220
+ type: 'staticLink',
221
+ href: `https://www.zigbee2mqtt.io/supported-devices/#v=${deviceInfo._manufacturerName}`,
222
+ button: true,
223
+ },
224
+ _link2: {
225
+ label: `Model : ${device.common.type}`,
226
+ type: 'staticLink',
227
+ href: `https://www.zigbee2mqtt.io/devices/${device.common.type}.html`,
228
+ button: true,
229
+ },
230
+ _softwareBuildID: {
231
+ type: 'staticText',
232
+ text: `<b>Software Build Id:</b> ${deviceInfo._softwareBuildID}`,
233
+ style: {
234
+ fontSize: 14
235
+ }
236
+ },
237
+
238
+ _divider2: {
239
+ type: 'divider',
240
+ color: 'primary',
241
+ },
242
+ _interviewCompleted: {
243
+ type: 'checkbox',
244
+ label: `Interview completed`,
245
+ checked: deviceInfo._interviewCompleted == 1 ? 'true' : 'false',
246
+ disabled: 'true',
247
+ newLine: true,
248
+ },
249
+ _configure: {
250
+ type: 'checkbox',
251
+ label: 'is Configured',
252
+ help: 'if it possible',
253
+ checked: deviceInfo.meta.configured == 1 ? 'true' : 'false',
254
+ disabled: 'true',
255
+ },
256
+ _lastSeen: {
257
+ type: 'staticText',
258
+ text: `<b>Last seen:</b> ${lastSeen}`,
259
+ },
260
+ _manufacturerID: {
261
+ type: 'staticText',
262
+ text: `<b>Manufacturer Id:</b> ${deviceInfo._manufacturerID}`,
263
+ newLine: true,
264
+ },
265
+ _network: {
266
+ type: 'staticText',
267
+ text: `<b>Network address:</b> 0x${deviceInfo._networkAddress}`,
268
+ },
269
+ _type: {
270
+ type: 'staticText',
271
+ text: `<b>Device Type:</b> ${deviceInfo._type}`,
272
+ },
273
+ _powered: {
274
+ type: 'staticText',
275
+ text: deviceInfo._powerSource ? `<b>Power:</b> ${deviceInfo._powerSource.toUpperCase()}` : ``,
276
+ },
277
+ _maxListeners: {
278
+ type: 'staticText',
279
+ text: `<b>max Listeners:</b> ${deviceInfo._maxListeners}`,
280
+ },
281
+ },
282
+ },
283
+ _tab_Details: {
284
+ type: 'panel',
285
+ label: 'Details',
286
+ items,
287
+ },
288
+ },
289
+ },
290
+ };
291
+
292
+ return data;
293
+ }
294
+
295
+ async handleDeleteDevice(id, context) {
296
+ const devId = id.replace(/zigbee\.\d\./, '');
297
+ const deviceInfo = await this.adapter.zbController.getDevice('0x'+ devId);
298
+
299
+
300
+ const response = await context.showConfirmation({
301
+ en: `Do you really want to delete the device ${deviceInfo._ieeeAddr}?`,
302
+ de: `Möchten Sie das Gerät ${deviceInfo._ieeeAddr} wirklich löschen?`,
303
+ ru: `Вы действительно хотите удалить устройство ${deviceInfo._ieeeAddr}?`,
304
+ pt: `Você realmente deseja excluir o dispositivo ${deviceInfo._ieeeAddr}?`,
305
+ nl: `Weet u zeker dat u het apparaat ${deviceInfo._ieeeAddr} wilt verwijderen?`,
306
+ fr: `Voulez-vous vraiment supprimer l'appareil ${deviceInfo._ieeeAddr} ?`,
307
+ it: `Vuoi davvero eliminare il dispositivo ${deviceInfo._ieeeAddr}?`,
308
+ es: `¿Realmente desea eliminar el dispositivo ${deviceInfo._ieeeAddr}?`,
309
+ pl: `Czy na pewno chcesz usunąć urządzenie ${deviceInfo._ieeeAddr}?`,
310
+ 'zh-cn': `您真的要删除设备 ${deviceInfo._ieeeAddr} 吗?`,
311
+ uk: `Ви дійсно бажаєте видалити пристрій ${deviceInfo._ieeeAddr}?`
312
+ });
313
+
314
+
315
+ // delete device
316
+ if(response === false) {
317
+ return {refresh: false};
318
+ }
319
+ const res = await this.adapter.leaveDevice('0x'+ devId);
320
+
321
+ if (res !== null) {
322
+ this.adapter.log.info(`${devId} deleted`);
323
+ return {refresh: true};
324
+ } else {
325
+ this.adapter.log.error(`Can not delete device ${devId}: ${JSON.stringify(res)}`);
326
+ return {refresh: false};
327
+ }
328
+ }
329
+
330
+ async handleRenameDevice(id, context) {
331
+ const result = await context.showForm({
332
+ type : 'panel',
333
+ items: {
334
+ newName: {
335
+ type: 'text',
336
+ trim: false,
337
+ placeholder: '',
338
+ }
339
+ }}, {
340
+ data: {
341
+ newName: ''
342
+ },
343
+ title: {
344
+ en: 'Enter new name',
345
+ de: 'Neuen Namen eingeben',
346
+ ru: 'Введите новое имя',
347
+ pt: 'Digite um novo nome',
348
+ nl: 'Voer een nieuwe naam in',
349
+ fr: 'Entrez un nouveau nom',
350
+ it: 'Inserisci un nuovo nome',
351
+ es: 'Ingrese un nuevo nombre',
352
+ pl: 'Wpisz nowe imię',
353
+ 'zh-cn': '输入新名称',
354
+ uk: 'Введіть нове ім\'я'
355
+ }
356
+ });
357
+ if (result == undefined || result.newName == '') {
358
+ return {refresh: false};
359
+ }
360
+
361
+ const obj = {
362
+ common: {
363
+ name: result.newName
364
+ }
365
+ };
366
+ const res = await this.adapter.extendObjectAsync(id, obj);
367
+ this.adapter.log.info(JSON.stringify(res));
368
+ if (res === null) {
369
+ this.adapter.log.warn(`Can not rename device ${context.id}: ${JSON.stringify(res)}`);
370
+
371
+ }
372
+
373
+ return {refresh: true};
374
+ }
375
+
376
+ async formatDate(time, type) { //'ISO_8601' | 'ISO_8601_local' | 'epoch' | 'relative'
377
+ if (type === 'ISO_8601') return new Date(time).toISOString();
378
+ else if (type === 'ISO_8601_local') return this.toLocalISOString(new Date(time));
379
+ else if (type === 'epoch') return time;
380
+ else { // relative
381
+ const ago = humanizeDuration(Date.now() - time, {language: 'en', largest: 2, round: true}) + ' ago';
382
+ return ago;
383
+ }
384
+ }
385
+
386
+ toLocalISOString(d) {
387
+ const off = d.getTimezoneOffset();
388
+ return new Date(d.getFullYear(), d.getMonth(), d.getDate(), d.getHours(), d.getMinutes() - off, d.getSeconds(), d.getMilliseconds()).toISOString();
389
+ }
390
+
391
+ }
392
+
393
+ module.exports = dmZigbee;
package/lib/devices.js CHANGED
@@ -3041,6 +3041,10 @@ const devices = [
3041
3041
  },
3042
3042
 
3043
3043
  /* ------------ images only for admin ------------------- */
3044
+ {
3045
+ models: ['LED1923R5/LED1925G6'],
3046
+ icon: 'img/LED1923R5.png',
3047
+ },
3044
3048
  {
3045
3049
  models: ['E1812'],
3046
3050
  icon: 'img/ikea_E1812.png',
package/lib/exposes.js CHANGED
@@ -5,7 +5,7 @@ const statesDefs = require('./states.js').states;
5
5
  const rgb = require('./rgb.js');
6
6
  const utils = require('./utils.js');
7
7
  const colors = require('./colors.js');
8
- const ea = zigbeeHerdsmanConverters.exposes.access;
8
+ const ea = require('zigbee-herdsman-converters/lib/exposes.js').access;
9
9
 
10
10
  function genState(expose, role, name, desc) {
11
11
  let state;
@@ -8,7 +8,7 @@ const fs = require('fs');
8
8
  const request = require('request');
9
9
 
10
10
  let savedDeviceNames = {};
11
- let knownUndefinedDevices = {};
11
+ const knownUndefinedDevices = {};
12
12
 
13
13
  class StatesController extends EventEmitter {
14
14
  constructor(adapter) {
@@ -138,7 +138,7 @@ class StatesController extends EventEmitter {
138
138
  const result = {};
139
139
  // find model states for options and get it values
140
140
  const devStates = await this.getDevStates('0x' + devId, model);
141
- if (devStates == null || devStates == undefined) {
141
+ if (devStates == null || devStates == undefined || devStates.states == null || devStates.states == undefined) {
142
142
  callback(result);
143
143
  return;
144
144
  }
package/lib/utils.js CHANGED
@@ -108,7 +108,7 @@ function flatten(arr) {
108
108
 
109
109
  const forceEndDevice = flatten(
110
110
  ['QBKG03LM', 'QBKG04LM', 'ZNMS13LM', 'ZNMS12LM']
111
- .map(model => zigbeeHerdsmanConverters.devices.find((d) => d.model === model))
111
+ .map(model => zigbeeHerdsmanConverters.findByModel(model))
112
112
  .map(mappedModel => mappedModel.zigbeeModel));
113
113
 
114
114
  // Xiaomi uses 4151 and 4447 (lumi.plug) as manufacturer ID.
@@ -7,11 +7,11 @@ const utils = require('./utils');
7
7
  // Some EndDevices should be pinged
8
8
  // e.g. E11-G13 https://github.com/Koenkk/zigbee2mqtt/issues/775#issuecomment-453683846
9
9
  const forcedPingable = [
10
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'E11-G13'),
11
- zigbeeHerdsmanConverters.devices.find((d) => d.model === '53170161'),
12
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'V3-BTZB'),
13
- zigbeeHerdsmanConverters.devices.find((d) => d.model === 'SPZB0001'),
14
- zigbeeHerdsmanConverters.devices.find((d) => d.model === '014G2461')
10
+ zigbeeHerdsmanConverters.findByModel('E11-G13'),
11
+ zigbeeHerdsmanConverters.findByModel('53170161'),
12
+ zigbeeHerdsmanConverters.findByModel('V3-BTZB'),
13
+ zigbeeHerdsmanConverters.findByModel('SPZB0001'),
14
+ zigbeeHerdsmanConverters.findByModel('014G2461')
15
15
  ];
16
16
 
17
17
  // asgothian: 29.12.2020: Removed color and color_temp from readable
@@ -4,10 +4,10 @@ const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters');
4
4
  const BaseExtension = require('./zbBaseExtension');
5
5
 
6
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')
7
+ zigbeeHerdsmanConverters.findByModel('V3-BTZB'),
8
+ zigbeeHerdsmanConverters.findByModel('014G2461'),
9
+ zigbeeHerdsmanConverters.findByModel('SPZB0001'),
10
+ zigbeeHerdsmanConverters.findByModel('ZK03840')
11
11
  ];
12
12
 
13
13
  class DeviceConfigure extends BaseExtension {
@@ -130,13 +130,15 @@ class DeviceConfigure extends BaseExtension {
130
130
  }
131
131
 
132
132
  async doConfigure(device, mappedDevice) {
133
- this.info(`Configuring ${device.ieeeAddr} ${device.modelID}`);
134
133
  const coordinatorEndpoint = await this.zigbee.getDevicesByType('Coordinator')[0].endpoints[0];
135
134
  try {
136
- await mappedDevice.configure(device, coordinatorEndpoint, this);
137
- device.meta.configured = zigbeeHerdsmanConverters.getConfigureKey(mappedDevice);
138
- device.save();
139
- this.info(`DeviceConfigure successful ${device.ieeeAddr} ${device.modelID}`);
135
+ if (mappedDevice !== undefined) {
136
+ this.info(`Configuring ${device.ieeeAddr} ${device.modelID}`);
137
+ await mappedDevice.configure(device, coordinatorEndpoint, this);
138
+ device.meta.configured = zigbeeHerdsmanConverters.getConfigureKey(mappedDevice);
139
+ device.save();
140
+ this.info(`DeviceConfigure successful ${device.ieeeAddr} ${device.modelID}`);
141
+ }
140
142
  } catch (error) {
141
143
  this.sendError(error);
142
144
  this.error(