NEWS
[Gelöst] Javascript schreibt nicht in Datenpunkt
-
Ich habe folgendes Javasrcript. Leider wird das Objekt bzw. der Datenpunkt nicht aktualiert. In der Console wird true ausgegeben… im Backend steht aber false. Was mache ich falsch?
! ````
const request = require('request');
const parser = require('xml2js').parseString;
! createState('Dreambox_OG_Standby_Status', false, {
"type": "object",
"role": "state",
"read": true,
"write": true
});
! function getDB500Status(xml) {
parser(xml, function (err, result) {
if(err) log('Fehler XML-Parsen: ' + err, 'error');
else {
var stateDB = result.e2powerstate.e2instandby;
setState('Dreambox_OG_Standby_Status', stateDB, true);
console.log(stateDB);
//console.log(obj.e2powerstate);
}
});
}
function getXML() {
request('http://root:********@192.168.178.210/web/powerstate', function (error, response, body) {
if (error) log("Fehler beim Herunterladen: " + error, 'error');
else getDB500Status(body);
});
}
getXML(); -
Probier mal 'Dreambox_OG_Standby_Status' auf 'javascript.0.Dreambox_OG_Standby_Status' zu ersetzen..
Wieso machst du "type" = "object" und schreibst dabei boolean?
Mach type=boolean (Das hat aber mit deinem Fehler wenig zu tun. Einfach Feng Shui)
-
Geschrieben wir wieder nichts Bin neu auf dem Gebiet. Es erscheint ein Warning:
! javascript.0 2018-05-07 22:09:16.176 warn at Parser. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/parser.js:303:18)
! javascript.0 2018-05-07 22:09:16.176 warn at script.js.common.Dreambox_OG.Standby_Status_DB_OG:17:9
! javascript.0 2018-05-07 22:09:16.156 warn Wrong type of javascript.0.Dreambox_OG_Standby_Status: "object". Please fix, while deprecated and will not work in next versions.
! javascript.0 2018-05-07 22:09:15.834 info script.js.common.Dreambox_OG.Standby_Status_DB_OG: registered 0 subscriptions and 0 schedules
! javascript.0 2018-05-07 22:09:15.820 info Start javascript script.js.common.Dreambox_OG.Standby_Status_DB_OG
! javascript.0 2018-05-07 22:09:15.801 info Stop script script.js.common.Dreambox_OG.Standby_Status_DB_OG
! javascript.0 2018-05-07 22:09:05.156 info script.js.common.Dreambox_OG.Standby_Status_DB_OG: true -
> setState('Dreambox_OG_Standby_Status', stateDB, true);
nimm mal da das true raus.
Das gehört da glaub ich nicht hin.
setState('Dreambox_OG_Standby_Status', stateDB);
MfG
dna909
-
Kein Ahnung was ich falsch mache. Wenn ich diese Zeile ändere, z.b. in "Test" ändere, schreibt er den Wert.
var stateDB = "Test";
Wenn ich den Befehl im Log aussgebe:````
console.log(result.e2powerstate.e2instandby)Wenn ich es wie folgt mache, wird der Wert nicht übernommen:
var stateDB = result.e2powerstate.e2instandby;
Wo ist der Fehler?
-
ist jetzt nicht dein ernst oder…
var stateDB = getState('result.e2powerstate.e2instandby').val;
-
ist jetzt nicht dein ernst oder…
var stateDB = getState('result.e2powerstate.e2instandby').val; ```` `
Doch, ich bin da leider nicht erfahren. Allerdings kommt bei deinem Vorschlag folgende Meldung
"getState "result.e2powerstate.e2instandby" not found (3)"
Es geht auch hier darum, daß zuerst eine XML ausgelesen wird und dann der Wert in den Datenpunkt geschrieben werden soll.
-
Doch, ich bin da leider nicht erfahren. Allerdings kommt bei deinem Vorschlag folgende Meldung
"getState "result.e2powerstate.e2instandby" not found (3)" `
Das macht schon Sinn wie du es hattest. result.e2powerstate.e2instandby ist eine Variable in deinem ausgelesenen Objekt und kein State in ioBroker.
> Wrong type of javascript.0.Dreambox_OG_Standby_Status: "object"
bedeutet aber, dass du nicht wie von Bluefox empfohlen den State mit Typ "boolean" (wahr/falsch) erstellst, sondern mit "object". Änder das erst mal und probiers dann nochmal. -
Offenbar enthält die Variable result.e2powerstate.e2instandby ein Objekt. Was ergibt ?
log(JSON.stringify(result.e2powerstate.e2instandby));
-
Offenbar enthält die Variable result.e2powerstate.e2instandby ein Objekt. Was ergibt ?
log(JSON.stringify(result.e2powerstate.e2instandby)); ```` `
javascript.0 script.js.common.Dreambox_OG.Standby_Status_DB_OG: ["true"]
-
Das ist ein Array mit einem Element. Was ergibt ?
log(result.e2powerstate.e2instandby[0] + ' ' + typeof result.e2powerstate.e2instandby[0]);
-
Das ist ein Array mit einem Element. Was ergibt ?
log(result.e2powerstate.e2instandby[0] + ' ' + typeof result.e2powerstate.e2instandby[0]); ```` `
Das ergibt:
! javascript.0 script.js.common.Dreambox_OG.Standby_Status_DB_OG: false string
Wenn ich es so mache, scheint es zu gehen:
stateDB = JSON.parse(result.e2powerstate.e2instandby);
Ist das okay?
Kann ich ein Javascript via Blockly starten / stoppen?
-
var stateDB = JSON.parse(result.e2powerstate.e2instandby);
Ist das okay? `
Ja. -
Prima! Kann als gelöst markiert werden.
PS. Wenn noch jemand eine Antwort hat, ob ich ein Scirpt per Blockly starten kann, bin ich happy.
-
Ja, das geht.
Gibt einen Datenpunkt zu deinem Script der heißt etwas mit „script.enabled“.
Z.B.
Denn kannst du über eine Blockly per Cron z.B. Für 2-3 Sekunden auf „true“ setzen.
Das````
[Gelöst] -
Hier mein Script um die Dreambox (Enigma2) den Standby Status abzufragen:
! const request = require('request');
! const parser = require('xml2js').parseString;
! createState('javascript.0.Dreambox_OG_Standby_Status', false, {
! read: true,
! write: true,
! desc: "DB500 Standby Status",
! type: "object",
! def: false
! });
! function getDB500Status(xml) {
! parser(xml, function (err, result) {
! if(err) log('Fehler XML-Parsen: ' + err, 'error');
! else {
! var stateDB;
! stateDB = JSON.parse(result.e2powerstate.e2instandby);
! setState('javascript.0.Dreambox_OG_Standby_Status', stateDB);
! console.log(JSON.parse(result.e2powerstate.e2instandby));
! }
! });
! }
! function getXML() {
! request('http://root:%2A%2A%2A%2A%2A%2A%2A%2A@192.168.178.220:88/web/powerstate', function (error, response, body) {
! if (error) log("Fehler beim Herunterladen: " + error, 'error');
! else getDB500Status(body);
! });
! }
! schedule('* * * * *', getXML); // jede Minute -
Danke fürs teilen!
-
createState('javascript.0.Dreambox_OG_Standby_Status', false, {
read: true,
write: true,
desc: "DB500 Standby Status",
type: "object",
def: false
}); `
Der Datenpunkt-Typ ist falsch !createState('javascript.0.Dreambox_OG_Standby_Status', false, { read: true, write: true, desc: "DB500 Standby Status", type: "boolean", def: false });