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. Skripten / Logik
  4. JavaScript
  5. [Skript] Namespace für Datenpunkte in Skripten abändern

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.5k

[Skript] Namespace für Datenpunkte in Skripten abändern

Geplant Angeheftet Gesperrt Verschoben JavaScript
82 Beiträge 6 Kommentatoren 8.3k Aufrufe 9 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.
  • F fastfoot

    @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

    kannst/willst du das abfangen ?

    ändere in Zeile 36 zu if(obj && obj.type === 'script' && obj.common.source){

    Der neue JS-Adapter erzeugt auch bei leeren Skripten einen obj.common.source, so dass mir das nicht aufgefallen ist. Erinnerst du dich was im Objekt gefehlt hatte? Ich habe zum Testen das source Attribut entfernt, bekam aber eine andere Fehlermeldung als du, so dass icht ganz sicher bin ob der Fehler gefixt ist, evtl. hat auch das kmpl. common bei dir gefehlt

    liv-in-skyL Offline
    liv-in-skyL Offline
    liv-in-sky
    schrieb am zuletzt editiert von
    #44

    @fastfoot
    und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

    irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

    F 1 Antwort Letzte Antwort
    0
    • liv-in-skyL liv-in-sky

      @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

      Der neue JS-Adapter erzeugt auch bei leeren Skripten einen obj.common.source, so dass mir das nicht aufgefallen ist. Erinnerst du dich was im Objekt gefehlt hatte? Ich habe zum Testen das source Attribut entfernt, bekam aber eine andere Fehlermeldung als du, so dass icht ganz sicher bin ob der Fehler gefixt ist, evtl. hat auch das kmpl. common bei dir gefehlt

      weiß ich leider nicht - habe das log angesehen, dass script gecheckt, welches als letztes angezeigt wurde und das "leere" gelöscht

      noch ne frage - habe die beiden scripte (im log), die leer waren gelöscht - alle js-instanzen neugestartet und bekomme nun dieses warning

      Image 11.png

      das problem dabei, in script_enabled werden die datenpunkte nicht gelöscht. nur in der eigentlichen instanz wird der dp gelöscht - in den anderen beiden bleibt dieser dp enthalten - man sollte also auf jeden fall alle script_enabled-ordner aller instanzen löschen bovor das script läuft - evtl in der anleitung als pflicht angeben ?

      F Offline
      F Offline
      fastfoot
      schrieb am zuletzt editiert von
      #45

      @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

      das problem dabei, in script_enabled werden die datenpunkte nicht gelöscht. nur in der eigentlichen instanz wird der dp gelöscht - in den anderen beiden bleibt dieser dp enthalten - man sollte also auf jeden fall alle script_enabled-ordner aller instanzen löschen bovor das script läuft - evtl in der anleitung als pflicht angeben ?

      eigentlich sollte der Fehler nicht auftauchen, da in Zeile 32 auf die Existenz des Objekts geprüft wird. Zusätzlich wird, falls existent, auch die Instanz der scriptID mit der tatsächlichen verglichen und nur bei Gleichheit weitergemacht. Theoretisch sollte also egal sein was in scriptEnabled steht. DA hilft nur die beiden Skripte zu prüfen,

      iobroker läuft unter Docker auf QNAP TS-451+
      SkriptRecovery: https://forum.iobroker.net/post/930558

      liv-in-skyL 1 Antwort Letzte Antwort
      0
      • liv-in-skyL liv-in-sky

        @fastfoot
        und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

        irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

        F Offline
        F Offline
        fastfoot
        schrieb am zuletzt editiert von
        #46

        @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

        @fastfoot
        und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

        irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

        das ist richtig, du kannst aber auch die Datei im Filesystem nutzen und erstmal von Hand importieren, es werden nur Dateien geschrieben welche auch eine Änderung haben(also oldNamespace beinhalten). Müsstest du im Pfad von pathToRestore finden, vorher löschen damit nur diese Datei drinne ist. Für ein Schreiben ins System empfehle ich mit Endung Chg, dann wird ein neues Skript angelegt und das alte bleibt erhalten!

        iobroker läuft unter Docker auf QNAP TS-451+
        SkriptRecovery: https://forum.iobroker.net/post/930558

        liv-in-skyL 1 Antwort Letzte Antwort
        0
        • F fastfoot

          @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

          das problem dabei, in script_enabled werden die datenpunkte nicht gelöscht. nur in der eigentlichen instanz wird der dp gelöscht - in den anderen beiden bleibt dieser dp enthalten - man sollte also auf jeden fall alle script_enabled-ordner aller instanzen löschen bovor das script läuft - evtl in der anleitung als pflicht angeben ?

          eigentlich sollte der Fehler nicht auftauchen, da in Zeile 32 auf die Existenz des Objekts geprüft wird. Zusätzlich wird, falls existent, auch die Instanz der scriptID mit der tatsächlichen verglichen und nur bei Gleichheit weitergemacht. Theoretisch sollte also egal sein was in scriptEnabled steht. DA hilft nur die beiden Skripte zu prüfen,

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          schrieb am zuletzt editiert von
          #47

          @fastfoot

          da kann ich nix prüfen - die scripte sind gelöscht - habe die dp aus script_enabled von hand gelöscht - dann sind warnungen weg

          habe mal ein "großes" blockly konvertiert und ins filesystem geschrieben - kann man ohne fehler importieren :-)

          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

          F 1 Antwort Letzte Antwort
          0
          • F fastfoot

            @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

            @fastfoot
            und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

            irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

            das ist richtig, du kannst aber auch die Datei im Filesystem nutzen und erstmal von Hand importieren, es werden nur Dateien geschrieben welche auch eine Änderung haben(also oldNamespace beinhalten). Müsstest du im Pfad von pathToRestore finden, vorher löschen damit nur diese Datei drinne ist. Für ein Schreiben ins System empfehle ich mit Endung Chg, dann wird ein neues Skript angelegt und das alte bleibt erhalten!

            liv-in-skyL Offline
            liv-in-skyL Offline
            liv-in-sky
            schrieb am zuletzt editiert von
            #48

            @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

            @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

            @fastfoot
            und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

            irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

            das ist richtig, du kannst aber auch die Datei im Filesystem nutzen und erstmal von Hand importieren, es werden nur Dateien geschrieben welche auch eine Änderung haben(also oldNamespace beinhalten). Müsstest du im Pfad von pathToRestore finden, vorher löschen damit nur diese Datei drinne ist. Für ein Schreiben ins System empfehle ich mit Endung Chg, dann wird ein neues Skript angelegt und das alte bleibt erhalten!

            bedeutet: ich hätte dann 1500 scripte - statt 750

            nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

            F 1 Antwort Letzte Antwort
            0
            • liv-in-skyL liv-in-sky

              @fastfoot

              da kann ich nix prüfen - die scripte sind gelöscht - habe die dp aus script_enabled von hand gelöscht - dann sind warnungen weg

              habe mal ein "großes" blockly konvertiert und ins filesystem geschrieben - kann man ohne fehler importieren :-)

              F Offline
              F Offline
              fastfoot
              schrieb am zuletzt editiert von
              #49

              @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

              da kann ich nix prüfen - die scripte sind gelöscht - habe die dp aus script_enabled von hand gelöscht - dann sind warnungen weg

              aber genau das dürfte nicht passieren, da ja auf die Existenz eines Objektes zuerst geprüft wird. Evtl. habe ich da einen Denkfehler. Die Id ist xxxx.scriptEnabled.DeletedScript. Daraus wird script.js.DeletedScript und dann wird auf existsObject('script.js.DeletedScript') geprüft.

              Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

              iobroker läuft unter Docker auf QNAP TS-451+
              SkriptRecovery: https://forum.iobroker.net/post/930558

              liv-in-skyL 1 Antwort Letzte Antwort
              0
              • liv-in-skyL liv-in-sky

                @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                @fastfoot
                und noch ne frage - zur sicherheit - wenn ich "scriptIds" so auswähle, dass ich nur ein script "erwische", wird doch nur ein script ins system geschrieben und der rest bleibt oder ist der rest gefährdet (natürlich mit proxmox backup !)

                irgendwie muss ich ja mal richtig testen - möchte aber nicht alles auf einmal ändern - ist zuviel

                das ist richtig, du kannst aber auch die Datei im Filesystem nutzen und erstmal von Hand importieren, es werden nur Dateien geschrieben welche auch eine Änderung haben(also oldNamespace beinhalten). Müsstest du im Pfad von pathToRestore finden, vorher löschen damit nur diese Datei drinne ist. Für ein Schreiben ins System empfehle ich mit Endung Chg, dann wird ein neues Skript angelegt und das alte bleibt erhalten!

                bedeutet: ich hätte dann 1500 scripte - statt 750

                F Offline
                F Offline
                fastfoot
                schrieb am zuletzt editiert von
                #50

                @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                bedeutet: ich hätte dann 1500 scripte - statt 750

                jein, wenn du erstmal zum Test auf ein einziges Skript beschränkst, sind es nur 751 :-)

                iobroker läuft unter Docker auf QNAP TS-451+
                SkriptRecovery: https://forum.iobroker.net/post/930558

                1 Antwort Letzte Antwort
                1
                • F fastfoot

                  @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                  da kann ich nix prüfen - die scripte sind gelöscht - habe die dp aus script_enabled von hand gelöscht - dann sind warnungen weg

                  aber genau das dürfte nicht passieren, da ja auf die Existenz eines Objektes zuerst geprüft wird. Evtl. habe ich da einen Denkfehler. Die Id ist xxxx.scriptEnabled.DeletedScript. Daraus wird script.js.DeletedScript und dann wird auf existsObject('script.js.DeletedScript') geprüft.

                  Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

                  liv-in-skyL Offline
                  liv-in-skyL Offline
                  liv-in-sky
                  schrieb am zuletzt editiert von
                  #51

                  @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                  Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

                  daher habe ich js-instanzen neugestartet

                  nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                  F 1 Antwort Letzte Antwort
                  0
                  • liv-in-skyL liv-in-sky

                    @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                    Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

                    daher habe ich js-instanzen neugestartet

                    F Offline
                    F Offline
                    fastfoot
                    schrieb am zuletzt editiert von
                    #52

                    @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                    @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                    Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

                    daher habe ich js-instanzen neugestartet

                    ich kann es nicht nachvollziehen. in ScriptEnabled noch vorhanden aber tatsächlich gelöscht. Das Skript arbeitet da bei mir sauber.

                    Vlt stelle ich doch noch auf Mirrorpfad um :-)

                    iobroker läuft unter Docker auf QNAP TS-451+
                    SkriptRecovery: https://forum.iobroker.net/post/930558

                    liv-in-skyL 1 Antwort Letzte Antwort
                    0
                    • F fastfoot

                      Schon länger sind User angehalten, für ihre eigenen Datenpunkte den Namespace 0_userdata.0 zu verwenden. Mit Einführung von Admin 5 wird das auch mehr forciert und es wird so langsam Zeit 'umzuziehen', sprich, wer eigene Datenpunkte z.B. unter MeineDatenpunkte.0 angelegt hat sollte diese nun unter 0_userdata.0 anlegen. Da sich evtl. viele Skripte angesammelt haben, welche auf die alten DP Bezug nehmen und es sehr mühsam ist alle Skripte händisch anzupassen ist dieses Skript entstanden. Auch wer nicht konvertieren will oder muss kann so eine komplette Übersicht über seine Skripte erhalten.
                      Was kann das Skript?

                      • Auflistung aller Skripte mit Name und Pfad, Beschreibung(wenn Header gepflegt wird), Instanz, Typ, Anzahl der erforderlichen Änderungen, Status(läuft/läuft nicht)
                        • Die Darstellung erfolgt durch einen mit JSON Daten gefüllten DP und einem JSON Widget von inventwo. Der dazu notwendige DP muss händisch angelegt werden!
                      • Schreiben von notwendigen Änderungen als Datei in das Dateisystem, bei Blockly-Skripten als xml-Export. Unterstützt werden Javascript, Blockly und Typescript.
                        • Diese Option ist einstellbar über writeToFileSystem (Default = true) und pathToRestore (Default = /opt/iobroker/switched)
                      • Direktes Ändern der Skripte im System.
                        • Auf Wunsch (und aus Sicherheitsgründen enpfohlen!!!) wird an den Skriptnamen die Endung Chg angehängt, hierbei wird dann eine Kopie erstellt und das Original bleibt erhalten. Ist die Endung auf '' gesetzt, wird das Original überschrieben.
                        • Aktive Skripte werden nicht ins System übernommen.
                        • Diese Option ist einstellbar über replaceInSystemsDB (Default = false) und extChanged (Default = Chg)
                      • Einstellungen für das Verhalten des Skriptes erfolgen in den Zeilen 11-15

                      Was das Skript nicht kann:

                      • Notwendige Änderungen in der VIS müssen händisch erfolgen.
                      • Die neuen Datenpunkte unter 0_userdata.0 sollten/müssen vor dem Neustart der Skripte natürlich schon vorhanden sein(Export Objekstruktur => Ersetzen alter Namespace mit neuem Namespace => Import unter 0_userdata.0)

                      Unzulänglichkeiten:

                      • Skripte, welche javascript.x.scriptEnabled zum Ein- und Auschalten von Skripten verwenden, werden evtl. nicht richtig/vollständig konvertiert
                      • Skripte welche setState(myDP, wert) ohne Namespace verwenden(d.h. der State wird automatisch in javascript.instance.myDP geschrieben) werden nicht korrekt konvertiert

                      Ich hoffe dass das Skript bei einer anstehenden Konvertierung hilfreich sein wird. Evtl. Korrekturen und Verbesserungen werden in diesem Beitrag gepostet

                      /**
                      * Zweck:           Ändert Namespace von Datenpunkten in Skripten
                      * Datum:           20.08.2021
                      * Author:          @fastfoot
                      * Forum:           https://forum.iobroker.net/topic/47113/skript-namespace-f%C3%BCr-datenpunkte-in-skripten-abändern
                      */
                      let dbg = false;                        // Zusatzausgaben fürs Debugging
                      const newNamespace = '0_userdata.0';      //neuer Namespace für DP
                      
                      //          Eigene Einstellungen
                      const oldNamespace = 'oldNamespace.0';       //Ordner für Namespace welcher ersetzt wird
                      const replaceInSystemsDB = false;// lädt geänderte Dateien sofort ins System(ACHTUNG! *** auf eigenes Risiko ***)
                      const writeToFileSystem = true;// Geänderte Dateien ins Filesystem schreiben
                      const pathToRestore = '/opt/iobroker/switched/'; // <=== Pfad eintragen mit abschliessendem /
                      const extChanged = 'Chg';   // Wird im Falle einer Änderung an ID und Name angehangen
                      
                      let changes = 0; // Zählt Änderungen in einem Skript
                      let changesResult = []; // Zussammenfassung der Ergebnisse, wird in DP geschrieben
                      
                      function switchDPs(){
                         if(oldNamespace === newNamespace) return;
                         if(!checkPath()) return;
                         let scriptNo = 0;
                         const scriptIds = $('javascript.*.scriptEnabled.*');        //NICHT abändern!!!
                         scriptIds.each(scriptSearchId => {
                             //if(dbg) log(scriptSearchId);
                             let isRunning = getState(scriptSearchId).val ? 'Ja' : 'Nein';
                             let scripPath = scriptSearchId.split('.').slice(3).join('.');
                             let searchInstance = scriptSearchId.split('.')[1];
                             let scriptId = 'script.js.' + scripPath;
                             let scriptIdNew = scriptId + extChanged;
                             let obj = getObject(scriptId);
                             let data = '';
                             let Zweck = ' ';
                             changes = 0;
                             if(obj && obj.type === 'script' && obj.common.source){
                                 //if(dbg) log(obj.common.name);
                                 let arr = obj.common.engine.split('.');
                                 let Instance = arr[arr.length - 1];
                                 if (searchInstance != Instance) return;
                                 scriptNo++;
                                 let fn = scripPath; // obj.common.name;
                                 let ext = '';
                                 let sourceNew = '';
                                 //obj.common.name += extChanged;
                                 switch(obj.common.engineType.toLowerCase()){
                                     case 'blockly':
                                         ext = '.xml';
                                         if(/(Zweck|Purpose):\s+(.*)/.test(obj.common.source)){
                                             Zweck = /(Zweck|Purpose):\s+(.*)/.exec(obj.common.source)[2];
                                         }
                                         let result = convertBlockly(obj.common.source);
                                         sourceNew = result.source;
                                         data = result.xml;
                                         //if(dbg) log(result.xml)
                                         break;
                                     case 'javascript/js':
                                         ext = '.js';
                                         sourceNew = obj.common.source;
                                         if(/(Zweck|Purpose):\s+(.*)/.test(sourceNew)){
                                             Zweck = /(Zweck|Purpose):\s+(.*)/.exec(sourceNew)[2];
                                         }
                                         while(sourceNew.indexOf(oldNamespace) >= 0 && sourceNew.indexOf('.scriptEnabled.') == -1){
                                             changes++;
                                             sourceNew = sourceNew.replace(oldNamespace, newNamespace)
                                         }
                                         data = sourceNew;
                                         break;
                                     case 'typescript/ts':
                                         ext = '.ts';
                                         sourceNew = obj.common.source;
                                         while(sourceNew.indexOf(oldNamespace) >= 0 && sourceNew.indexOf('.scriptEnabled.') == -1){
                                             changes++;
                                             sourceNew = sourceNew.replace(oldNamespace, newNamespace)
                                         }
                                         data = sourceNew;
                                         break;
                                     default:
                                         ext = 'undef';
                                 }
                                 if(isRunning === 'Nein' && replaceInSystemsDB && changes > 0){
                                     obj.common.name += extChanged;
                                     obj.common.source = sourceNew;
                                     setObject(scriptId + extChanged, obj);
                                 }
                                 if(writeToFileSystem && changes > 0){
                                     fn += extChanged + ext;
                                     let fnOut = pathToRestore + fn;
                                     //if(dbg) log(fnOut);
                                     require('fs').writeFile(fnOut, data, e => {
                                         if(e) log('Fehler beim Schreiben der Datei: ' + e);
                                     })
                                 }
                                 if(changes >= 0){
                                     changesResult.push({
                                         Nr: scriptNo,
                                         Skript: fn,
                                         Zweck: Zweck,
                                         Instance: Instance,
                                         Type: obj.common.engineType,
                                         Changes: changes,
                                         isRunning: isRunning
                                     })
                                 }
                             }
                         })
                         require('fs').writeFile(pathToRestore + 'scriptsFound.json', JSON.stringify(changesResult,null,4),e =>{
                             if(e) log('Fehle beim Schreiben von Datei: ' + e);
                         })
                         changesResult.sort((a,b) => a.Skript.localeCompare(b.Skript));
                         scriptNo = 1;
                         changesResult.forEach(obj => {
                             obj.Nr = scriptNo++;
                         })
                         if(existsState('0_userdata.0.scriptCheck')){
                             setState('0_userdata.0.scriptCheck', JSON.stringify(changesResult));
                         } else{
                             log('Der DP 0_userdata.0.scriptCheck muss händisch angelegt werden!', 'error')
                         }
                      }
                      /**
                      * konvertiere Blockly Sourcecode
                      * @param {string} source - base64 codierter Source
                      * @returns {object} konvertierte Daten
                      */
                      function convertBlockly(source){
                         let regex = new RegExp(oldNamespace, "g");
                         let blocklyHeaderTmp = source.split('\n')
                         blocklyHeaderTmp.pop();
                         let blocklyHeader = blocklyHeaderTmp.join('\n').replace(regex, newNamespace) + '\n//'; 
                         const pos = source.lastIndexOf('\n');
                         if (pos !== -1) {
                             let base64Str = source.substring(pos + 3);
                             if(base64Str.indexOf('JTNDeG1sJTIweG1') > -1) {
                                 let xml = decodeURIComponent(Buffer.from(base64Str, 'base64').toString('utf8'));
                                 let xmlNew = convertJsFunction(xml);
                                 //if(dbg) log(xml);
                                 while(xmlNew.indexOf(oldNamespace) >= 0 && xmlNew.indexOf('.scriptEnabled.') == -1){
                                     changes++;
                                     xmlNew = xmlNew.replace(oldNamespace, newNamespace)
                                 }
                                 let sourceNew = blocklyHeader + Buffer.from(encodeURIComponent(xmlNew)).toString('base64');
                                 //if(dbg) log(sourceNew);
                                 return {source: sourceNew, xml: prettifyXml(xmlNew), changed: changes > 0};
                             }
                         }
                      }
                      /**
                      * konvertiere Blockly JS-Funktion
                      * @param {string} xml - blockly xml
                      * @returns {string} konvertierte Daten
                      */
                      function convertJsFunction(xml) {
                         let b64 = new RegExp(/(?:"SCRIPT">)([^<]+)(?:<\/field>)/g);
                         let m;
                         while ((m = b64.exec(xml)) !== null) {
                             if (m.index === b64.lastIndex) b64.lastIndex++;
                             let fnc = Buffer.from(m[1], 'base64').toString();
                             while(fnc.indexOf(oldNamespace) >= 0){
                                 changes++;
                                 fnc = fnc.replace(oldNamespace, newNamespace);
                             }
                             fnc = Buffer.from(fnc).toString('base64');
                             xml = xml.replace(m[1],fnc);
                         }
                         return xml;
                      }
                      
                      //from Stackoverflow
                      function prettifyXml(xml){
                         var reg = /(>)\s*(<)(\/*)/g;
                         xml = xml.replace(/\r|\n/g, ''); //deleting already existing whitespaces
                         xml = xml.replace(reg, '$1\r\n$2$3');
                         return xml;
                      }
                      
                      function checkPath(){
                         if(pathToRestore.lastIndexOf('/') != pathToRestore.length -1){
                             log('Der Pfad in pathToRestore muss mit einem Slash(/) abschliessen!','error');
                             return false;
                         }
                         if(!require('fs').existsSync(pathToRestore)){
                             log('Der Pfad in pathToRestore(' + pathToRestore +') existiert nicht!','error');
                             return false;
                         }
                         return true
                      }
                      
                      switchDPs();
                      
                      



                      {
                      "settings": {
                      "style": {
                      "background_class": ""
                      },
                      "theme": "redmond",
                      "sizex": "",
                      "sizey": "",
                      "gridSize": "10",
                      "snapType": 2
                      },
                      "widgets": {
                      "e00001": {
                      "tpl": "i-vis-jsontable",
                      "data": {
                      "g_fixed": false,
                      "g_visibility": false,
                      "g_css_font_text": false,
                      "g_css_background": false,
                      "g_css_shadow_padding": false,
                      "g_css_border": false,
                      "g_gestures": false,
                      "g_signals": false,
                      "g_last_change": false,
                      "visibility-cond": "==",
                      "visibility-val": 1,
                      "visibility-groups-action": "hide",
                      "iTblRowLimit": "500",
                      "iTableRefreshRate": "0",
                      "iColCount": "7",
                      "iColShow1": "true",
                      "iTblTextAlign1": "center",
                      "iTblCellFormat1": "normal",
                      "iTblCellImageSize1": "200",
                      "iTblCellBooleanCheckbox1": "false",
                      "iTblCellBooleanColorFalse1": "#ff0000",
                      "iTblCellBooleanColorTrue1": "#00ff00",
                      "iTblCellNumberDecimals1": "2",
                      "iTblCellNumberDecimalSeperator1": ".",
                      "iTblCellNumberThousandSeperator1": ",",
                      "iTblCellThresholdsDp1": "",
                      "iTblCellThresholdsText1": "",
                      "iOpacityAll": "1",
                      "iTblRowEvenColor": "#333333",
                      "iTblRowUnevenColor": "#455618",
                      "iTblHeaderColor": "#333333",
                      "iRowSpacing": "10",
                      "iTblRowEvenTextColor": "#ffffff",
                      "iTblRowUnevenTextColor": "#ffffff",
                      "iTblHeaderTextColor": "#ffffff",
                      "iBorderSize": "1",
                      "iBorderStyleLeft": "solid",
                      "iBorderStyleRight": "solid",
                      "iBorderStyleUp": "solid",
                      "iBorderStyleDown": "solid",
                      "iBorderColor": "#ffffff",
                      "signals-cond-0": "==",
                      "signals-val-0": true,
                      "signals-icon-0": "/vis/signals/lowbattery.png",
                      "signals-icon-size-0": 0,
                      "signals-blink-0": false,
                      "signals-horz-0": 0,
                      "signals-vert-0": 0,
                      "signals-hide-edit-0": false,
                      "signals-cond-1": "==",
                      "signals-val-1": true,
                      "signals-icon-1": "/vis/signals/lowbattery.png",
                      "signals-icon-size-1": 0,
                      "signals-blink-1": false,
                      "signals-horz-1": 0,
                      "signals-vert-1": 0,
                      "signals-hide-edit-1": false,
                      "signals-cond-2": "==",
                      "signals-val-2": true,
                      "signals-icon-2": "/vis/signals/lowbattery.png",
                      "signals-icon-size-2": 0,
                      "signals-blink-2": false,
                      "signals-horz-2": 0,
                      "signals-vert-2": 0,
                      "signals-hide-edit-2": false,
                      "lc-type": "last-change",
                      "lc-is-interval": true,
                      "lc-is-moment": false,
                      "lc-format": "",
                      "lc-position-vert": "top",
                      "lc-position-horz": "right",
                      "lc-offset-vert": 0,
                      "lc-offset-horz": 0,
                      "lc-font-size": "12px",
                      "lc-font-family": "",
                      "lc-font-style": "",
                      "lc-bkg-color": "",
                      "lc-color": "",
                      "lc-border-width": "0",
                      "lc-border-style": "",
                      "lc-border-color": "",
                      "lc-border-radius": 10,
                      "lc-zindex": 0,
                      "oid": "0_userdata.0.scriptCheck",
                      "iTblShowHead": true,
                      "iTblFixedHead": true,
                      "iVertScroll": true,
                      "iColShow2": "true",
                      "iTblTextAlign2": "left",
                      "iTblCellFormat2": "normal",
                      "iTblCellImageSize2": "200",
                      "iTblCellBooleanCheckbox2": "false",
                      "iTblCellBooleanColorFalse2": "#ff0000",
                      "iTblCellBooleanColorTrue2": "#00ff00",
                      "iTblCellNumberDecimals2": "2",
                      "iTblCellNumberDecimalSeperator2": ".",
                      "iTblCellNumberThousandSeperator2": ",",
                      "iTblCellThresholdsDp2": "",
                      "iTblCellThresholdsText2": "",
                      "iColShow3": "true",
                      "iTblTextAlign3": "left",
                      "iTblCellFormat3": "normal",
                      "iTblCellImageSize3": "200",
                      "iTblCellBooleanCheckbox3": "false",
                      "iTblCellBooleanColorFalse3": "#ff0000",
                      "iTblCellBooleanColorTrue3": "#00ff00",
                      "iTblCellNumberDecimals3": "2",
                      "iTblCellNumberDecimalSeperator3": ".",
                      "iTblCellNumberThousandSeperator3": ",",
                      "iTblCellThresholdsDp3": "",
                      "iTblCellThresholdsText3": "",
                      "iBorderRemoveDouble": true,
                      "iColShow4": "true",
                      "iTblTextAlign4": "center",
                      "iTblCellFormat4": "normal",
                      "iTblCellImageSize4": "200",
                      "iTblCellBooleanCheckbox4": "false",
                      "iTblCellBooleanColorFalse4": "#ff0000",
                      "iTblCellBooleanColorTrue4": "#00ff00",
                      "iTblCellNumberDecimals4": "2",
                      "iTblCellNumberDecimalSeperator4": ".",
                      "iTblCellNumberThousandSeperator4": ",",
                      "iTblCellThresholdsDp4": "",
                      "iTblCellThresholdsText4": "",
                      "iColShow5": "true",
                      "iTblTextAlign5": "left",
                      "iTblCellFormat5": "normal",
                      "iTblCellImageSize5": "200",
                      "iTblCellBooleanCheckbox5": "false",
                      "iTblCellBooleanColorFalse5": "#ff0000",
                      "iTblCellBooleanColorTrue5": "#00ff00",
                      "iTblCellNumberDecimals5": "2",
                      "iTblCellNumberDecimalSeperator5": ".",
                      "iTblCellNumberThousandSeperator5": ",",
                      "iTblCellThresholdsDp5": "",
                      "iTblCellThresholdsText5": "",
                      "iColShow6": "true",
                      "iTblTextAlign6": "right",
                      "iTblCellFormat6": "normal",
                      "iTblCellImageSize6": "200",
                      "iTblCellBooleanCheckbox6": true,
                      "iTblCellBooleanColorFalse6": "#ff0000",
                      "iTblCellBooleanColorTrue6": "#00ff00",
                      "iTblCellNumberDecimals6": "2",
                      "iTblCellNumberDecimalSeperator6": ".",
                      "iTblCellNumberThousandSeperator6": ",",
                      "iTblCellThresholdsDp6": "",
                      "iTblCellThresholdsText6": "",
                      "iColShow7": "true",
                      "iTblTextAlign7": "center",
                      "iTblCellFormat7": "normal",
                      "iTblCellImageSize7": "200",
                      "iTblCellBooleanCheckbox7": "false",
                      "iTblCellBooleanColorFalse7": "#ff0000",
                      "iTblCellBooleanColorTrue7": "#00ff00",
                      "iTblCellNumberDecimals7": "2",
                      "iTblCellNumberDecimalSeperator7": ".",
                      "iTblCellNumberThousandSeperator7": ",",
                      "iTblCellThresholdsDp7": "",
                      "iTblCellThresholdsText7": ""
                      },
                      "style": {
                      "left": "10px",
                      "top": "59px",
                      "height": "716px",
                      "width": "1273px"
                      },
                      "widgetSet": "vis-inventwo"
                      }
                      },
                      "name": "scriptCheck",
                      "filterList": []
                      }

                      SwitchDP.PNG

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      schrieb am zuletzt editiert von
                      #53

                      @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                      Direktes Ändern der Skripte im System.

                      Auf Wunsch (und aus Sicherheitsgründen enpfohlen!!!) wird an den Skriptnamen die Endung Chg angehängt, hierbei wird dann eine Kopie erstellt und das Original bleibt erhalten. Ist die Endung auf '' gesetzt, wird das Original überschrieben.
                      Aktive Skripte werden nicht ins System übernommen.
                      Diese Option ist einstellbar über replaceInSystemsDB (Default = false) und extChanged (Default = Chg)

                      moin @fastfoot

                      hätte noch ein paar fragen

                      bitte bedenke die große anzahl meiner scripte

                      • wie kann ich aktiv laufende scripte konvertieren - was gibt es da für ein problem? könnten wir evtl über eine eigene javascript-instanz für das script nehmen und die anderen instanzen deaktivieren - es ist einfach zu viel, alle aktiven scripte "von hand" zu importieren
                      • das .chg als endung: könnten wir das auch ausschalten - ich hätte ja 750 scripte zu löschen

                      da ich proxmox habe ist das mit dem backup und restore ziemlich schnell erledigt - ich wollte jetzt einfach mal dein script auf alles anwenden und mich überraschen lassen. so wie es momentan ist, ist die nacharbeit zu viel

                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                      F 1 Antwort Letzte Antwort
                      0
                      • F fastfoot

                        @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                        @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                        Ich versuche das mal nachzustellen, evtl. spielt da auch der Buffer von iobroker einen Streich

                        daher habe ich js-instanzen neugestartet

                        ich kann es nicht nachvollziehen. in ScriptEnabled noch vorhanden aber tatsächlich gelöscht. Das Skript arbeitet da bei mir sauber.

                        Vlt stelle ich doch noch auf Mirrorpfad um :-)

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        schrieb am zuletzt editiert von
                        #54

                        @fastfoot ich hoffe ich kapier das überhaupt alles richtig

                        theoretisch müßte man doch die scripte gleich in das object schreiben bzw überschreiben können - falls das nicht geht, wäre es möglich die "running" scripte nicht mit pfad im namen zu schreiben, sondern in eine verzeichnisstruktur, die dem mirror pfad entspricht - dann sollte man doch die file-struktur ins mirror kopieren können - ich weiß dann aber nicht, ob das running bleibt, wenn das script einfach in den mirror geschrieben wird

                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                        F 1 Antwort Letzte Antwort
                        0
                        • liv-in-skyL liv-in-sky

                          @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                          Direktes Ändern der Skripte im System.

                          Auf Wunsch (und aus Sicherheitsgründen enpfohlen!!!) wird an den Skriptnamen die Endung Chg angehängt, hierbei wird dann eine Kopie erstellt und das Original bleibt erhalten. Ist die Endung auf '' gesetzt, wird das Original überschrieben.
                          Aktive Skripte werden nicht ins System übernommen.
                          Diese Option ist einstellbar über replaceInSystemsDB (Default = false) und extChanged (Default = Chg)

                          moin @fastfoot

                          hätte noch ein paar fragen

                          bitte bedenke die große anzahl meiner scripte

                          • wie kann ich aktiv laufende scripte konvertieren - was gibt es da für ein problem? könnten wir evtl über eine eigene javascript-instanz für das script nehmen und die anderen instanzen deaktivieren - es ist einfach zu viel, alle aktiven scripte "von hand" zu importieren
                          • das .chg als endung: könnten wir das auch ausschalten - ich hätte ja 750 scripte zu löschen

                          da ich proxmox habe ist das mit dem backup und restore ziemlich schnell erledigt - ich wollte jetzt einfach mal dein script auf alles anwenden und mich überraschen lassen. so wie es momentan ist, ist die nacharbeit zu viel

                          F Offline
                          F Offline
                          fastfoot
                          schrieb am zuletzt editiert von
                          #55

                          @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                          @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                          Direktes Ändern der Skripte im System.

                          Auf Wunsch (und aus Sicherheitsgründen enpfohlen!!!) wird an den Skriptnamen die Endung Chg angehängt, hierbei wird dann eine Kopie erstellt und das Original bleibt erhalten. Ist die Endung auf '' gesetzt, wird das Original überschrieben.
                          Aktive Skripte werden nicht ins System übernommen.
                          Diese Option ist einstellbar über replaceInSystemsDB (Default = false) und extChanged (Default = Chg)

                          moin @fastfoot

                          hätte noch ein paar fragen

                          bitte bedenke die große anzahl meiner scripte

                          • wie kann ich aktiv laufende scripte konvertieren - was gibt es da für ein problem? könnten wir evtl über eine eigene javascript-instanz für das script nehmen und die anderen instanzen deaktivieren - es ist einfach zu viel, alle aktiven scripte "von hand" zu importieren

                          du kannst ja die isRunning condition(Zeile83) wegnehmen und auch Chg zu '' ändern(Zeile16 extChanded), das sind eig. alles nur Sicherheitsmassnahmen, das Skript ist ja auch für relativ Unbedarfte Leute gedacht. Ein Test zeigt dass der running Status beim Überschreiben erhalten bleibt und das Skript neu startet. Da das aber ein Rumgefummel am System ist, kann ich die Auswirkungen nicht wirklich einschätzen. So als Läie würde ich aber sagen dass das funktionieren müsste. Trau Dich!! :-) Meine Tests waren soweit sehr positiv

                          • das .chg als endung: könnten wir das auch ausschalten - ich hätte ja 750 scripte zu löschen

                          s.o.

                          Ich bin gerade dabei das Einlesen auf Mirrorpath umzustellen, es hakt nur noch an Kleinigkeiten, bei der Bestimmung der ObjektId sieht der Code grausig aus, ansonsten ist es aufgräumter und läuft auch schon ganz gut. Die Probleme mit dem Selektor haben mich total genervt

                          iobroker läuft unter Docker auf QNAP TS-451+
                          SkriptRecovery: https://forum.iobroker.net/post/930558

                          liv-in-skyL 1 Antwort Letzte Antwort
                          0
                          • liv-in-skyL liv-in-sky

                            @fastfoot ich hoffe ich kapier das überhaupt alles richtig

                            theoretisch müßte man doch die scripte gleich in das object schreiben bzw überschreiben können - falls das nicht geht, wäre es möglich die "running" scripte nicht mit pfad im namen zu schreiben, sondern in eine verzeichnisstruktur, die dem mirror pfad entspricht - dann sollte man doch die file-struktur ins mirror kopieren können - ich weiß dann aber nicht, ob das running bleibt, wenn das script einfach in den mirror geschrieben wird

                            F Offline
                            F Offline
                            fastfoot
                            schrieb am zuletzt editiert von
                            #56

                            @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                            @fastfoot ich hoffe ich kapier das überhaupt alles richtig

                            theoretisch müßte man doch die scripte gleich in das object schreiben bzw überschreiben können - falls das nicht geht, wäre es möglich die "running" scripte nicht mit pfad im namen zu schreiben, sondern in eine verzeichnisstruktur, die dem mirror pfad entspricht - dann sollte man doch die file-struktur ins mirror kopieren können - ich weiß dann aber nicht, ob das running bleibt, wenn das script einfach in den mirror geschrieben wird

                            siehe den vorigen Post, überschreiben funktioniert eigentlich. Wie der Status eines 'neuen' Skript im Mirror ist weiss ich nicht, scheint mir aber von hinten durch die Brust ins Auge.

                            Wenn man zig Skripte konvertiert, dann werden die ja auch neu kompiliert, hier könnte ich mir eine race condition vorstellen. Speziell den global Ordner sollte man evtl. ausschliessen, da eine Änderung dort auch alle Skripte neu kompiliert

                            iobroker läuft unter Docker auf QNAP TS-451+
                            SkriptRecovery: https://forum.iobroker.net/post/930558

                            liv-in-skyL 1 Antwort Letzte Antwort
                            0
                            • F fastfoot

                              @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                              @fastfoot sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                              Direktes Ändern der Skripte im System.

                              Auf Wunsch (und aus Sicherheitsgründen enpfohlen!!!) wird an den Skriptnamen die Endung Chg angehängt, hierbei wird dann eine Kopie erstellt und das Original bleibt erhalten. Ist die Endung auf '' gesetzt, wird das Original überschrieben.
                              Aktive Skripte werden nicht ins System übernommen.
                              Diese Option ist einstellbar über replaceInSystemsDB (Default = false) und extChanged (Default = Chg)

                              moin @fastfoot

                              hätte noch ein paar fragen

                              bitte bedenke die große anzahl meiner scripte

                              • wie kann ich aktiv laufende scripte konvertieren - was gibt es da für ein problem? könnten wir evtl über eine eigene javascript-instanz für das script nehmen und die anderen instanzen deaktivieren - es ist einfach zu viel, alle aktiven scripte "von hand" zu importieren

                              du kannst ja die isRunning condition(Zeile83) wegnehmen und auch Chg zu '' ändern(Zeile16 extChanded), das sind eig. alles nur Sicherheitsmassnahmen, das Skript ist ja auch für relativ Unbedarfte Leute gedacht. Ein Test zeigt dass der running Status beim Überschreiben erhalten bleibt und das Skript neu startet. Da das aber ein Rumgefummel am System ist, kann ich die Auswirkungen nicht wirklich einschätzen. So als Läie würde ich aber sagen dass das funktionieren müsste. Trau Dich!! :-) Meine Tests waren soweit sehr positiv

                              • das .chg als endung: könnten wir das auch ausschalten - ich hätte ja 750 scripte zu löschen

                              s.o.

                              Ich bin gerade dabei das Einlesen auf Mirrorpath umzustellen, es hakt nur noch an Kleinigkeiten, bei der Bestimmung der ObjektId sieht der Code grausig aus, ansonsten ist es aufgräumter und läuft auch schon ganz gut. Die Probleme mit dem Selektor haben mich total genervt

                              liv-in-skyL Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              schrieb am zuletzt editiert von
                              #57

                              @fastfoot

                              habe jetzt umgestellt - habe aber ein problem

                              • objecte
                              • scripte - dank dir :-)
                              • iqontrol
                              • vis

                              was ich total vergessen habe,
                              sind alle meine tasker profiles - das sind einige - aber da geht auch was mit search und replace
                              und
                              ich habe viele scripte auf dem pc, die direct über simpleapi senden - die musss ich auch noch ändern :-)
                              und
                              und die linux scripte, die direct in linux laufen und auch simple api nutzen
                              und linux-control adapter

                              und
                              kann es sein, dass die trigger nicht mehr funktionieren ?

                              werde morgen wohl den ganzen tag in irgendwelchen log-dateien eintauchen müssen

                              nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                              1 Antwort Letzte Antwort
                              0
                              • F fastfoot

                                @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                @fastfoot ich hoffe ich kapier das überhaupt alles richtig

                                theoretisch müßte man doch die scripte gleich in das object schreiben bzw überschreiben können - falls das nicht geht, wäre es möglich die "running" scripte nicht mit pfad im namen zu schreiben, sondern in eine verzeichnisstruktur, die dem mirror pfad entspricht - dann sollte man doch die file-struktur ins mirror kopieren können - ich weiß dann aber nicht, ob das running bleibt, wenn das script einfach in den mirror geschrieben wird

                                siehe den vorigen Post, überschreiben funktioniert eigentlich. Wie der Status eines 'neuen' Skript im Mirror ist weiss ich nicht, scheint mir aber von hinten durch die Brust ins Auge.

                                Wenn man zig Skripte konvertiert, dann werden die ja auch neu kompiliert, hier könnte ich mir eine race condition vorstellen. Speziell den global Ordner sollte man evtl. ausschliessen, da eine Änderung dort auch alle Skripte neu kompiliert

                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                schrieb am zuletzt editiert von
                                #58

                                @fastfoot

                                es scheint im moment, dass ich jedes blockly mit einem neuen trigger versehen muss - irgendeinen - dann speichern und dann triggert das blockly wieder

                                shr seltsam

                                nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                F 1 Antwort Letzte Antwort
                                0
                                • liv-in-skyL liv-in-sky

                                  @fastfoot

                                  es scheint im moment, dass ich jedes blockly mit einem neuen trigger versehen muss - irgendeinen - dann speichern und dann triggert das blockly wieder

                                  shr seltsam

                                  F Offline
                                  F Offline
                                  fastfoot
                                  schrieb am zuletzt editiert von
                                  #59

                                  @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                  @fastfoot

                                  es scheint im moment, dass ich jedes blockly mit einem neuen trigger versehen muss - irgendeinen - dann speichern und dann triggert das blockly wieder

                                  shr seltsam

                                  ich hätte ja auf einen Neustart des JS-Adapters getippt. Allerdings, wenn du dir den JS-Code eines geänderten Blockly anschaust, dann ist der ja weg. Bewegt man einen Block dann berechnet iobroker den Code neu. Evtll. liegt es auch daran. nach meiner Überzeugung braucht es diesen Code aber nicht zwingend. Evtl. braucht es aber dennoch eine Neucompilation.

                                  Ansonsten hast du ja eine riesen Baustelle :-) Für die VIS hatten wir doch aber auch etwas?

                                  iobroker läuft unter Docker auf QNAP TS-451+
                                  SkriptRecovery: https://forum.iobroker.net/post/930558

                                  liv-in-skyL 1 Antwort Letzte Antwort
                                  0
                                  • F fastfoot

                                    @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                    @fastfoot

                                    es scheint im moment, dass ich jedes blockly mit einem neuen trigger versehen muss - irgendeinen - dann speichern und dann triggert das blockly wieder

                                    shr seltsam

                                    ich hätte ja auf einen Neustart des JS-Adapters getippt. Allerdings, wenn du dir den JS-Code eines geänderten Blockly anschaust, dann ist der ja weg. Bewegt man einen Block dann berechnet iobroker den Code neu. Evtll. liegt es auch daran. nach meiner Überzeugung braucht es diesen Code aber nicht zwingend. Evtl. braucht es aber dennoch eine Neucompilation.

                                    Ansonsten hast du ja eine riesen Baustelle :-) Für die VIS hatten wir doch aber auch etwas?

                                    liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    schrieb am zuletzt editiert von
                                    #60

                                    @fastfoot die vis läuft - auch ein script von dir

                                    nein -. ich muss einen neuen trigger-block einfügen - der muss einmal getriggert werden und danach funktioniert es
                                    , iobroker neustart, instanz neustart - alles gemacht - die scripte sind auch im editor auf run eingestellt und auch unter script_enabeld

                                    im moment muss ich jedes blockly aufrufen und das durchziehen - sondt geht nix mehr im haus

                                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                    F 1 Antwort Letzte Antwort
                                    0
                                    • liv-in-skyL liv-in-sky

                                      @fastfoot die vis läuft - auch ein script von dir

                                      nein -. ich muss einen neuen trigger-block einfügen - der muss einmal getriggert werden und danach funktioniert es
                                      , iobroker neustart, instanz neustart - alles gemacht - die scripte sind auch im editor auf run eingestellt und auch unter script_enabeld

                                      im moment muss ich jedes blockly aufrufen und das durchziehen - sondt geht nix mehr im haus

                                      F Offline
                                      F Offline
                                      fastfoot
                                      schrieb am zuletzt editiert von
                                      #61

                                      @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                      im moment muss ich jedes blockly aufrufen und das durchziehen - sondt geht nix mehr im haus

                                      krass. ich habe keine Blocklys mehr, werde das aber mal testen

                                      iobroker läuft unter Docker auf QNAP TS-451+
                                      SkriptRecovery: https://forum.iobroker.net/post/930558

                                      liv-in-skyL 1 Antwort Letzte Antwort
                                      0
                                      • F fastfoot

                                        @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                        im moment muss ich jedes blockly aufrufen und das durchziehen - sondt geht nix mehr im haus

                                        krass. ich habe keine Blocklys mehr, werde das aber mal testen

                                        liv-in-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        schrieb am zuletzt editiert von
                                        #62

                                        @fastfoot

                                        habe alles direkt ins system geschrieben zeile 83 if(replaceInSystemsDB && changes > 0){

                                        und const extChanged = '';

                                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                        F 1 Antwort Letzte Antwort
                                        0
                                        • liv-in-skyL liv-in-sky

                                          @fastfoot

                                          habe alles direkt ins system geschrieben zeile 83 if(replaceInSystemsDB && changes > 0){

                                          und const extChanged = '';

                                          F Offline
                                          F Offline
                                          fastfoot
                                          schrieb am zuletzt editiert von
                                          #63

                                          @liv-in-sky sagte in [Skript] Namespace für Datenpunkte in Skripten abändern:

                                          @fastfoot

                                          habe alles direkt ins system geschrieben zeile 83 if(replaceInSystemsDB && changes > 0){

                                          und const extChanged = '';

                                          habe einen Fix. Der Code wird tatsächlich gebraucht.
                                          ersetze in convertBlockly die erste Zeile(const BlocklyHeader....) durch

                                              let regex = new RegExp(oldNamespace, "g");
                                              //let blocklyHeader = '//Das Skript wurde programmatisch modifiziert. Um den JS code zurück zu erhalten, \n//einen der Blöcke etwas verschieben und abspeichern.\n//';
                                              let blocklyHeaderTmp = source.split('\n');
                                              blocklyHeaderTmp.pop();
                                              let blocklyHeader = blocklyHeaderTmp.join('\n').replace(regex, newNamespace) + '\n//';
                                          

                                          Ein Zeitplan welcher nicht funktioniert hatte nach der Konvertierung läuft jetzt problemlos weiter

                                          iobroker läuft unter Docker auf QNAP TS-451+
                                          SkriptRecovery: https://forum.iobroker.net/post/930558

                                          liv-in-skyL 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

                                          773

                                          Online

                                          32.5k

                                          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