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

Issue 329 tic #330

Open
wants to merge 12 commits into
base: master
Choose a base branch
from
3 changes: 2 additions & 1 deletion admin/i18n/de/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "JSON-Format für EFR SmartGridHub",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Standard Protokoll/Übertragung",
"value_transport_HttpRequestTransport": "Daten von einer HTTP-URL auslesen",
"value_transport_LocalFileTransport": "Daten aus einer lokalen Datei lesen",
"value_transport_SerialRequestResponseTransport": "Serielles Gerät mit bidir. Komm.",
"value_transport_SerialResponseTransport": "Serielle Daten werden nur gelesen",
"value_transport_TCPTransport": "Netzwerk/TCP-Daten werden nur gelesen"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/en/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "JSON-Format for EFR SmartGridHub",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protocol-/Transport-Default",
"value_transport_HttpRequestTransport": "Read data from an HTTP URL",
"value_transport_LocalFileTransport": "Read data from a local file",
"value_transport_SerialRequestResponseTransport": "Serial device with Bi-dir. comm.",
"value_transport_SerialResponseTransport": "Serial device reading data only",
"value_transport_TCPTransport": "TCP device reading data only"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/es/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (despertar, inicio de sesión, datos)",
"value_protocol_JsonEfrProtocol": "EFR SmartGridHub en formato JSON",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protocolo / transporte predeterminado",
"value_transport_HttpRequestTransport": "Leer datos de una URL HTTP",
"value_transport_LocalFileTransport": "Leer datos de un archivo local",
"value_transport_SerialRequestResponseTransport": "Dispositivo serie con Bi-dir. ",
"value_transport_SerialResponseTransport": "Solo datos de lectura del dispositivo serie",
"value_transport_TCPTransport": "Solo datos de lectura del dispositivo TCP"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/fr/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, données)",
"value_protocol_JsonEfrProtocol": "SmartGridHub EFR au format JSON",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protocol- / Transport-Default",
"value_transport_HttpRequestTransport": "Lire les données à partir d'une URL HTTP",
"value_transport_LocalFileTransport": "Lire les données à partir d'un fichier local",
"value_transport_SerialRequestResponseTransport": "Périphérique série avec Bi-dir. ",
"value_transport_SerialResponseTransport": "Périphérique série lisant uniquement les données",
"value_transport_TCPTransport": "Périphérique TCP lisant uniquement les données"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/it/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "Formato JSON EFR SmartGridHub",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Predefinito protocollo / trasporto",
"value_transport_HttpRequestTransport": "Leggi i dati da un URL HTTP",
"value_transport_LocalFileTransport": "Leggi i dati da un file locale",
"value_transport_SerialRequestResponseTransport": "Dispositivo seriale con Bi-dir. ",
"value_transport_SerialResponseTransport": "Solo dati di lettura del dispositivo seriale",
"value_transport_TCPTransport": "Solo lettura dei dati del dispositivo TCP"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/nl/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "EFR SmartGridHub in JSON-indeling",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protocol- / transportstandaard",
"value_transport_HttpRequestTransport": "Lees gegevens van een HTTP-URL",
"value_transport_LocalFileTransport": "Lees gegevens uit een lokaal bestand",
"value_transport_SerialRequestResponseTransport": "Serieel apparaat met Bi-dir. ",
"value_transport_SerialResponseTransport": "Alleen seriële apparaten lezen gegevens",
"value_transport_TCPTransport": "Alleen TCP-apparaat leest gegevens"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/pl/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "Format JSON EFR SmartGridHub",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protokół- / Transport-Default",
"value_transport_HttpRequestTransport": "Odczytaj dane z adresu URL HTTP",
"value_transport_LocalFileTransport": "Odczytaj dane z pliku lokalnego",
"value_transport_SerialRequestResponseTransport": "Urządzenie szeregowe z Bi-reż. ",
"value_transport_SerialResponseTransport": "Urządzenie szeregowe odczytuje tylko dane",
"value_transport_TCPTransport": "TCP Urządzenie odczytuje tylko dane"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/pt/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (WakeUp, SignOn, Data)",
"value_protocol_JsonEfrProtocol": "Formato JSON EFR SmartGridHub",
"value_protocol_SmlProtocol": "Smart Message Language 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Protocolo- / Transporte-Padrão",
"value_transport_HttpRequestTransport": "Ler dados de um URL HTTP",
"value_transport_LocalFileTransport": "Ler dados de um arquivo local",
"value_transport_SerialRequestResponseTransport": "Dispositivo serial com Bi-dir. ",
"value_transport_SerialResponseTransport": "Dados de leitura do dispositivo serial apenas",
"value_transport_TCPTransport": "Dados de leitura do dispositivo TCP apenas"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/ru/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0 (пробуждение, вход, данные)",
"value_protocol_JsonEfrProtocol": "JSON-формат EFR SmartGridHub",
"value_protocol_SmlProtocol": "Язык умных сообщений 1.0.3/1.0.4",
"value_protocol_TicProtocol": "Télé-Information Client",
"value_protocol_default": "Протокол / Транспорт по умолчанию",
"value_transport_HttpRequestTransport": "Чтение данных из URL-адреса HTTP",
"value_transport_LocalFileTransport": "Чтение данных из локального файла",
"value_transport_SerialRequestResponseTransport": "Последовательное устройство с Bi-dir. ",
"value_transport_SerialResponseTransport": "Только данные чтения последовательного устройства",
"value_transport_TCPTransport": "Только данные устройства TCP для чтения"
}
}
3 changes: 2 additions & 1 deletion admin/i18n/zh-cn/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,11 @@
"value_protocol_D0Protocol": "D0(唤醒,登录,数据)",
"value_protocol_JsonEfrProtocol": "JSON格式的EFR SmartGridHub",
"value_protocol_SmlProtocol": "智能消息语言1.0.3",
"value_protocol_TicProtocol": "客户电话信息",
"value_protocol_default": "协议/传输默认",
"value_transport_HttpRequestTransport": "从HTTP URL读取数据",
"value_transport_LocalFileTransport": "从本地文件读取数据",
"value_transport_SerialRequestResponseTransport": "具有双向目录的串行设备。",
"value_transport_SerialResponseTransport": "串行设备仅读取数据",
"value_transport_TCPTransport": "TCP设备仅读取数据"
}
}
1 change: 1 addition & 0 deletions admin/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -286,6 +286,7 @@
<option class="translate" value="D0Protocol">value_protocol_D0Protocol</option>
<option class="translate" value="JsonEfrProtocol">value_protocol_JsonEfrProtocol</option>
<option class="translate" value="SmlProtocol">value_protocol_SmlProtocol</option>
<option class="translate" value="TicProtocol">value_protocol_TicProtocol</option>
</select>
</td>
<td>
Expand Down
1 change: 1 addition & 0 deletions admin/words.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

