Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Error/Bug
  4. Blockly Skripte korrupt ("Cannot extract Blockly code!")

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.3k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.4k

Blockly Skripte korrupt ("Cannot extract Blockly code!")

Geplant Angeheftet Gesperrt Verschoben Error/Bug
4 Beiträge 2 Kommentatoren 344 Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • D Offline
    D Offline
    Dan_Ce
    schrieb am zuletzt editiert von
    #1

    Hallo zusammen,

    Bei meinen Skripts erhalte ich aktuell die Fehlermeldung "Cannot extract Blockly code"

    Hier ein Beispiel-Skript, welches betroffen ist:

    /* -- do not edit following lines - START --
    {
      "expert": true,
      "engineType": "Blockly",
      "debug": false,
      "verbose": false
    }
    -- do not edit previous lines - END --*/
    var Waschmaschine_Dauerzaehler, Waschmaschine_aktiv, timeout_Waschmaschine, Dauerzaehler, timeout_WaMa_Meldung, timeout_WaMa_Dauerzaehler, WZ_HUE_E27_1_XY, WZ_HUE_E27_2_XY, WZ_HUE_E27_1_On_Off, WZ_HUE_E27_2_On_Off;
    
    
    Waschmaschine_Dauerzaehler = 0;
    Waschmaschine_aktiv = false;
    setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, false);
    on({id: [].concat(['sonoff.0.Tasmota10.ENERGY_Power']), change: "ne"}, async function (obj) {
      var value = obj.state.val;
      var oldValue = obj.oldState.val;
      if ((obj.state ? obj.state.val : "") >= 400 && Waschmaschine_aktiv == false) {
        setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, true);
        Waschmaschine_aktiv = true;
        setState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart"/*Waschstart*/, getState("sonoff.0.Tasmota10.ENERGY_Total").val);
        Dauerzaehler = setInterval(async function () {
          Waschmaschine_Dauerzaehler = (typeof Waschmaschine_Dauerzaehler == 'number' ? Waschmaschine_Dauerzaehler : 0) + 1;
        }, 60000);
        (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
        // Kommentar
      } else if ((obj.state ? obj.state.val : "") >= 2.7 && (obj.state ? obj.state.val : "") < 400) {
        (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
      } else if ((obj.state ? obj.state.val : "") < 2.7 && Waschmaschine_aktiv == true) {
        // Kommentar
        timeout_Waschmaschine = setTimeout(async function () {
          Waschmaschine_aktiv = false;
          setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, false);
          (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
          (function () {if (Dauerzaehler) {clearInterval(Dauerzaehler); Dauerzaehler = null;}})();
          setState("javascript.0.Energieueberwachung.Waschmaschine.Waschende"/*Waschende*/, getState("sonoff.0.Tasmota10.ENERGY_Total").val);
          timeout_WaMa_Meldung = setTimeout(async function () {
            if (Waschmaschine_Dauerzaehler >= 2) {
              sendTo("email", "send", {
                 text: (['Die Waschmaschine ist fertig',formatDate(new Date(), "\n"),'Dauer: ',Waschmaschine_Dauerzaehler,' Minuten',formatDate(new Date(), "\n"),'Verbrauch: ',Math.round((parseFloat(getState("javascript.0.Energieueberwachung.Waschmaschine.Waschende").val) - getState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart").val)*100)/100,' kWh'].join('')),
                 to: 'xyz123@gmail.com',
                 subject: 'ioBroker: Waschmaschine ist fertig',
                 from: 'Waschmaschine'
              });
              sendTo("telegram", "send", {
                  text: (['Die Waschmaschine ist fertig',formatDate(new Date(), "\n"),'Dauer: ',Waschmaschine_Dauerzaehler,' Minuten',formatDate(new Date(), "\n"),'Verbrauch: ',Math.round((parseFloat(getState("javascript.0.Energieueberwachung.Waschmaschine.Waschende").val) - getState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart").val)*100)/100,' kWh',''].join(''))
              });
              WZ_HUE_E27_1_XY = getState("deconz.0.Lights.12.xy").val;
              WZ_HUE_E27_2_XY = getState("deconz.0.Lights.13.xy").val;
              WZ_HUE_E27_1_On_Off = getState("deconz.0.Lights.12.on").val;
              WZ_HUE_E27_2_On_Off = getState("deconz.0.Lights.13.on").val;
              setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 1, false);
              setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 450, false);
              setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 900, false);
              setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 1450, false);
              setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 1900, false);
              setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 2350, false);
              setStateDelayed("deconz.0.Lights.12.xy"/*HUE-E27-WZ1 xy*/, WZ_HUE_E27_1_XY, 2800, false);
              setStateDelayed("deconz.0.Lights.13.xy"/*Hue-e27-wz2 xy*/, WZ_HUE_E27_2_XY, 2800, false);
              setStateDelayed("deconz.0.Lights.12.on"/*HUE-E27-WZ1 on*/, WZ_HUE_E27_1_On_Off, 2850, false);
              setStateDelayed("deconz.0.Lights.13.on"/*Hue-e27-wz2 on*/, WZ_HUE_E27_1_On_Off, 2850, false);
            }
          }, 5000);
          timeout_WaMa_Dauerzaehler = setTimeout(async function () {
            Waschmaschine_Dauerzaehler = 0;
          }, 10000);
        }, 180000);
      }
    });
    
    //JTNDe.........
    

    Irgendwie habe ich den Versand über SendTo in Verdacht, ein neues Blockly bietet mir nicht mehr die Möglichkeiten wie in früheren Versionen:
    sendto.JPG

    Meister MopperM 1 Antwort Letzte Antwort
    0
    • D Dan_Ce

      Hallo zusammen,

      Bei meinen Skripts erhalte ich aktuell die Fehlermeldung "Cannot extract Blockly code"

      Hier ein Beispiel-Skript, welches betroffen ist:

      /* -- do not edit following lines - START --
      {
        "expert": true,
        "engineType": "Blockly",
        "debug": false,
        "verbose": false
      }
      -- do not edit previous lines - END --*/
      var Waschmaschine_Dauerzaehler, Waschmaschine_aktiv, timeout_Waschmaschine, Dauerzaehler, timeout_WaMa_Meldung, timeout_WaMa_Dauerzaehler, WZ_HUE_E27_1_XY, WZ_HUE_E27_2_XY, WZ_HUE_E27_1_On_Off, WZ_HUE_E27_2_On_Off;
      
      
      Waschmaschine_Dauerzaehler = 0;
      Waschmaschine_aktiv = false;
      setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, false);
      on({id: [].concat(['sonoff.0.Tasmota10.ENERGY_Power']), change: "ne"}, async function (obj) {
        var value = obj.state.val;
        var oldValue = obj.oldState.val;
        if ((obj.state ? obj.state.val : "") >= 400 && Waschmaschine_aktiv == false) {
          setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, true);
          Waschmaschine_aktiv = true;
          setState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart"/*Waschstart*/, getState("sonoff.0.Tasmota10.ENERGY_Total").val);
          Dauerzaehler = setInterval(async function () {
            Waschmaschine_Dauerzaehler = (typeof Waschmaschine_Dauerzaehler == 'number' ? Waschmaschine_Dauerzaehler : 0) + 1;
          }, 60000);
          (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
          // Kommentar
        } else if ((obj.state ? obj.state.val : "") >= 2.7 && (obj.state ? obj.state.val : "") < 400) {
          (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
        } else if ((obj.state ? obj.state.val : "") < 2.7 && Waschmaschine_aktiv == true) {
          // Kommentar
          timeout_Waschmaschine = setTimeout(async function () {
            Waschmaschine_aktiv = false;
            setState("0_userdata.0.Waschmaschine.Waschmaschine_laeuft"/*Waschmaschine_laeuft*/, false);
            (function () {if (timeout_Waschmaschine) {clearTimeout(timeout_Waschmaschine); timeout_Waschmaschine = null;}})();
            (function () {if (Dauerzaehler) {clearInterval(Dauerzaehler); Dauerzaehler = null;}})();
            setState("javascript.0.Energieueberwachung.Waschmaschine.Waschende"/*Waschende*/, getState("sonoff.0.Tasmota10.ENERGY_Total").val);
            timeout_WaMa_Meldung = setTimeout(async function () {
              if (Waschmaschine_Dauerzaehler >= 2) {
                sendTo("email", "send", {
                   text: (['Die Waschmaschine ist fertig',formatDate(new Date(), "\n"),'Dauer: ',Waschmaschine_Dauerzaehler,' Minuten',formatDate(new Date(), "\n"),'Verbrauch: ',Math.round((parseFloat(getState("javascript.0.Energieueberwachung.Waschmaschine.Waschende").val) - getState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart").val)*100)/100,' kWh'].join('')),
                   to: 'xyz123@gmail.com',
                   subject: 'ioBroker: Waschmaschine ist fertig',
                   from: 'Waschmaschine'
                });
                sendTo("telegram", "send", {
                    text: (['Die Waschmaschine ist fertig',formatDate(new Date(), "\n"),'Dauer: ',Waschmaschine_Dauerzaehler,' Minuten',formatDate(new Date(), "\n"),'Verbrauch: ',Math.round((parseFloat(getState("javascript.0.Energieueberwachung.Waschmaschine.Waschende").val) - getState("javascript.0.Energieueberwachung.Waschmaschine.Waschstart").val)*100)/100,' kWh',''].join(''))
                });
                WZ_HUE_E27_1_XY = getState("deconz.0.Lights.12.xy").val;
                WZ_HUE_E27_2_XY = getState("deconz.0.Lights.13.xy").val;
                WZ_HUE_E27_1_On_Off = getState("deconz.0.Lights.12.on").val;
                WZ_HUE_E27_2_On_Off = getState("deconz.0.Lights.13.on").val;
                setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 1, false);
                setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 450, false);
                setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 900, false);
                setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 1450, false);
                setStateDelayed("deconz.0.Groups.19.Scene_6.recall"/*recall*/, true, 1900, false);
                setStateDelayed("deconz.0.Groups.19.Scene_5.recall"/*recall*/, true, 2350, false);
                setStateDelayed("deconz.0.Lights.12.xy"/*HUE-E27-WZ1 xy*/, WZ_HUE_E27_1_XY, 2800, false);
                setStateDelayed("deconz.0.Lights.13.xy"/*Hue-e27-wz2 xy*/, WZ_HUE_E27_2_XY, 2800, false);
                setStateDelayed("deconz.0.Lights.12.on"/*HUE-E27-WZ1 on*/, WZ_HUE_E27_1_On_Off, 2850, false);
                setStateDelayed("deconz.0.Lights.13.on"/*Hue-e27-wz2 on*/, WZ_HUE_E27_1_On_Off, 2850, false);
              }
            }, 5000);
            timeout_WaMa_Dauerzaehler = setTimeout(async function () {
              Waschmaschine_Dauerzaehler = 0;
            }, 10000);
          }, 180000);
        }
      });
      
      //JTNDe.........
      

      Irgendwie habe ich den Versand über SendTo in Verdacht, ein neues Blockly bietet mir nicht mehr die Möglichkeiten wie in früheren Versionen:
      sendto.JPG

      Meister MopperM Abwesend
      Meister MopperM Abwesend
      Meister Mopper
      schrieb am zuletzt editiert von
      #2

      @dan_ce

      Ja, es müssen alle Adapter, die das Skript nutzt, installiert sein, sonst kommt es zu diesen Fehlermeldungen.

      Proxmox und HA

      D 2 Antworten Letzte Antwort
      0
      • Meister MopperM Meister Mopper

        @dan_ce

        Ja, es müssen alle Adapter, die das Skript nutzt, installiert sein, sonst kommt es zu diesen Fehlermeldungen.

        D Offline
        D Offline
        Dan_Ce
        schrieb am zuletzt editiert von
        #3

        @meister-mopper Das ist der Fall. Telegram allerdings in Instanz 1 anstatt 0. Die Skripte liefen aber immer einwandfrei.

        1 Antwort Letzte Antwort
        0
        • Meister MopperM Meister Mopper

          @dan_ce

          Ja, es müssen alle Adapter, die das Skript nutzt, installiert sein, sonst kommt es zu diesen Fehlermeldungen.

          D Offline
          D Offline
          Dan_Ce
          schrieb am zuletzt editiert von
          #4

          @meister-mopper
          Ich konnte das Problem lösen: Ich habe bei allen Adaptern, die ich in meinen Skripten bei SendTo verwende um eine Instanz erweitert. (Telegram, Email, Awtrix). Dann waren die SendTo-Blöcke bei neuen Skripten wieder auswählbar und in den bestehenden Skripten sind die Fehler weg. Danach konnte ich die neuen Instanzen wieder löschen und es funktioniert weiterhin.
          Ob das jetzt ein Bug der betroffenen Adapter war oder an meinem System liegt, vermag ich nicht zu sagen.

          1 Antwort Letzte Antwort
          0
          Antworten
          • In einem neuen Thema antworten
          Anmelden zum Antworten
          • Älteste zuerst
          • Neuste zuerst
          • Meiste Stimmen


          Support us

          ioBroker
          Community Adapters
          Donate

          678

          Online

          32.4k

          Benutzer

          81.6k

          Themen

          1.3m

          Beiträge
          Community
          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
          ioBroker Community 2014-2025
          logo
          • Anmelden

          • Du hast noch kein Konto? Registrieren

          • Anmelden oder registrieren, um zu suchen
          • Erster Beitrag
            Letzter Beitrag
          0
          • Home
          • Aktuell
          • Tags
          • Ungelesen 0
          • Kategorien
          • Unreplied
          • Beliebt
          • GitHub
          • Docu
          • Hilfe