Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Gelöst] Javascript schreibt nicht in Datenpunkt

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Gelöst] Javascript schreibt nicht in Datenpunkt

    This topic has been deleted. Only users with topic management privileges can see it.
    • L
      LJSven last edited by

      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();

      1 Reply Last reply Reply Quote 0
      • Bluefox
        Bluefox last edited by

        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)

        1 Reply Last reply Reply Quote 0
        • L
          LJSven last edited by

          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

          1 Reply Last reply Reply Quote 0
          • D
            dna909 last edited by

            > 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

            1 Reply Last reply Reply Quote 0
            • L
              LJSven last edited by

              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?
              1 Reply Last reply Reply Quote 0
              • arteck
                arteck Developer Most Active last edited by

                ist jetzt nicht dein ernst oder…

                var stateDB = getState('result.e2powerstate.e2instandby').val;
                
                1 Reply Last reply Reply Quote 0
                • L
                  LJSven last edited by

                  @arteck:

                  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.

                  1 Reply Last reply Reply Quote 0
                  • AlCalzone
                    AlCalzone Developer last edited by

                    @LJSven:

                    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.

                    1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 last edited by

                      Offenbar enthält die Variable result.e2powerstate.e2instandby ein Objekt. Was ergibt ?

                      log(JSON.stringify(result.e2powerstate.e2instandby));
                      
                      1 Reply Last reply Reply Quote 0
                      • L
                        LJSven last edited by

                        @paul53:

                        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"]

                        1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 last edited by

                          Das ist ein Array mit einem Element. Was ergibt ?

                          log(result.e2powerstate.e2instandby[0] + ' ' + typeof result.e2powerstate.e2instandby[0]);
                          
                          1 Reply Last reply Reply Quote 0
                          • L
                            LJSven last edited by

                            @paul53:

                            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?

                            1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 last edited by

                              @LJSven:

                              var stateDB = JSON.parse(result.e2powerstate.e2instandby);
                              

                              Ist das okay? `
                              Ja.

                              1 Reply Last reply Reply Quote 0
                              • L
                                LJSven last edited by

                                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.

                                1 Reply Last reply Reply Quote 0
                                • wendy2702
                                  wendy2702 last edited by

                                  Ja, das geht.

                                  Gibt einen Datenpunkt zu deinem Script der heißt etwas mit „script.enabled“.

                                  Z.B.

                                  999_f84ea20d-0854-45b7-a64f-ced5c1869903.jpeg

                                  Denn kannst du über eine Blockly per Cron z.B. Für 2-3 Sekunden auf „true“ setzen.

                                  Das````
                                  [Gelöst]

                                  1 Reply Last reply Reply Quote 0
                                  • L
                                    LJSven last edited by

                                    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

                                    1 Reply Last reply Reply Quote 0
                                    • wendy2702
                                      wendy2702 last edited by

                                      Danke fürs teilen!

                                      1 Reply Last reply Reply Quote 0
                                      • paul53
                                        paul53 last edited by

                                        @LJSven:

                                        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
                                        });
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • First post
                                          Last post

                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        769
                                        Online

                                        32.0k
                                        Users

                                        80.3k
                                        Topics

                                        1.3m
                                        Posts

                                        7
                                        18
                                        1312
                                        Loading More Posts
                                        • Oldest to Newest
                                        • Newest to Oldest
                                        • Most Votes
                                        Reply
                                        • Reply as topic
                                        Log in to reply
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                        The ioBroker Community 2014-2023
                                        logo