152 changes: 152 additions & 0 deletions lib/obiscollector.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,152 @@
// Thought about making this a class, but... meh.

'use strict';

const SmartmeterObis = require('smartmeter-obis');

let adapter;
let setConnected;
let stopInProgress = false;
const smValues = {};

function init(adapterIn, setConnectedIn, smOptions) {
adapter = adapterIn;

setConnected = setConnectedIn;
const smTransport = SmartmeterObis.init(smOptions, storeObisData);

return {
process: () => {
smTransport.process()
},
stop: () => {
stopInProgress = true;
}
};
}

async function storeObisData(err, obisResult) {
if (stopInProgress) return;
if (err) {
adapter.log.warn(err.message);
adapter.log.debug(err);
setConnected(false);
return;
}
setConnected(true);
let updateCount = 0;
for (const obisId in obisResult) {
if (!obisResult.hasOwnProperty(obisId)) continue;

adapter.log.debug(obisResult[obisId].idToString() + ': ' + SmartmeterObis.ObisNames.resolveObisName(obisResult[obisId], adapter.config.obisNameLanguage).obisName + ' = ' + obisResult[obisId].valueToString());
let i;
let ioChannelId = obisResult[obisId].idToString().replace(/[\]\[*,;'"`<>\\?]/g, '__');
ioChannelId = ioChannelId.replace(/\./g, '_');
if (!smValues[obisId]) {
let ioChannelName = SmartmeterObis.ObisNames.resolveObisName(obisResult[obisId], adapter.config.obisNameLanguage).obisName;
adapter.log.debug('Create Channel ' + ioChannelId + ' with name ' + ioChannelName);
try {
await adapter.setObjectNotExistsAsync(ioChannelId, {
type: 'channel',
common: {
name: ioChannelName
},
native: {}
});
} catch (err) {
adapter.log.error('Error creating Channel: ' + err);
}

if (obisResult[obisId].getRawValue() !== undefined) {
adapter.log.debug('Create State ' + ioChannelId + '.rawvalue');
try {
await adapter.setObjectNotExistsAsync(ioChannelId + '.rawvalue', {
type: 'state',
common: {
name: ioChannelId + '.rawvalue',
type: 'string',
read: true,
role: 'value',
write: false
},
native: {
id: ioChannelId + '.rawvalue'
}
});
} catch (err) {
adapter.log.error('Error creating State: ' + err);
}
}

adapter.log.debug('Create State ' + ioChannelId + '.value');
try {
await adapter.setObjectNotExistsAsync(ioChannelId + '.value', {
type: 'state',
common: {
name: ioChannelId + '.value',
type: (typeof obisResult[obisId].getValue(0).value),
read: true,
unit: obisResult[obisId].getValue(0).unit,
role: 'value',
write: false
},
native: {
id: ioChannelId + '.value'
}
});
} catch (err) {
adapter.log.error('Error creating State: ' + err);
}

if (obisResult[obisId].getValueLength() > 1) {
for (i = 1; i < obisResult[obisId].getValueLength(); i++) {
adapter.log.debug('Create State ' + ioChannelId + '.value' + (i + 1));
try {
await adapter.setObjectNotExistsAsync(ioChannelId + '.value' + (i + 1), {
type: 'state',
common: {
name: ioChannelId + '.value' + (i + 1),
type: (typeof obisResult[obisId].getValue(i).value),
read: true,
unit: obisResult[obisId].getValue(i).unit,
role: 'value',
write: false
},
native: {
id: ioChannelId + '.value' + (i + 1)
}
});
} catch (err) {
adapter.log.error('Error creating State: ' + err);
}
}
}
}
if (!smValues[obisId] || smValues[obisId].valueToString() !== obisResult[obisId].valueToString()) {
if (obisResult[obisId].getRawValue() !== undefined) {
adapter.log.debug('Set State ' + ioChannelId + '.rawvalue = ' + obisResult[obisId].getRawValue());
await adapter.setStateAsync(ioChannelId + '.rawvalue', { ack: true, val: obisResult[obisId].getRawValue() });
}

adapter.log.debug('Set State ' + ioChannelId + '.value = ' + obisResult[obisId].getValue(0).value);
await adapter.setStateAsync(ioChannelId + '.value', { ack: true, val: obisResult[obisId].getValue(0).value });

if (obisResult[obisId].getValueLength() > 1) {
for (i = 1; i < obisResult[obisId].getValueLength(); i++) {
adapter.log.debug('Set State ' + ioChannelId + '.value' + (i + 1) + ' = ' + obisResult[obisId].getValue(i).value);
await adapter.setStateAsync(ioChannelId + '.value' + (i + 1), { ack: true, val: obisResult[obisId].getValue(i).value });
}
}
smValues[obisId] = obisResult[obisId];
updateCount++;
}
else {
adapter.log.debug('Data for ' + ioChannelId + ' unchanged');
}
}
adapter.log.info('Received ' + Object.keys(obisResult).length + ' values, ' + updateCount + ' updated');
}

module.exports = {
init: init
}
Loading
Loading