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. Entwicklung
  4. Klärung von AdpaterEntwicklungs Fragen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.1k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Klärung von AdpaterEntwicklungs Fragen

Geplant Angeheftet Gesperrt Verschoben Entwicklung
adapter entwicklung
48 Beiträge 6 Kommentatoren 2.6k Aufrufe 7 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.
  • PeoplesP Peoples

    Wie schon in einem anderen Thread geschrieben bin ich gerade dabei mich in das Thema Adapter einzulesen, nun habe ich mal damit begonnen mein "Seitenwechsel-Script" in einen Adapter zu portiern.

    Das was ich umsetzen will klappt und funktioniert auch, aber wenn ich mir den Code anschaue kriege ich schier das ko.... nur leider ist mein Wissen hier begrenzt, die lernbereitschaft ist aber da!
    Ich muss einige vorher angelegte Objekte abfragen und mache das derzeit mit der adapter.getState Funktion inkl. dem Callback.

    Das bläst mir den Code aber unnötig auf, da ich jedes mal den error abfange was ich persönlich jetzt nicht machen würde (gerne lasse ich mich hier belehren). Als Beispiel habe ich mal eine der Funktionen hier gepostet wo in den Zeilen 3, 9, 17, 36, 43 eben genau dieses getState auftaucht.

    Ich wollte mal nun die wirklichen Programmierer/Entwickler fragen ob es da nicht eine hübschere / professionellere Methode gibt das umzusetzen.

    Meistens möchte ich nicht nur dass es funktioniert sondern es sollte auch schön aussehen. :+1:

    function switchToHomeView() {
        timerTout = setTimeout(function () {
            adapter.getState('switchTimer', (err, state) => {
                if (!state || state.val === null) {
                    adapter.log.error('Error by getting Value switchTimer');
                } else {
                    let timer = parseInt(state.val, 10);
                    if (timer > 1) {
                        adapter.getState('lockViewActive', (err, state) => {
                            if (!state || state.val === null) {
                                adapter.log.error('Error bei getting Value of lockViewActive');
                                } else {
                                    if(state.val === true){
                    //Timeout prüfen?
                                        if(timerTout) clearTimeout(timerTout);
                                        adapter.setState('switchTimer', 0);
                                        adapter.getState('actualLockView', (err, state) => {
                                            if (!state || state.val === null) {
                                                adapter.log.error('Error bei getting Value of actualLockView');
                                            } else {
                                                if(state.val != newState.split('/').pop()){
                                                    switchToViewImmediate(project+'/'+state.val);
                                                }
                                            }
                                        });
                                    } else {
                                        adapter.setState('switchTimer',timer - 1);
                                        switchToHomeView(); 
                                    }
                                }
                        });
                    }
                    else{
                        adapter.setState('switchTimer', 0);
                       
                        adapter.getForeignState('vis.0.control.instance', (err, state) => {
                            if (!state || state.val === null) {
                                adapter.log.error('Error bei getting Value of vis.0.control.instance');
                            } else {
                                if(state.val == 'undefined') adapter.setForeignState('vis.0.control.instance', 'FFFFFFFF');
                            }
                        });
                        adapter.getState('actualHomeView', (err, state) => {
                            if (!state || state.val === null) {
                                adapter.log.error('Error bei getting Value of actualHomeView');
                            } else {
                                adapter.log.info(project + '/' + state.val)
                                adapter.setForeignState('vis.0.control.data', project + '/' + state.val);
                                adapter.setForeignState('vis.0.control.command', 'changeView');
                            }
                        });
                    }
                }
            });
        }, 1000);
    }
    

    Merci schonmal!

    UncleSamU Offline
    UncleSamU Offline
    UncleSam
    Developer
    schrieb am zuletzt editiert von UncleSam
    #2

    @Peoples Die Lösung heisst async/await mit Promises.

    Damit kannst du dann z.B. schreiben (sorry, bin TypeScript Fan, kann sein dass das nicht perfektes JavaScript ist):

    try {
      const switchTimer = await adapter.getStateAsync('switchTimer');
      if (switchTimer.val === null) {
        throw new Error('Error by getting Value switchTimer');
      }
      const timer = parseInt(state.val, 10);
      if (timer > 1) {
        const lockViewActive = await adapter.getStateAsync('lockViewActive');
        /* ... und so weiter */
      } else {
        /* der andere Fall... */
      }
    } catch (error) {
      /* Fehler behandeln... */
    }
    

    Mehr Infos findest du z.B. hier: https://javascript.info/async-await

    Bitte bei Problemen mit meinen Adaptern, Issue auf GitHub erfassen: Loxone | I2C | Luxtronik2
    ♡-lichen Dank an meine Sponsoren

    1 Antwort Letzte Antwort
    0
    • PeoplesP Peoples

      Wie schon in einem anderen Thread geschrieben bin ich gerade dabei mich in das Thema Adapter einzulesen, nun habe ich mal damit begonnen mein "Seitenwechsel-Script" in einen Adapter zu portiern.

      Das was ich umsetzen will klappt und funktioniert auch, aber wenn ich mir den Code anschaue kriege ich schier das ko.... nur leider ist mein Wissen hier begrenzt, die lernbereitschaft ist aber da!
      Ich muss einige vorher angelegte Objekte abfragen und mache das derzeit mit der adapter.getState Funktion inkl. dem Callback.

      Das bläst mir den Code aber unnötig auf, da ich jedes mal den error abfange was ich persönlich jetzt nicht machen würde (gerne lasse ich mich hier belehren). Als Beispiel habe ich mal eine der Funktionen hier gepostet wo in den Zeilen 3, 9, 17, 36, 43 eben genau dieses getState auftaucht.

      Ich wollte mal nun die wirklichen Programmierer/Entwickler fragen ob es da nicht eine hübschere / professionellere Methode gibt das umzusetzen.

      Meistens möchte ich nicht nur dass es funktioniert sondern es sollte auch schön aussehen. :+1:

      function switchToHomeView() {
          timerTout = setTimeout(function () {
              adapter.getState('switchTimer', (err, state) => {
                  if (!state || state.val === null) {
                      adapter.log.error('Error by getting Value switchTimer');
                  } else {
                      let timer = parseInt(state.val, 10);
                      if (timer > 1) {
                          adapter.getState('lockViewActive', (err, state) => {
                              if (!state || state.val === null) {
                                  adapter.log.error('Error bei getting Value of lockViewActive');
                                  } else {
                                      if(state.val === true){
                      //Timeout prüfen?
                                          if(timerTout) clearTimeout(timerTout);
                                          adapter.setState('switchTimer', 0);
                                          adapter.getState('actualLockView', (err, state) => {
                                              if (!state || state.val === null) {
                                                  adapter.log.error('Error bei getting Value of actualLockView');
                                              } else {
                                                  if(state.val != newState.split('/').pop()){
                                                      switchToViewImmediate(project+'/'+state.val);
                                                  }
                                              }
                                          });
                                      } else {
                                          adapter.setState('switchTimer',timer - 1);
                                          switchToHomeView(); 
                                      }
                                  }
                          });
                      }
                      else{
                          adapter.setState('switchTimer', 0);
                         
                          adapter.getForeignState('vis.0.control.instance', (err, state) => {
                              if (!state || state.val === null) {
                                  adapter.log.error('Error bei getting Value of vis.0.control.instance');
                              } else {
                                  if(state.val == 'undefined') adapter.setForeignState('vis.0.control.instance', 'FFFFFFFF');
                              }
                          });
                          adapter.getState('actualHomeView', (err, state) => {
                              if (!state || state.val === null) {
                                  adapter.log.error('Error bei getting Value of actualHomeView');
                              } else {
                                  adapter.log.info(project + '/' + state.val)
                                  adapter.setForeignState('vis.0.control.data', project + '/' + state.val);
                                  adapter.setForeignState('vis.0.control.command', 'changeView');
                              }
                          });
                      }
                  }
              });
          }, 1000);
      }
      

      Merci schonmal!

      UncleSamU Offline
      UncleSamU Offline
      UncleSam
      Developer
      schrieb am zuletzt editiert von
      #3

      @Peoples Und noch ein grundsätzlicher Tipp: schau dir mal "gute" Adapter an, wie die geschrieben sind.

      "Gut" kannst du selber definieren, aber ich glaube, du hast da ein gutes Bauchgefühl:

      wenn ich mir den Code anschaue kriege ich schier das ko....

      Wenn du bereit bist etwas mehr zu lernen, empfehle ich dir sehr, den Adapter gleich in TypeScript zu schreiben - das ist wirklich keine Magie!

      Und verwende unbedingt den Adapter Creator: https://github.com/ioBroker/create-adapter

      npx @iobroker/create-adapter [options]
      

      Bitte bei Problemen mit meinen Adaptern, Issue auf GitHub erfassen: Loxone | I2C | Luxtronik2
      ♡-lichen Dank an meine Sponsoren

      PeoplesP 1 Antwort Letzte Antwort
      0
      • UncleSamU UncleSam

        @Peoples Und noch ein grundsätzlicher Tipp: schau dir mal "gute" Adapter an, wie die geschrieben sind.

        "Gut" kannst du selber definieren, aber ich glaube, du hast da ein gutes Bauchgefühl:

        wenn ich mir den Code anschaue kriege ich schier das ko....

        Wenn du bereit bist etwas mehr zu lernen, empfehle ich dir sehr, den Adapter gleich in TypeScript zu schreiben - das ist wirklich keine Magie!

        Und verwende unbedingt den Adapter Creator: https://github.com/ioBroker/create-adapter

        npx @iobroker/create-adapter [options]
        
        PeoplesP Offline
        PeoplesP Offline
        Peoples
        schrieb am zuletzt editiert von
        #4

        @UncleSam sagte in Suche Alternative zu adapter.getState mit Callback:

        @Peoples Und noch ein grundsätzlicher Tipp: schau dir mal "gute" Adapter an, wie die geschrieben sind.

        "Gut" kannst du selber definieren, aber ich glaube, du hast da ein gutes Bauchgefühl:

        wenn ich mir den Code anschaue kriege ich schier das ko....

        Wenn du bereit bist etwas mehr zu lernen, empfehle ich dir sehr, den Adapter gleich in TypeScript zu schreiben - das ist wirklich keine Magie!

        Und verwende unbedingt den Adapter Creator: https://github.com/ioBroker/create-adapter

        npx @iobroker/create-adapter [options]
        

        Den Adapter-Creater habe ich benutzt und versuche eben nun erstmal alle Funktionen meines Scripts zum Laufen zu kriegen, das nächste Ziel ist dann den Code aufzuhübschen.
        Wenn ich mich dann noch nicht gefragt habe warum ich das angefangen habe, werde ich mir das Thema TypeScript auch noch anschauen.

        Aber für Laien ist das im Ganzen schon ein sehr forderndes Thema

        Ich beantworte keine Fragen zu Themen via PN

        UncleSamU AlCalzoneA 2 Antworten Letzte Antwort
        0
        • PeoplesP Peoples

          @UncleSam sagte in Suche Alternative zu adapter.getState mit Callback:

          @Peoples Und noch ein grundsätzlicher Tipp: schau dir mal "gute" Adapter an, wie die geschrieben sind.

          "Gut" kannst du selber definieren, aber ich glaube, du hast da ein gutes Bauchgefühl:

          wenn ich mir den Code anschaue kriege ich schier das ko....

          Wenn du bereit bist etwas mehr zu lernen, empfehle ich dir sehr, den Adapter gleich in TypeScript zu schreiben - das ist wirklich keine Magie!

          Und verwende unbedingt den Adapter Creator: https://github.com/ioBroker/create-adapter

          npx @iobroker/create-adapter [options]
          

          Den Adapter-Creater habe ich benutzt und versuche eben nun erstmal alle Funktionen meines Scripts zum Laufen zu kriegen, das nächste Ziel ist dann den Code aufzuhübschen.
          Wenn ich mich dann noch nicht gefragt habe warum ich das angefangen habe, werde ich mir das Thema TypeScript auch noch anschauen.

          Aber für Laien ist das im Ganzen schon ein sehr forderndes Thema

          UncleSamU Offline
          UncleSamU Offline
          UncleSam
          Developer
          schrieb am zuletzt editiert von
          #5

          @Peoples sagte in Suche Alternative zu adapter.getState mit Callback:

          Aber für Laien ist das im Ganzen schon ein sehr forderndes Thema

          Absolut. Ich wünsche dir auf jeden Fall viel Erfolg. Und du weisst ja: im Forum wirst du immer geholfen! ;-)

          Bitte bei Problemen mit meinen Adaptern, Issue auf GitHub erfassen: Loxone | I2C | Luxtronik2
          ♡-lichen Dank an meine Sponsoren

          1 Antwort Letzte Antwort
          0
          • PeoplesP Peoples

            @UncleSam sagte in Suche Alternative zu adapter.getState mit Callback:

            @Peoples Und noch ein grundsätzlicher Tipp: schau dir mal "gute" Adapter an, wie die geschrieben sind.

            "Gut" kannst du selber definieren, aber ich glaube, du hast da ein gutes Bauchgefühl:

            wenn ich mir den Code anschaue kriege ich schier das ko....

            Wenn du bereit bist etwas mehr zu lernen, empfehle ich dir sehr, den Adapter gleich in TypeScript zu schreiben - das ist wirklich keine Magie!

            Und verwende unbedingt den Adapter Creator: https://github.com/ioBroker/create-adapter

            npx @iobroker/create-adapter [options]
            

            Den Adapter-Creater habe ich benutzt und versuche eben nun erstmal alle Funktionen meines Scripts zum Laufen zu kriegen, das nächste Ziel ist dann den Code aufzuhübschen.
            Wenn ich mich dann noch nicht gefragt habe warum ich das angefangen habe, werde ich mir das Thema TypeScript auch noch anschauen.

            Aber für Laien ist das im Ganzen schon ein sehr forderndes Thema

            AlCalzoneA Offline
            AlCalzoneA Offline
            AlCalzone
            Developer
            schrieb am zuletzt editiert von AlCalzone
            #6

            @Peoples sagte in Suche Alternative zu adapter.getState mit Callback:

            werde ich mir das Thema TypeScript auch noch anschauen.

            ==> https://forum.iobroker.net/topic/36493/einsteiger-cursus-demonstration-von-typescript :)

            @Peoples sagte in Suche Alternative zu adapter.getState mit Callback:

            aber wenn ich mir den Code anschaue kriege ich schier das ko....

            Das kann ich dir bezüglich async/await noch ans Herz legen:
            https://gist.github.com/AlCalzone/d14b854b69ce5e8a03718336cc650a95#

            Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

            1 Antwort Letzte Antwort
            0
            • PeoplesP Offline
              PeoplesP Offline
              Peoples
              schrieb am zuletzt editiert von Peoples
              #7

              @UncleSam @AlCalzone

              Tausend Dank schonmal!

              Ich habe das Ganze jetzt wie folgt geändert:

              async function switchToHomeView() {
                    try {
                        const switchTimer = await adapter.getStateAsync('switchTimer');
                        const lockViewActive = await adapter.getStateAsync('lockViewActive');
                        const actualLockView = await adapter.getStateAsync('actualLockView');
                        const actualHomeView = await adapter.getStateAsync('actualHomeView');
                        const visInstance = await adapter.getForeignStateAsync('vis.0.control.instance');
                        timerTout = setTimeout(function () {
                               let timer = parseInt(switchTimer.val, 10)
                               if(timer > 1){
                                   if(lockViewActive.val === true){
                                       if(timerTout) clearTimeout(timerTout);
                                       adapter.setState('switchTimer', 0);
                      //Woher kommt newState                       
                                       if(actualLockView.val != newState.split('/').pop()){
                                           switchToViewImmediate(project+'/'+state.val);
                                       }
                                   } else {
                                      adapter.setState('switchTimer',timer - 1);
                                      switchToHomeView(); 
                                  }
                               } else {
                                   adapter.setState('switchTimer', 0);
                                   if(visInstance.val == undefined) adapter.setForeignState('vis.0.control.instance', 'FFFFFFFF');
              
                                   adapter.setForeignState('vis.0.control.data', project + '/' + actualHomeView.val);
                                   adapter.setForeignState('vis.0.control.command', 'changeView');
              
                               }
                          }, 1000);
              
                  } catch (error) {
                    adapter.log.error(error);
                  }
              }
              

              Rein optisch gefällt mir das nun schon sehr viel besser, ABER funktionieren tut das nun irgendwie nicht mehr richtig.

              Der Timer läuft nicht mehr im Sekundentakt sondern im 2 Sekundentakt, man sieht zwar in den Objekten dass er sekündlich getriggert wird aber die Wertänderung ist nur alle 2.

              Wie kann ich das beheben ausser dass ich das Timeout von 1000 auf 500 setze?

              Ich beantworte keine Fragen zu Themen via PN

              AsgothianA 1 Antwort Letzte Antwort
              0
              • PeoplesP Peoples

                @UncleSam @AlCalzone

                Tausend Dank schonmal!

                Ich habe das Ganze jetzt wie folgt geändert:

                async function switchToHomeView() {
                      try {
                          const switchTimer = await adapter.getStateAsync('switchTimer');
                          const lockViewActive = await adapter.getStateAsync('lockViewActive');
                          const actualLockView = await adapter.getStateAsync('actualLockView');
                          const actualHomeView = await adapter.getStateAsync('actualHomeView');
                          const visInstance = await adapter.getForeignStateAsync('vis.0.control.instance');
                          timerTout = setTimeout(function () {
                                 let timer = parseInt(switchTimer.val, 10)
                                 if(timer > 1){
                                     if(lockViewActive.val === true){
                                         if(timerTout) clearTimeout(timerTout);
                                         adapter.setState('switchTimer', 0);
                        //Woher kommt newState                       
                                         if(actualLockView.val != newState.split('/').pop()){
                                             switchToViewImmediate(project+'/'+state.val);
                                         }
                                     } else {
                                        adapter.setState('switchTimer',timer - 1);
                                        switchToHomeView(); 
                                    }
                                 } else {
                                     adapter.setState('switchTimer', 0);
                                     if(visInstance.val == undefined) adapter.setForeignState('vis.0.control.instance', 'FFFFFFFF');
                
                                     adapter.setForeignState('vis.0.control.data', project + '/' + actualHomeView.val);
                                     adapter.setForeignState('vis.0.control.command', 'changeView');
                
                                 }
                            }, 1000);
                
                    } catch (error) {
                      adapter.log.error(error);
                    }
                }
                

                Rein optisch gefällt mir das nun schon sehr viel besser, ABER funktionieren tut das nun irgendwie nicht mehr richtig.

                Der Timer läuft nicht mehr im Sekundentakt sondern im 2 Sekundentakt, man sieht zwar in den Objekten dass er sekündlich getriggert wird aber die Wertänderung ist nur alle 2.

                Wie kann ich das beheben ausser dass ich das Timeout von 1000 auf 500 setze?

                AsgothianA Offline
                AsgothianA Offline
                Asgothian
                Developer
                schrieb am zuletzt editiert von
                #8

                @Peoples ich denke du solltest den timeout vor die await Statements setzen. Der rennt dann schon einmal los während noch auf die Werte gewartet wird.

                A.

                ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                PeoplesP 1 Antwort Letzte Antwort
                0
                • AsgothianA Asgothian

                  @Peoples ich denke du solltest den timeout vor die await Statements setzen. Der rennt dann schon einmal los während noch auf die Werte gewartet wird.

                  A.

                  PeoplesP Offline
                  PeoplesP Offline
                  Peoples
                  schrieb am zuletzt editiert von Peoples
                  #9

                  @Asgothian
                  Die Idee hatte ich auch schon dann klappt das mit dem await nicht mehr, da das Timeout keine async function ist :-)

                  Edit
                  Nach längerm suchen und probieren habe ich es dann doch hinbekommen einfach das Timeout auch als async:

                  async function switchToHomeView() {
                        try {
                            const switchTimer = await adapter.getStateAsync('switchTimer');
                            const lockViewActive = await adapter.getStateAsync('lockViewActive');
                            const actualLockView = await adapter.getStateAsync('actualLockView');
                            const actualHomeView = await adapter.getStateAsync('actualHomeView');
                            const visInstance = await adapter.getForeignStateAsync('vis.0.control.instance');
                            timerTout = await setTimeout(async function () {
                                   let timer = parseInt(switchTimer.val, 10)
                                   if(timer > 1){
                                       if(lockViewActive.val === true){
                                           if(timerTout) clearTimeout(timerTout);
                                           await adapter.setStateAsync('switchTimer', 0);
                          //Woher kommt newState                       
                                           if(actualLockView.val != newState.split('/').pop()){
                                               switchToViewImmediate(project+'/'+state.val);
                                           }
                                       } else {
                                          await adapter.setStateAsync('switchTimer',timer - 1);
                                          switchToHomeView(); 
                                      }
                                   } else {
                                       await adapter.setStateAsync('switchTimer', 0);
                                       if(visInstance.val == undefined) await adapter.setForeignStateAsync('vis.0.control.instance', 'FFFFFFFF');
                  
                                       await adapter.setForeignStateAsync('vis.0.control.data', project + '/' + actualHomeView.val);
                                       await adapter.setForeignStateAsync('vis.0.control.command', 'changeView');
                  
                                   }
                              }, 1000);
                  
                      } catch (error) {
                        adapter.log.error(error);
                      }
                  }

                  Ich beantworte keine Fragen zu Themen via PN

                  1 Antwort Letzte Antwort
                  0
                  • PeoplesP Offline
                    PeoplesP Offline
                    Peoples
                    schrieb am zuletzt editiert von Peoples
                    #10

                    Ich habe jetzt mal den Titel geändert, um ein weiteres Problemchen hier mit einfügen zu können ohne einen neuen Thread auf zu machen

                    ``

                    Jetzt bleibt aber noch eine Frage:
                    Ich erstelle nach folgendem Muster meine Datenpunkte:

                    adapter.setObjectNotExistsAsync('actualHomeView', {
                            type: 'state',
                            common: {
                                name: 'View what is set as Home',
                                type: 'string',
                                role: 'indicator',
                                read: true,
                                write: true,
                            },
                            native: {},
                        });
                    

                    wenn ich diese jetzt mit deleteState lösche möchte passiert garnichts. Ich habe auch schon Beispiel mit einer Schleife gefunden und probiert aber auch ohne Erfolg.
                    Wie schaffe ich es bspw. den Ordner Demoview 2 inkl. aller darin enthaltenen Datenpunkte zu löschen?

                    viewswitch.0
                    - Datenpunkt
                    - Datenpunkt
                       |_ Views (Unterordner)
                         |_ Demoview 1(Unterordner)
                             - Datenpunkt 1
                             - Datenpunkt 2
                             - Datenpunkt 3
                             - Datenpunkt 4
                         |_ Demoview 2(Unterordner)
                              - Datenpunkt 1
                              - Datenpunkt 2
                              - Datenpunkt 3
                              - Datenpunkt 4
                         |_ Demoview 3(Unterordner)
                             - Datenpunkt 1
                             - Datenpunkt 2
                             - Datenpunkt 3
                             - Datenpunkt 4
                    - Datenpunkt 1
                    - Datenpunkt 2
                    - Datenpunkt 3
                    - Datenpunkt 4
                    

                    Ich beantworte keine Fragen zu Themen via PN

                    AlCalzoneA 1 Antwort Letzte Antwort
                    0
                    • PeoplesP Peoples

                      Ich habe jetzt mal den Titel geändert, um ein weiteres Problemchen hier mit einfügen zu können ohne einen neuen Thread auf zu machen

                      ``

                      Jetzt bleibt aber noch eine Frage:
                      Ich erstelle nach folgendem Muster meine Datenpunkte:

                      adapter.setObjectNotExistsAsync('actualHomeView', {
                              type: 'state',
                              common: {
                                  name: 'View what is set as Home',
                                  type: 'string',
                                  role: 'indicator',
                                  read: true,
                                  write: true,
                              },
                              native: {},
                          });
                      

                      wenn ich diese jetzt mit deleteState lösche möchte passiert garnichts. Ich habe auch schon Beispiel mit einer Schleife gefunden und probiert aber auch ohne Erfolg.
                      Wie schaffe ich es bspw. den Ordner Demoview 2 inkl. aller darin enthaltenen Datenpunkte zu löschen?

                      viewswitch.0
                      - Datenpunkt
                      - Datenpunkt
                         |_ Views (Unterordner)
                           |_ Demoview 1(Unterordner)
                               - Datenpunkt 1
                               - Datenpunkt 2
                               - Datenpunkt 3
                               - Datenpunkt 4
                           |_ Demoview 2(Unterordner)
                                - Datenpunkt 1
                                - Datenpunkt 2
                                - Datenpunkt 3
                                - Datenpunkt 4
                           |_ Demoview 3(Unterordner)
                               - Datenpunkt 1
                               - Datenpunkt 2
                               - Datenpunkt 3
                               - Datenpunkt 4
                      - Datenpunkt 1
                      - Datenpunkt 2
                      - Datenpunkt 3
                      - Datenpunkt 4
                      
                      AlCalzoneA Offline
                      AlCalzoneA Offline
                      AlCalzone
                      Developer
                      schrieb am zuletzt editiert von AlCalzone
                      #11

                      @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

                      Wie schaffe ich es bspw. den Ordner Demoview 2 inkl. aller darin enthaltenen Datenpunkte zu löschen?

                      Wie hast du es denn versucht (Code)? Ist Demoview 2 ein Channel oder Folder-Objekt oder nur ein Teil der ID?

                      Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                      PeoplesP 1 Antwort Letzte Antwort
                      0
                      • AlCalzoneA AlCalzone

                        @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

                        Wie schaffe ich es bspw. den Ordner Demoview 2 inkl. aller darin enthaltenen Datenpunkte zu löschen?

                        Wie hast du es denn versucht (Code)? Ist Demoview 2 ein Channel oder Folder-Objekt oder nur ein Teil der ID?

                        PeoplesP Offline
                        PeoplesP Offline
                        Peoples
                        schrieb am zuletzt editiert von Peoples
                        #12

                        @AlCalzone
                        Ich habe es versucht wie in diesem gefundenen Forumsthread: https://forum.iobroker.net/topic/948/adapter-alle-objekte-states-eines-adapters-l%C3%B6schen/4

                        dann kannst du es mit````
                        adapter.getChannels(function (err, channels) {
                             for(var d = 0; d < channels.length, d++) {
                                  adapter.deleteChannel(channels[d]._id);
                             }
                        

                        Aber bei mir passiert garnichts, nichtmal ein Fehler wird ausgegeben. Meine Objektstrucktur sieht so aus:
                        forum.JPG

                        Hintergrund ist folgender, wenn der Adapter gestartet wird, werden über die entsprechende vis-views.json alle vorhandenen Views eingelesen und als "Ordner" mit 4 States angelegt.

                        Nun beobachte ich mit watchfile die Datei und bei einer Änderung möchte ich eine Funktion aufrufen die prüft ob neue Views dazu gekommen sind und diese dann ergänzt oder nicht mehr vorhandene löscht.

                        Ich beantworte keine Fragen zu Themen via PN

                        AlCalzoneA 1 Antwort Letzte Antwort
                        0
                        • PeoplesP Peoples

                          @AlCalzone
                          Ich habe es versucht wie in diesem gefundenen Forumsthread: https://forum.iobroker.net/topic/948/adapter-alle-objekte-states-eines-adapters-l%C3%B6schen/4

                          dann kannst du es mit````
                          adapter.getChannels(function (err, channels) {
                               for(var d = 0; d < channels.length, d++) {
                                    adapter.deleteChannel(channels[d]._id);
                               }
                          

                          Aber bei mir passiert garnichts, nichtmal ein Fehler wird ausgegeben. Meine Objektstrucktur sieht so aus:
                          forum.JPG

                          Hintergrund ist folgender, wenn der Adapter gestartet wird, werden über die entsprechende vis-views.json alle vorhandenen Views eingelesen und als "Ordner" mit 4 States angelegt.

                          Nun beobachte ich mit watchfile die Datei und bei einer Änderung möchte ich eine Funktion aufrufen die prüft ob neue Views dazu gekommen sind und diese dann ergänzt oder nicht mehr vorhandene löscht.

                          AlCalzoneA Offline
                          AlCalzoneA Offline
                          AlCalzone
                          Developer
                          schrieb am zuletzt editiert von
                          #13

                          @Peoples
                          deleteChannel, deleteDevice etc. gehen davon aus, dass du dich an die vorgesehene Struktur device.channel.state hältst. Das ist hier nicht der Fall - du hast nur States ohne übergeordnete Device- und Channel-Objekte.
                          Das erkennst du daran, dass neben DemoView in der Typ-Spalte nicht channel steht.

                          Du musst also die zu löschenden States einzeln löschen, sprich

                          1. mit getStates die States auflisten
                          2. diese durchgehen und diejenigen mit deleteState löschen, die weg sollen.

                          Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                          PeoplesP 1 Antwort Letzte Antwort
                          0
                          • AlCalzoneA AlCalzone

                            @Peoples
                            deleteChannel, deleteDevice etc. gehen davon aus, dass du dich an die vorgesehene Struktur device.channel.state hältst. Das ist hier nicht der Fall - du hast nur States ohne übergeordnete Device- und Channel-Objekte.
                            Das erkennst du daran, dass neben DemoView in der Typ-Spalte nicht channel steht.

                            Du musst also die zu löschenden States einzeln löschen, sprich

                            1. mit getStates die States auflisten
                            2. diese durchgehen und diejenigen mit deleteState löschen, die weg sollen.
                            PeoplesP Offline
                            PeoplesP Offline
                            Peoples
                            schrieb am zuletzt editiert von
                            #14

                            @AlCalzone
                            Wäre es besser Channel zu benutzen?
                            Mir ist ehrlich gesagt nicht ganz klar was der Unterschied ist.
                            Und wenn ich die states lösche wie kriege ich die Ordner dann weg

                            Ich beantworte keine Fragen zu Themen via PN

                            AlCalzoneA 1 Antwort Letzte Antwort
                            0
                            • PeoplesP Peoples

                              @AlCalzone
                              Wäre es besser Channel zu benutzen?
                              Mir ist ehrlich gesagt nicht ganz klar was der Unterschied ist.
                              Und wenn ich die states lösche wie kriege ich die Ordner dann weg

                              AlCalzoneA Offline
                              AlCalzoneA Offline
                              AlCalzone
                              Developer
                              schrieb am zuletzt editiert von
                              #15

                              @Peoples
                              Die "Ordner" sind nur virtuell, sobald alle States mit diesem ID-Abschnitt weg sind, sind die auch weg.

                              Streng genommen sollte keiner dieser "Ordner" ohne ein zugehöriges Objekt existieren. Objekte definieren unter anderem den Sinn dieses "Ordners" und Anzeigenamen, etc.. Die Objekttypen sind definiert unter https://www.iobroker.net/#en/documentation/dev/objectsschema.md?objecttypes

                              Die "klassische" Struktur, die wohl noch aus der Homematic-Welt stammt, ist device.channel.state, wobei ein device ein physisches Gerät beschreibt, channel eine Teilfunktion (z.B. Licht) und states einzelne Zustände dieser Teilfunktion.
                              Abweichen davon gibt es auch noch den Objekttyp folder, der zum Gruppieren von States oder weiteren Ordnern dient, die nicht 1:1 in diese Struktur passen. Wäre für dich vermutlich der richtige Anwendungsfall, kann aber dennoch nicht mit deleteChannel gelöscht werden. Hättest du die zugehörigen Objekte angelegt, müsstest du sie neben den States per deleteObject löschen.

                              @apollon77 noch was hinzuzufügen?

                              Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                              PeoplesP 1 Antwort Letzte Antwort
                              0
                              • AlCalzoneA AlCalzone

                                @Peoples
                                Die "Ordner" sind nur virtuell, sobald alle States mit diesem ID-Abschnitt weg sind, sind die auch weg.

                                Streng genommen sollte keiner dieser "Ordner" ohne ein zugehöriges Objekt existieren. Objekte definieren unter anderem den Sinn dieses "Ordners" und Anzeigenamen, etc.. Die Objekttypen sind definiert unter https://www.iobroker.net/#en/documentation/dev/objectsschema.md?objecttypes

                                Die "klassische" Struktur, die wohl noch aus der Homematic-Welt stammt, ist device.channel.state, wobei ein device ein physisches Gerät beschreibt, channel eine Teilfunktion (z.B. Licht) und states einzelne Zustände dieser Teilfunktion.
                                Abweichen davon gibt es auch noch den Objekttyp folder, der zum Gruppieren von States oder weiteren Ordnern dient, die nicht 1:1 in diese Struktur passen. Wäre für dich vermutlich der richtige Anwendungsfall, kann aber dennoch nicht mit deleteChannel gelöscht werden. Hättest du die zugehörigen Objekte angelegt, müsstest du sie neben den States per deleteObject löschen.

                                @apollon77 noch was hinzuzufügen?

                                PeoplesP Offline
                                PeoplesP Offline
                                Peoples
                                schrieb am zuletzt editiert von
                                #16

                                @AlCalzone
                                Also ich hab jetzt zwar ewig gebraucht aber wenn ich es so mache:

                                adapter.getStates('Views.DemoView' + '.*', async function (err, states) {
                                        for (const idS in states) {            
                                            adapter.delObject(idS, function(err){
                                               // adapter.deleteState(idS, function(err){
                                               //     if (err) {
                                               //         adapter.log.error('cannot delete state : ' + idS + ' Error: ' + err);
                                               //     }
                                               // });
                                            });
                                            
                                        }
                                    });
                                    
                                

                                ist der Ordner samt Inhalt weg, die Frage die ich mir stelle ist nur ob es wirklich notwendig ist deleteState zu nutzen da mit dem nur delObject auch alles weg ist.

                                Ich beantworte keine Fragen zu Themen via PN

                                OliverIOO 1 Antwort Letzte Antwort
                                0
                                • PeoplesP Peoples

                                  @AlCalzone
                                  Also ich hab jetzt zwar ewig gebraucht aber wenn ich es so mache:

                                  adapter.getStates('Views.DemoView' + '.*', async function (err, states) {
                                          for (const idS in states) {            
                                              adapter.delObject(idS, function(err){
                                                 // adapter.deleteState(idS, function(err){
                                                 //     if (err) {
                                                 //         adapter.log.error('cannot delete state : ' + idS + ' Error: ' + err);
                                                 //     }
                                                 // });
                                              });
                                              
                                          }
                                      });
                                      
                                  

                                  ist der Ordner samt Inhalt weg, die Frage die ich mir stelle ist nur ob es wirklich notwendig ist deleteState zu nutzen da mit dem nur delObject auch alles weg ist.

                                  OliverIOO Offline
                                  OliverIOO Offline
                                  OliverIO
                                  schrieb am zuletzt editiert von
                                  #17

                                  @Peoples

                                  die logik in iobroker ist

                                  ein objekt hat 0 bis viele states
                                  ein state gehört immer zu einem objekt

                                  wenn du delState benutzt ist die objektdefinition immer noch da, auch wenn du das im objektbaum nicht mehr siehst. dort wird ein objekt nur angezeigt wenn es mindestens einen state hat.
                                  wenn du dann das objekt bspw neu mit einem anderen typ erzeugen willst, dann funktioniert das nicht. es gibt aberr auch keine fehlermeldung.

                                  bei der Erzeugung von objekten/states muss man 2 Sachen unterscheiden, die im objektbaum
                                  nicht gleich ersichtlich sind.

                                  1.) es gibt devices und channels, die eigene states haben
                                  bspw "meinadapter.0.devicename" oder "meinadapter.0.channelname"
                                  darunter kann es dann ein oder mehrere datenpunkte geben
                                  bspw "meinadapter.0.devicename.datenpunkt1" oder "meinadapter.0.devicename.datenpunkt2"
                                  Der Datenpunkt heißt in der internen Verwaltung genau so.
                                  channel und devices müssen separat gelöscht werden

                                  1. es gibt nur datenpunkte
                                    bspw "meinadapter.0.datenpunk1" oder "meinadapter.0.datenpunkt2"
                                    bspw "meinadapter.0.datenpunk1.datenpunkt11" oder "meinadapter.0.datenpunkt2.datenpunkt21"
                                    Der Datenpunkt heißt in der internen Verwaltung genau so.
                                    Wenn alle Unterdatenpunkte gelöscht sind, sind auch die "Ordner" weg

                                  Das was du als Ordner im Objektbaum siehst, wird nur in der Visualisierung so dargestellt, dass jeder Punkt ab Instanzbezeichnung zu einem eigenen Ordner interpretiert wird. Der Ordner existiert zumindest bei 2) so nirgends.

                                  Meine Adapter und Widgets
                                  TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                  Links im Profil

                                  AlCalzoneA 1 Antwort Letzte Antwort
                                  1
                                  • OliverIOO OliverIO

                                    @Peoples

                                    die logik in iobroker ist

                                    ein objekt hat 0 bis viele states
                                    ein state gehört immer zu einem objekt

                                    wenn du delState benutzt ist die objektdefinition immer noch da, auch wenn du das im objektbaum nicht mehr siehst. dort wird ein objekt nur angezeigt wenn es mindestens einen state hat.
                                    wenn du dann das objekt bspw neu mit einem anderen typ erzeugen willst, dann funktioniert das nicht. es gibt aberr auch keine fehlermeldung.

                                    bei der Erzeugung von objekten/states muss man 2 Sachen unterscheiden, die im objektbaum
                                    nicht gleich ersichtlich sind.

                                    1.) es gibt devices und channels, die eigene states haben
                                    bspw "meinadapter.0.devicename" oder "meinadapter.0.channelname"
                                    darunter kann es dann ein oder mehrere datenpunkte geben
                                    bspw "meinadapter.0.devicename.datenpunkt1" oder "meinadapter.0.devicename.datenpunkt2"
                                    Der Datenpunkt heißt in der internen Verwaltung genau so.
                                    channel und devices müssen separat gelöscht werden

                                    1. es gibt nur datenpunkte
                                      bspw "meinadapter.0.datenpunk1" oder "meinadapter.0.datenpunkt2"
                                      bspw "meinadapter.0.datenpunk1.datenpunkt11" oder "meinadapter.0.datenpunkt2.datenpunkt21"
                                      Der Datenpunkt heißt in der internen Verwaltung genau so.
                                      Wenn alle Unterdatenpunkte gelöscht sind, sind auch die "Ordner" weg

                                    Das was du als Ordner im Objektbaum siehst, wird nur in der Visualisierung so dargestellt, dass jeder Punkt ab Instanzbezeichnung zu einem eigenen Ordner interpretiert wird. Der Ordner existiert zumindest bei 2) so nirgends.

                                    AlCalzoneA Offline
                                    AlCalzoneA Offline
                                    AlCalzone
                                    Developer
                                    schrieb am zuletzt editiert von AlCalzone
                                    #18

                                    @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                    ein objekt hat 0 bis viele states

                                    Das stimmt so nicht ganz.
                                    Ein Objekt hat 0 oder 1 direkt zugeordneten State, kann aber im Fall von Device/Channel/Folder untergeordnete Objekte haben, die ihre eigenen States besitzen.

                                    @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                    dort wird ein objekt nur angezeigt wenn es mindestens einen state hat.

                                    Stimmt auch nicht:
                                    f34de1cb-dd73-4a66-bbd3-33c0a72252c6-grafik.png
                                    Alle 3 dieser Objekte haben keinen State.

                                    Ich denke du wirfst hier Objekte und die Baumstruktur im Admin durcheinander.

                                    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                                    OliverIOO 1 Antwort Letzte Antwort
                                    0
                                    • AlCalzoneA AlCalzone

                                      @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                      ein objekt hat 0 bis viele states

                                      Das stimmt so nicht ganz.
                                      Ein Objekt hat 0 oder 1 direkt zugeordneten State, kann aber im Fall von Device/Channel/Folder untergeordnete Objekte haben, die ihre eigenen States besitzen.

                                      @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                      dort wird ein objekt nur angezeigt wenn es mindestens einen state hat.

                                      Stimmt auch nicht:
                                      f34de1cb-dd73-4a66-bbd3-33c0a72252c6-grafik.png
                                      Alle 3 dieser Objekte haben keinen State.

                                      Ich denke du wirfst hier Objekte und die Baumstruktur im Admin durcheinander.

                                      OliverIOO Offline
                                      OliverIOO Offline
                                      OliverIO
                                      schrieb am zuletzt editiert von
                                      #19

                                      @AlCalzone
                                      hm, hab ich so unter 1) geschrieben.
                                      in iobroker gibt es doch keine folder, nur devices und channels.
                                      die ordner/folder werden nur in der darstellung so angezeigt.
                                      ein eigenständigen eintrag für ordern/folder gibt es nicht (ausser channel und devices)

                                      Meine Adapter und Widgets
                                      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                      Links im Profil

                                      AlCalzoneA 1 Antwort Letzte Antwort
                                      0
                                      • OliverIOO OliverIO

                                        @AlCalzone
                                        hm, hab ich so unter 1) geschrieben.
                                        in iobroker gibt es doch keine folder, nur devices und channels.
                                        die ordner/folder werden nur in der darstellung so angezeigt.
                                        ein eigenständigen eintrag für ordern/folder gibt es nicht (ausser channel und devices)

                                        AlCalzoneA Offline
                                        AlCalzoneA Offline
                                        AlCalzone
                                        Developer
                                        schrieb am zuletzt editiert von AlCalzone
                                        #20

                                        @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                        ein eigenständigen eintrag für ordern/folder gibt es nicht

                                        Doch! https://www.iobroker.net/#en/documentation/dev/objectsschema.md?objecttypes --> letzter Eintrag "folder"

                                        Hatte ich oben übrigens schon geschrieben.

                                        Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                                        OliverIOO 1 Antwort Letzte Antwort
                                        0
                                        • AlCalzoneA AlCalzone

                                          @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

                                          ein eigenständigen eintrag für ordern/folder gibt es nicht

                                          Doch! https://www.iobroker.net/#en/documentation/dev/objectsschema.md?objecttypes --> letzter Eintrag "folder"

                                          Hatte ich oben übrigens schon geschrieben.

                                          OliverIOO Offline
                                          OliverIOO Offline
                                          OliverIO
                                          schrieb am zuletzt editiert von
                                          #21

                                          @AlCalzone
                                          ah ok, noch nie was von typ folder in einem adapter gesehen.
                                          allerdings hab ich bisher noch keine vorteile gesehen, diese Unterscheidungen von devices, channels und folders zu treffen.
                                          in meinen adapter verwende ich mittlerweile immer nur states unterhalb einer adapter instanz.

                                          Meine Adapter und Widgets
                                          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                          Links im Profil

                                          AlCalzoneA 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

                                          767

                                          Online

                                          32.7k

                                          Benutzer

                                          82.3k

                                          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