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. [Aufruf] Welche guten JavaScripts setzt ihr ein?

NEWS

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

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

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

[Aufruf] Welche guten JavaScripts setzt ihr ein?

Geplant Angeheftet Gesperrt Verschoben JavaScript
91 Beiträge 31 Kommentatoren 31.2k Aufrufe 108 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.
  • SoundyS Soundy

    @ilovegym Danke für deine Bestätigung! Da bin ich mal richtig gespannt, heute sind die Batterien gekommen und sofort eingebaut. Mal sehen, wie lange es gut geht. ;-)

    ChaotC Offline
    ChaotC Offline
    Chaot
    schrieb am zuletzt editiert von
    #32

    Ich habe mittlerweile mein Klingelscript verändert weil das Klingeln in der Fritzbox doch teilweise sehr verzögert kam. Warum habe ich nicht herausfinden können. Deshalb wird das AVM Teil wohl so langsam ausgemustert werden.

    Aktuell klingele ich über einen Echo II der in der Küche steht. Theoretisch könnte ich auf allen Echos klingeln lassen, aber das ist bei mir baulich nicht nötig.
    Dazu wird in Alexa eine Routine angelegt und diese dann über den ioBroker gesteuert.

    var sperre = false;  //verhindert das doppeltes Drücken das Script stoppt
    var timeout1, timeout2, timeout3, timeout4, timeout5, timeout6, timeout7, timeout8, timeout9, timeout10, timeout11;
    var fs = require('fs');
    
    
    on({id: 'sonoff.0.Eingang.POWER2', val: true}, function (obj) {
      if(!sperre) {
        sperre = true;
        setState("alexa2.0.Echo-Devices.xxxxxxxxx.Routines.11242dac-bf4b-4ab1-9521-37fdf5dae51d", true);
     //Klingelt auf Alexa
        setState("alexa2.0.Echo-Devices.XXXXXXXXXXXXX.Routines.519a9af4-c186-4715-9e5d-cb4ac65c0c67", true);
    // Hier könnte man weitere Geräte zum Klingeln hinterlegen   
         // Speichert das erste Bild bei Klingeln
        exec('wget --output-document /tuer/alarm1.jpg \'http://192.168.xx.95:8765/picture/1/current/?_username=xxxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
        // Es wird 2500ms gewartet um dieses speichern auszuführen
        timeout1 = setTimeout(function () {
          // Und hier wird es versendet
          sendTo("email", "send", {
         text: '',
         to: 'xxxxxxxxxx@gmail.com',
         subject: 'Klingel',
         attachments:[
            {path: '/tuer/alarm1.jpg', cid: "file1"},
          ]
          });
          sendTo("email", "send", {
         text: '',
         to: 'xxxxxxxxxxx@gmail.com',
         subject: 'Klingel',
         attachments:[
            {path: '/tuer/alarm1.jpg', cid: "file1"},
          ]
          });
          
        }, 2500);
        
        // Nach dem ersten Bild wird nach 5000ms das nächste Bild gespeichert
        timeout2 = setTimeout(function () {
          exec('wget --output-document /tuer/alarm2.jpg \'http://192.168.xx.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
          // Es wird 2500ms gewartet um dieses speichern auszuführen
          timeout3 = setTimeout(function () {
            // Und hier wird es versendet
            sendTo("email", "send", {
         text: '',
         to: 'xxxxxxxxxx@gmail.com',
         subject: 'Klingel',
         attachments:[
            {path: '/tuer/alarm2.jpg', cid: "file1"},
          ]
            });
            sendTo("email", "send", {
         text: '',
         to: 'xxxxxxxxxx@gmail.com',
         subject: 'Klingel',
         attachments:[
            {path: '/tuer/alarm2.jpg', cid: "file1"},
          ]
          });
          
          }, 2500);
        }, 5000);
        
        timeout4 = setTimeout(function () {
          exec('wget --output-document /tuer/alarm3.jpg \'http://192.168.xx.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
        }, 10000);
       
       
        timeout5 = setTimeout(function () {
          exec('wget --output-document /tuer/alarm4.jpg \'http://192.168.xx.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
        }, 10000);
       
        }
    
         setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Neu/Tuer"}'); 
               // oder
               //setState("vis.0.control.instance", 'FFFFFFFF');
               //setState("vis.0.control.data",     'DemoView');
               //setState("vis.0.control.command",  'changeView'); // muss immer letzte sein
               
               // Setze View auf Kamerabild
                timeout6 = setTimeout(function () {
                          setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Neu/Info"}');
               }, 60000); // Nach 60 Sekunden, zeige wieder Start View
       
        timeout10 = setTimeout(function() {
           sperre = false;
        }, 5000); //Zeit für Klingelsperre 1.Zeile
        timeout11 = setTimeout(function () {
             const bild1 = fs.readFileSync('/tuer/alarm1.jpg');
             writeFile('0_userdata.0','alarm1.jpg', bild1);
             const bild2 = fs.readFileSync('/tuer/alarm2.jpg');
             writeFile('0_userdata.0','alarm2.jpg', bild2);
             const bild3 = fs.readFileSync('/tuer/alarm3.jpg');
             writeFile('0_userdata.0','alarm3.jpg', bild3);
             const bild4 = fs.readFileSync('/tuer/alarm4.jpg');
             writeFile('0_userdata.0','alarm4.jpg', bild4);
        }, 5000); 
    });
    
    


    Also könnte man das Script jetzt betiteln: Klingeln über Alexa

    ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

    1 Antwort Letzte Antwort
    0
    • C Offline
      C Offline
      CruziX
      schrieb am zuletzt editiert von
      #33

      Da ich nun eine Fritzbox habe, hier ein kleines Script was einen eingehendes Telefonanruf erkennt, eine Benachrichtigung vorbereitet und diese an Alexa weitergibt.
      Die Nachricht kann natürlich an beliebige Messenger oder sonstiges weitergegeben werden.
      https://github.com/xCruziX/ioBroker-tr064-Caller-Message/blob/main/README.md

      1 Antwort Letzte Antwort
      0
      • W Offline
        W Offline
        Worlik
        schrieb am zuletzt editiert von Worlik
        #34

        Ich hätte da was für die Kategorie Shelly. Damit in Blockly-Skripten zum Beispiel bei einem Trigger für einen Schaltzustand nicht einfach nur "Switch" steht, sondern man direkt den Gerätenamen, Kanalnamen und den Namen des Eigenschaftswertes sieht, habe ich etwas geskriptet. Dieses Skript updated den Common-Name der einzelnen Knoten der Shellygeräte, so das man dann sehr schön sehen kann, was genau im Blockly Skript geschrieben oder gelesen wird.

        var shellies = $('shelly.0.*.name');
        
        var generalTemplate = {
            'factoryResetFromSwitch': 'Firmwareupdate via Schalter',
            'firmware': 'Firmware Update verfügbar',
            'firmwareupdate': 'Firmware Update auslösen',
            'hostname': 'Hostname',
            'id': 'Gerätetyp',
            'mode': 'Modus',
            'name': 'Gerätename',
            'online': 'Verfügbar',
            'overtemperature': 'Überhitzt',
            'protocol': 'verwendetes Protokoll',
            'reboot': 'Neustarten',
            'rssi': 'WLAN-Empfang',
            'temperatureC': 'Gerätetemperatur in °C',
            'temperatureF': 'Gerätetemperatur in °F',
            'type': 'Gerätetyp',
            'uptime': 'Onlinezeit',
            'version': 'Firmware Version',
            'ext': 'externe Sensoren',
            'ext.humidity1': 'Luftfeuchtigkeit 1',
            'ext.humidity2': 'Luftfeuchtigkeit 2',
            'ext.humidity3': 'Luftfeuchtigkeit 3',
            'ext.temperatureC1': 'Temperatur 1 in °C',
            'ext.temperatureC2': 'Temperatur 2 in °C',
            'ext.temperatureC3': 'Temperatur 3 in °C',
            'ext.temperatureF1': 'Temperatur 1 in °F',
            'ext.temperatureF2': 'Temperatur 2 in °F',
            'ext.temperatureF3': 'Temperatur 3 in °F',
            'Shutter': 'Jalousiesteuerung',
            'Shutter.ButtonReverse': 'Button umkehren',
            'Shutter.ButtonType': 'Button-Typ',
            'Shutter.Close': 'Schließen',
            'Shutter.Duration': 'Dauer',
            'Shutter.Energy': 'Zähler',
            'Shutter.Open': 'Öffnen',
            'Shutter.Pause': 'Pausieren',
            'Shutter.Position': 'Position',
            'Shutter.Power': 'Momentanverbrauch',
            'Shutter.StopReason': 'Stoppgrund',
            'Shutter.state': 'Status',
        }
        
        var dimmerTemplate = {
            'AutoTimerOff': 'Ausschalttimer',
            'AutoTimerOn': 'Einschalttimer',
            'ButtonType': 'Button-Typ',
            'ChannelName': 'Kanalname',
            'Energy': 'Zähler',
            'Event1': 'letztes Ereignis rechts',
            'Event2': 'letztes Ereignis links',
            'EventCount1': 'Anzahl Ereignisse rechts',
            'EventCount2': 'Anzahl Ereignisse links',
            'Input1': 'rechter Schalter gedrückt',
            'Input2': 'linker Schalter gedrückt',
            'Power': 'Momentanverbrauch',
            'Switch': 'Schaltzustand',
            'brightness': 'Helligkeit',
            'longpush1': 'rechts lang gedrückt',
            'longpush2': 'links lang gedrückt',
            'mode': 'Modus',
        }
        
        var relayTemplate = {
            'AutoTimerOff': 'Ausschalttimer',
            'AutoTimerOn': 'Einschalttimer',
            'ButtonReverse': 'Button umkehren',
            'ButtonType': 'Button-Typ',
            'ChannelName': 'Kanalname',
            'Name': 'Kanalname',
            'Energy': 'Zähler',
            'Event': 'letztes Ereignis',
            'EventCount': 'Anzahl Ereignisse',
            'Input': 'Schalter gedrückt',
            'Power': 'Momentanverbrauch',
            'Switch': 'Schaltzustand',
            'Timer': 'Timer',
            'longpush': 'lang gedrückt',
            'longpushtime': 'Dauer langes drücken',
        }
        
        var updateCount = 0;
        
        console.log('Dem System sind ' + shellies.length + ' Geräte von Shelly bekannt.');
        
        shellies.each(
            function(id, i) {
                var shellyId = id.split(".").slice(0,-1).join(".");
                var lightsChannelName = $(shellyId + '.lights.ChannelName');
                var relay0ChannelName = lightsChannelName.length == 0 ? $(shellyId + '.Relay0.ChannelName') : [];
                var relay1ChannelName = relay0ChannelName.length > 0 ? $(shellyId + '.Relay1.ChannelName') : [];
                var relay2ChannelName = relay1ChannelName.length > 0 ? $(shellyId + '.Relay2.ChannelName') : [];
                var deviceName = getState(id).val;
                var obj = null;
                var relays = [];
        
                // Fallback für den i3 (dieser nutzt nicht ChannelName, sondern Name für den Kanalnamen)
                if(lightsChannelName.length == 0 && relay0ChannelName.length == 0) {
                  relay0ChannelName = lightsChannelName.length == 0 ? $(shellyId + '.Relay0.Name') : [];
                  relay1ChannelName = relay0ChannelName.length > 0 ? $(shellyId + '.Relay1.Name') : [];
                  relay2ChannelName = relay1ChannelName.length > 0 ? $(shellyId + '.Relay2.Name') : [];
                }
        
                for(const [key, value] of Object.entries(generalTemplate)) {
                    obj = getObject(shellyId + '.' + key);
        
                    if(obj && obj.common.name != (deviceName + ' ' + value).trim()) {
                        obj.common.name = (deviceName + ' ' + value).trim();
                        setObject(shellyId + '.' + key, obj);
                        updateCount++;
                    }
                }
        
                if(lightsChannelName.length > 0) {
                    var channelName = getState(lightsChannelName[0]).val;
        
                    if(channelName != deviceName)
                      channelName = deviceName + ' ' + channelName;
        
                    for(const [key, value] of Object.entries(dimmerTemplate)) {
                        obj = getObject(shellyId + '.lights.' + key);
        
                        if(obj && obj.common.name != (channelName + ' ' + value).trim()) {
                            obj.common.name = (channelName + ' ' + value).trim();
                            setObject(shellyId + '.lights.' + key, obj);
                            updateCount++;
                        }
                    }
                }
                
                if(relay0ChannelName.length > 0)
                    relays.push(getState(relay0ChannelName[0]).val);
        
                if(relay1ChannelName.length > 0)
                    relays.push(getState(relay1ChannelName[0]).val);
        
                if(relay2ChannelName.length > 0)
                    relays.push(getState(relay2ChannelName[0]).val);
        
                for(var i = 0; i < relays.length; i++) {
                    var channelName = relays[i];
        
                    if(channelName != deviceName)
                      channelName = deviceName + ' ' + channelName;
        
                    for(const [key, value] of Object.entries(relayTemplate)) {
                        obj = getObject(shellyId + '.Relay' + i + '.' + key);
        
                        if(obj && obj.common.name != (channelName + ' ' + value).trim()) {
                            obj.common.name = (channelName + ' ' + value).trim();
                            setObject(shellyId + '.Relay' + i + '.' + key, obj);
                            updateCount++;
                        }
                    }
                }
            }
        );
        
        console.log('Es wurden ' + updateCount + ' Objektnamen aktualisiert.');
        

        Ich hoffe meine Templates sind einigermaßen vollständig. Ich habe nur Shelly 1, Shelly 1PM, Shelly 2.5, Shelly Dimmer 2 und Shelly i3 hier zu Hause im Einsatz. Möglichweise werden weitere Templates benötigt oder die vorhandenen Templates oben im Skript müssen erweitert werden, um weitere Werte abzufragen.

        Das Skript kann einmal manuell gestartet werden, wenn man Shelly Geräte hinzugefügt oder umbenannt hat.

        Hier noch ein Beispiel in der Objekthierarchie:

        e230bd43-f96a-4b65-a24d-25e8c25cc2d6-image.png

        Und dann im Blockly Skript:

        ddd0f7cc-41f0-45c3-af09-6343c9aeb404-image.png

        1 Antwort Letzte Antwort
        3
        • T Tictactoo

          @Superdad Kein Problem.


          Folgendes Skript ist vielleicht für den ein oder anderen Benutzer des iot-Adapters interessant. Bei uns zu hause herrscht folgende Situation vor: Wir haben in drei Räumen eine Stehlampe stehen, weils betitelt mit dem Namen "Stehlampe im Spielzimmer", Stehlampe im Schlafzimmer" und "Stehlampe im Wohnzimmer". Da wir es müde waren in jedem Raum immer "Alexa, Stehlampe im Schlafzimmer an" usw zu sagen, habe ich den State "stehlampe_hack" im javascript-Adapter erstellt und anschließend per iot-Adapter als "Stehlampe" mit der Rolle "Licht" eingerichtet. In der On-Function fragt das Skript ab, ob sich die History von Alexa geändert hat. Trifft das zu, prüft es, ob die Worte Stehlampe an/aus, aber nicht die Namen der Zimmer gesagt wurden. Anschließend wird per Seriennummer gecheckt, aus welchem Zimmer die Anfrage kommt und dann entsprechend dort der State des jeweiligen Geräts geschaltet.

          Das ganze lässt sich natürlich auf diverse Geräte anwenden (Fernseher, normales Licht, Rollos usw) und muss entsprechend dafür angepasst werden.

          createState('stehlampe_hack', false);
          
          on({id: 'alexa2.0.History.json', change: "ne"}, function (obj) {
              var value = obj.state.val;
              var oldValue = obj.oldState.val;
          
              var valueArray = value.replace("{", "").replace("}", "").split(",");
          
              var calledEchoDevice = valueArray[1];
              var summary = valueArray[2];
          
              if (summary.toLowerCase().includes("stehlampe") && 
                  summary.toLowerCase().includes("an") &&
                  (!summary.toLowerCase().includes("spielzimmer") && !summary.toLowerCase().includes("wohnzimmer") && !summary.toLowerCase().includes("schlafzimmer")))
              {
                      if(calledEchoDevice.includes(wohnzimmer))
                      {
                          setState(stehlampeWohnzimmer + '.state', true); 
                      }
                      else if(calledEchoDevice.includes(spielzimmer))
                      {
                          setState(stehlampespielzimmer + '.state', true); 
                      }
                      else if(calledEchoDevice.includes(schlafzimmer))
                      {
                          setState(schlafzimmerstehlampe + '.state', true); 
                      }
              }
          
              if (summary.toLowerCase().includes("stehlampe") && 
                  summary.toLowerCase().includes("aus") &&
                  (!summary.toLowerCase().includes("spielzimmer") && !summary.toLowerCase().includes("wohnzimmer") && !summary.toLowerCase().includes("schlafzimmer")))
              {
                      if(calledEchoDevice.includes(wohnzimmer))
                      {
                          setState(stehlampeWohnzimmer + '.state', false); 
                      }
                      else if(calledEchoDevice.includes(spielzimmer))
                      {
                          setState(stehlampespielzimmer + '.state', false); 
                      }
                      else if(calledEchoDevice.includes(schlafzimmer))
                      {
                          setState(schlafzimmerstehlampe + '.state', false); 
                      }
              }
          });
          


          Folgendes Skript habe ich mit der Intention geschrieben, dass man nicht in der ganzen Wohnung Nachrichten auf Alexa bekommt, wenn zum Beispiel die Poste gekommen ist, es an der Tür klingelt oder ähnliches. Daher trackt das erste Skript, auf welchem Echo die letzte Aktivität in Form einer Eingabe statt fand, speichert die Seriennummer in seinem State, so dass man mit dem zweiten Skript eine Ausgabe auf diesem machen kann.

          createState("lastActivityIn");
          var lastActivityIn = "javascript.0.lastActivityIn";
          
          on({id: 'alexa2.0.History.serialNumber', change: "any"}, function (obj) {
              var value = obj.state.val;
              setState(lastActivityIn, value);
          });
          
          setState('alexa2.0.Echo-Devices.' +   getState('javascript.0.lastActivityIn').val  + '.Commands.speak', "Nachricht");
          

          Ich persönlich habe das Ganze dann noch etwas erweitert und bei allen BWM usw ebenfalls eine Tracking-Funktion eingebaut, die checkt, wo man zuletzt war und welcher Echo für diesen Bereich zuständig ist.


          Dieses Skript prüft per fritzbox-Adapter, ob jemand anruft und sendet dann eine Nachricht mit der Nummer des Anrufers per Telegram an den Benutzer.

          In meinem Fall habe ich zwei Nummern im Skript laufen, die ich getrennt überwache. Einen Anruf auf "1234567890" wird immer per Telegram angekündigt, ein Anruf auf "0987654321" nur dann, wenn die Security scharf geschaltet ist, was soviel bedeutet wie "Außer Haus".

          var state = 'fritzbox.0.message';
          
          on({id: state, change: "any"}, function (obj) {
             var lastValue = getState(state).val;
             
             if(lastValue.includes("RING") && lastValue.includes("1234567890"))
             {
                 var tempArray = lastValue.split(";");
                 var lastCallNumber = tempArray[3];
          
                 sendTo('telegram.0', 'Du hast einen Anruf von ' + lastCallNumber + ' auf deiner Geschäfsnummer bekommen.');   
             }
          
             if(lastValue.includes("RING") && lastValue.includes("0987654321") && getState('javascript.0.Security').val)
             {
                 var tempArray = lastValue.split(";");
                 var lastCallNumber = tempArray[3];
          
                 sendTo('telegram.0', 'Du hast einen Anruf von ' + lastCallNumber + ' bekommen.');  
             }
          });
          


          Wie der Titel schon sagt, zwei Skripte, die einen Rauchmelder (in meinem Fall einen Xiaomi Honeywell) prüft und gegebenenfalls entsprechend Alarm schlägt.

          In unserem Fall ist es wie folgt: Alle Echos geben im 5 Sekunden Takt über eine Gruppe eine Sprachnachricht in der ganzen Wohnung aus. Außerdem wird im zwei Sekunden-Takt mein Nachttischlicht an- und ausschaltet. Desweiteren sendet das Rauchmelder Skript eine Nachricht per Telegram, für den Fall, dass niemand zu Hause ist.

          createState('fireAlert', false);
          createState('fireAlertRoom', false);
          
          var room = "javascript.0.fireAlertRoom";
          
          on({id: 'javascript.0.fireAlert', val: true}, function (obj) {
              alarmOnAlexa();  
              notfallevakuierung(); 
          });
          
          function alarmOnAlexa(){
              if(getState('javascript.0.fireAlert').val)
              {
                  setState('alexa2.0.Echo-Devices.7dasd7as098sd98asd089.Commands.speak', 'Achtung! Im ' + getState(room).val + ' wurde eine Rauchentwicklung festgestellt!');
                  setTimeout(alarmOnAlexa, 5000);
              }
          }
          
          function notfallevakuierung(){ 
              if(getState('javascript.0.fireAlert').val)
              {
                  if(getState(nachttischlicht + '.state').val)
                  {
                      setState(nachttischlicht + '.state', false);
                  }
                  else
                  {
                      setState(nachttischlicht + '.state', true);
                  }
          
                  setTimeout(notfallevakuierung, 2000);
              }
          }
          
          var sensorID = rauchmelderAnkleidezimmer;
          var room = "Ankleidezimmer";
          
          on({id: sensorID + '.detected', val: true}, function (obj) {
              setState('javascript.0.fireAlert', true); 
              setState('javascript.0.fireAlertRoom', room);
              sendTo('telegram.0', 'ALARM! Im ' + room +  ' wurde eine Rauchentwicklung festgestellt.');
          });
          
          

          tobasiumT Offline
          tobasiumT Offline
          tobasium
          schrieb am zuletzt editiert von
          #35

          @Tictactoo Hallo, dein skript macht mich neugierig aber ich Blicke das mit den Variablen nicht:

          var sensorID = rauchmelderAnkleidezimmer;
          var room = "Ankleidezimmer";

          Wie kann ich diese Festlegen? Bin für jede Hilfe Dankbar.

          T 1 Antwort Letzte Antwort
          0
          • tobasiumT tobasium

            @Tictactoo Hallo, dein skript macht mich neugierig aber ich Blicke das mit den Variablen nicht:

            var sensorID = rauchmelderAnkleidezimmer;
            var room = "Ankleidezimmer";

            Wie kann ich diese Festlegen? Bin für jede Hilfe Dankbar.

            T Offline
            T Offline
            Tictactoo
            schrieb am zuletzt editiert von
            #36

            @tobasium Hi, ich hab mir ein gobales Skript angelegt, in der ich alle Geräte eintrage mit ihrer ID, so dass ich gleiche Geräte in verschiedenen Skripten nicht alle von Hand ändern muss. Effektiv kannst du bei sensorID lediglich die ID des Zigbeegeräts angeben ("zigbee.0.XXXX"). Den Raum änderst du einfach in dem du den String umschreibst. Alternativ könnte man auch das Enum des Zigbeegeräts auslesen.

            Hoffe, dass dir das hilft!

            tobasiumT 1 Antwort Letzte Antwort
            1
            • T Tictactoo

              @tobasium Hi, ich hab mir ein gobales Skript angelegt, in der ich alle Geräte eintrage mit ihrer ID, so dass ich gleiche Geräte in verschiedenen Skripten nicht alle von Hand ändern muss. Effektiv kannst du bei sensorID lediglich die ID des Zigbeegeräts angeben ("zigbee.0.XXXX"). Den Raum änderst du einfach in dem du den String umschreibst. Alternativ könnte man auch das Enum des Zigbeegeräts auslesen.

              Hoffe, dass dir das hilft!

              tobasiumT Offline
              tobasiumT Offline
              tobasium
              schrieb am zuletzt editiert von
              #37

              @Tictactoo Danke. Wie sieht den globales script den aus. Wäre cool das mal zu sehen.

              Danke vorab

              T 1 Antwort Letzte Antwort
              0
              • tobasiumT tobasium

                @Tictactoo Danke. Wie sieht den globales script den aus. Wäre cool das mal zu sehen.

                Danke vorab

                T Offline
                T Offline
                Tictactoo
                schrieb am zuletzt editiert von
                #38

                @tobasium Das Skript liegt im global-Order, denn man im Experternmodus sieht. Das Skirpt besteht nur aus Variablen und den jeweiligen IDs der Zigbeegeräte, die ich den Variablen zugewiesen hab. Sobald das Skript gespeichert ist, kann man die Variablen in jedem anderen Skript abrufen.

                1 Antwort Letzte Antwort
                0
                • T Offline
                  T Offline
                  Tictactoo
                  schrieb am zuletzt editiert von Tictactoo
                  #39

                  Hi zusammen,

                  ich bin grade dabei meine ganzen Skripte etwas zu überarbeiten und zusammen zu schrumpfen und dachte mir, ich teil das gern mit euch. Als erstes wäre hier mein überarbeitetes Pflanzenskript. Ich hab es mittlerweile eingedampft und ein Skript für alle Planzen zusammen. Der Unterschied zur vorherigen Version ist, dass das Skript sich nun alle Pflanzen selbst sucht, wenn sie der entsprechenden Enum-Funktion("enum.functions.plant") zugeordnet sind. Desweiteren wird immer um 0 Uhr nachts nach neuen Pflanzen gesucht wird. Außerdem werden die aktuellen Timer nun in einem State gespeichert, damit nach einem Reset des Adapters oder des Rechners nicht wieder alle losgehen. Die Namen werden bei diesem Skript aus dem Namen des jeweiligen States übernommen. Bei mir heißt beispielweise eine der Pflanzen "Flower care - Fikus benjamina (Weißer Sensor)". Per replace wird der jeweilige State und das das "Flower care -" entfernt.

                  Der einzige Nachteil ist, dass die Feuchtigkeit nicht mehr pro Pflanze gesetzt werden kann, sondern die Werte für alle Pfalnzen gelten. Mir persönlich ist es wurscht, weil 95% aller Pflanzen bei mir die gleiche Feuchtigkeit usw brauchen. Vermutlich könnte man das mit ein paar Kniffen aber auch irgendwie lösen, wenn man es will.

                  /////////////////////
                  ///   Parameter   ///
                  
                  var moistureMin = 15;
                  var moistureMax = 60;
                  
                  var fertilityMin = 350;
                  var fertilityMax = 2000;
                  
                  var temperatureMin = 10;
                  var temperatureMax = 32;
                  
                  /*var lightMin = 1500;
                  var lightMax = 6000;*/
                  
                  ////////////////////////////
                  ///   Lokale Variablen   ///
                  
                  var timer = {};
                  var timeouts = {};
                  
                  var moistureArray;
                  var fertilityArray;
                  var temperatureArray;
                  
                  var timerState = "javascript.0.plantTimer";
                  
                  ///////////////////////////////////
                  ///   Variablen initalisieren   ///
                  
                  if(getState(timerState).notExist)
                  {
                      createState("plantTimer", {type: "object"});
                  }
                  
                  setTimeout(function() {getPlants();}, 1000);
                  
                  //////////////////////
                  ///   Monitoring   ///
                  
                  setTimeout(function() {
                      //Moisture-Check
                      on({id: moistureArray, change: "ne"}, function (obj) {
                          timer = getState(timerState).val;
                  
                          if(!timer)
                              return;
                  
                          if(getState(obj.id).val < moistureMin && !timer[obj.id])
                          {
                              var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                              var pflanzenName = getObject(obj.id.replace('.moisture', "")).common.name.replace("Flower care - ", "");
                  
                              sendTo('telegram.0', 'Du solltest deinen ' + pflanzenName + ' im ' + raum + ' dringend gießen.');
                  
                              timer[obj.id] = true;
                              setState(timerState, {val: timer});
                              timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                          }
                      });
                  
                      //Fertility-Check
                      on({id: fertilityArray, change: "ne"}, function (obj) {
                          timer = getState(timerState).val;
                  
                          if(!timer)
                              return;
                  
                          if(getState(obj.id).val < fertilityMin && !timer[obj.id])
                          {
                              var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                              var pflanzenName = getObject(obj.id.replace('.fertility', "")).common.name.replace("Flower care - ", "");
                  
                              sendTo('telegram.0', 'Dein ' + pflanzenName + ' im ' + raum + ' könnte etwas Dünger vertragen.');
                              
                              timer[obj.id] = true;
                              setState(timerState, {val: timer});
                              timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                          }
                      });
                  
                  
                      //Temprature-Check
                      on({id: temperatureArray, change: "ne"}, function (obj) {  
                          timer = getState(timerState).val;
                  
                          if(!timer)
                              return;
                  
                          if(getState(obj.id).val < temperatureMin && !timer[obj.id])
                          {
                              var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                              var pflanzenName = getObject(obj.id.replace('.temperature', "")).common.name.replace("Flower care - ", "");
                  
                              sendTo('telegram.0', 'Deinem ' + pflanzenName + ' im ' + raum + ' ist es etwas zu kalt.');
                              
                              timer[obj.id] = true;
                              setState(timerState, {val: timer});
                              timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                          }
                      });
                  
                      schedule("0 0 * * *", function()
                      {
                          getPlants();
                      });
                  
                  }, 2000);
                  
                  function boolTimer(id){
                      timer = getState(timerState).val;
                      timer[id] = false;
                      log("Timer: " + id + " wurde zurückgeetzt!");
                      setState(timerState, {val: timer});
                  }
                  
                  function getPlants()
                  {
                      moistureArray = [];
                      fertilityArray = [];
                      temperatureArray = [];
                  
                      timer = getState(timerState).val;
                  
                      if(!timer)
                      {
                          timer = {};
                      }
                  
                      var plants = getObject("enum.functions.plant").common.members;
                      for(let i = 0; i < plants.length; i++) {
                          var moisture = plants[i] + '.moisture';
                          var fertility = plants[i] + '.fertility';
                          var temperature = plants[i] + '.temperature';
                  
                          moistureArray.push(moisture);
                          if(timer[moisture] == null)
                          {
                              timer[moisture] = false;  
                          }
                          try {
                              if (timer[moisture] && timeouts[moisture]._destroyed)
                              {
                                  timeouts[moisture] = setTimeout(function() {boolTimer(moisture)}, 14400000);
                              }            
                          }
                          catch(err) {
                              if(getState(moisture).val < moistureMin)
                              {
                                  timer[moisture] = false;
                              }
                  
                              if (timer[moisture])
                              {
                                  timeouts[moisture] = setTimeout(function() {boolTimer(moisture)}, 14400000);
                              }  
                          }
                  
                          fertilityArray.push(fertility);
                          if(timer[fertility] == null)
                          {
                              timer[fertility] = false;  
                          }
                          try {
                              if (timer[fertility] && timeouts[fertility]._destroyed)
                              {
                                  timeouts[fertility] = setTimeout(function() {boolTimer(fertility)}, 14400000);
                              }            
                          }
                          catch(err) {
                              if(getState(fertility).val < fertilityMin)
                              {
                                  timer[fertility] = false;
                              }
                  
                              if (timer[fertility])
                              {
                                  timeouts[fertility] = setTimeout(function() {boolTimer(fertility)}, 14400000);
                              }  
                          }
                  
                          temperatureArray.push(temperature);
                          if(timer[temperature] == null)
                          {
                              timer[temperature] = false;  
                          }
                          try {
                              if (timer[temperature] && timeouts[temperature]._destroyed)
                              {
                                  log(temperature);
                                  timeouts[temperature] = setTimeout(function() {boolTimer(temperature)}, 14400000);
                              }            
                          }
                          catch(err) {
                              if(getState(temperature).val < temperatureMin)
                              {
                                  timer[temperature] = false;
                              }
                              if (timer[temperature])
                              {              
                                  log(temperature);
                                  timeouts[temperature] = setTimeout(function() {boolTimer(temperature)}, 14400000);
                              }  
                          }
                      }
                  
                      log(timer);
                      setState(timerState, {val: timer});
                  }
                  

                  Update: Hab leider festgestellt, dass ich einen kleinen Fehler beim Programmieren gemacht habt und leider manche Timer mehrfach gesetzt werden. Ich teste grade einen Fix dafür und update es, wenn es klappt.

                  Update2: Wies aussieht läuft es nun wohl richtig! Auf V2 geupdatet.

                  Update3: Nochmal ein paar kleine Fehler gefunden! Auf V2.1 geupdatet.

                  Update4: Auf V3 geupdatet.

                  T 1 Antwort Letzte Antwort
                  1
                  • T Tictactoo

                    Hi zusammen,

                    ich bin grade dabei meine ganzen Skripte etwas zu überarbeiten und zusammen zu schrumpfen und dachte mir, ich teil das gern mit euch. Als erstes wäre hier mein überarbeitetes Pflanzenskript. Ich hab es mittlerweile eingedampft und ein Skript für alle Planzen zusammen. Der Unterschied zur vorherigen Version ist, dass das Skript sich nun alle Pflanzen selbst sucht, wenn sie der entsprechenden Enum-Funktion("enum.functions.plant") zugeordnet sind. Desweiteren wird immer um 0 Uhr nachts nach neuen Pflanzen gesucht wird. Außerdem werden die aktuellen Timer nun in einem State gespeichert, damit nach einem Reset des Adapters oder des Rechners nicht wieder alle losgehen. Die Namen werden bei diesem Skript aus dem Namen des jeweiligen States übernommen. Bei mir heißt beispielweise eine der Pflanzen "Flower care - Fikus benjamina (Weißer Sensor)". Per replace wird der jeweilige State und das das "Flower care -" entfernt.

                    Der einzige Nachteil ist, dass die Feuchtigkeit nicht mehr pro Pflanze gesetzt werden kann, sondern die Werte für alle Pfalnzen gelten. Mir persönlich ist es wurscht, weil 95% aller Pflanzen bei mir die gleiche Feuchtigkeit usw brauchen. Vermutlich könnte man das mit ein paar Kniffen aber auch irgendwie lösen, wenn man es will.

                    /////////////////////
                    ///   Parameter   ///
                    
                    var moistureMin = 15;
                    var moistureMax = 60;
                    
                    var fertilityMin = 350;
                    var fertilityMax = 2000;
                    
                    var temperatureMin = 10;
                    var temperatureMax = 32;
                    
                    /*var lightMin = 1500;
                    var lightMax = 6000;*/
                    
                    ////////////////////////////
                    ///   Lokale Variablen   ///
                    
                    var timer = {};
                    var timeouts = {};
                    
                    var moistureArray;
                    var fertilityArray;
                    var temperatureArray;
                    
                    var timerState = "javascript.0.plantTimer";
                    
                    ///////////////////////////////////
                    ///   Variablen initalisieren   ///
                    
                    if(getState(timerState).notExist)
                    {
                        createState("plantTimer", {type: "object"});
                    }
                    
                    setTimeout(function() {getPlants();}, 1000);
                    
                    //////////////////////
                    ///   Monitoring   ///
                    
                    setTimeout(function() {
                        //Moisture-Check
                        on({id: moistureArray, change: "ne"}, function (obj) {
                            timer = getState(timerState).val;
                    
                            if(!timer)
                                return;
                    
                            if(getState(obj.id).val < moistureMin && !timer[obj.id])
                            {
                                var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                                var pflanzenName = getObject(obj.id.replace('.moisture', "")).common.name.replace("Flower care - ", "");
                    
                                sendTo('telegram.0', 'Du solltest deinen ' + pflanzenName + ' im ' + raum + ' dringend gießen.');
                    
                                timer[obj.id] = true;
                                setState(timerState, {val: timer});
                                timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                            }
                        });
                    
                        //Fertility-Check
                        on({id: fertilityArray, change: "ne"}, function (obj) {
                            timer = getState(timerState).val;
                    
                            if(!timer)
                                return;
                    
                            if(getState(obj.id).val < fertilityMin && !timer[obj.id])
                            {
                                var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                                var pflanzenName = getObject(obj.id.replace('.fertility', "")).common.name.replace("Flower care - ", "");
                    
                                sendTo('telegram.0', 'Dein ' + pflanzenName + ' im ' + raum + ' könnte etwas Dünger vertragen.');
                                
                                timer[obj.id] = true;
                                setState(timerState, {val: timer});
                                timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                            }
                        });
                    
                    
                        //Temprature-Check
                        on({id: temperatureArray, change: "ne"}, function (obj) {  
                            timer = getState(timerState).val;
                    
                            if(!timer)
                                return;
                    
                            if(getState(obj.id).val < temperatureMin && !timer[obj.id])
                            {
                                var raum = getObject(obj.id, 'rooms').enumNames[0].de;
                                var pflanzenName = getObject(obj.id.replace('.temperature', "")).common.name.replace("Flower care - ", "");
                    
                                sendTo('telegram.0', 'Deinem ' + pflanzenName + ' im ' + raum + ' ist es etwas zu kalt.');
                                
                                timer[obj.id] = true;
                                setState(timerState, {val: timer});
                                timeouts[obj.id] = setTimeout(function() {boolTimer(obj.id)}, 14400000);
                            }
                        });
                    
                        schedule("0 0 * * *", function()
                        {
                            getPlants();
                        });
                    
                    }, 2000);
                    
                    function boolTimer(id){
                        timer = getState(timerState).val;
                        timer[id] = false;
                        log("Timer: " + id + " wurde zurückgeetzt!");
                        setState(timerState, {val: timer});
                    }
                    
                    function getPlants()
                    {
                        moistureArray = [];
                        fertilityArray = [];
                        temperatureArray = [];
                    
                        timer = getState(timerState).val;
                    
                        if(!timer)
                        {
                            timer = {};
                        }
                    
                        var plants = getObject("enum.functions.plant").common.members;
                        for(let i = 0; i < plants.length; i++) {
                            var moisture = plants[i] + '.moisture';
                            var fertility = plants[i] + '.fertility';
                            var temperature = plants[i] + '.temperature';
                    
                            moistureArray.push(moisture);
                            if(timer[moisture] == null)
                            {
                                timer[moisture] = false;  
                            }
                            try {
                                if (timer[moisture] && timeouts[moisture]._destroyed)
                                {
                                    timeouts[moisture] = setTimeout(function() {boolTimer(moisture)}, 14400000);
                                }            
                            }
                            catch(err) {
                                if(getState(moisture).val < moistureMin)
                                {
                                    timer[moisture] = false;
                                }
                    
                                if (timer[moisture])
                                {
                                    timeouts[moisture] = setTimeout(function() {boolTimer(moisture)}, 14400000);
                                }  
                            }
                    
                            fertilityArray.push(fertility);
                            if(timer[fertility] == null)
                            {
                                timer[fertility] = false;  
                            }
                            try {
                                if (timer[fertility] && timeouts[fertility]._destroyed)
                                {
                                    timeouts[fertility] = setTimeout(function() {boolTimer(fertility)}, 14400000);
                                }            
                            }
                            catch(err) {
                                if(getState(fertility).val < fertilityMin)
                                {
                                    timer[fertility] = false;
                                }
                    
                                if (timer[fertility])
                                {
                                    timeouts[fertility] = setTimeout(function() {boolTimer(fertility)}, 14400000);
                                }  
                            }
                    
                            temperatureArray.push(temperature);
                            if(timer[temperature] == null)
                            {
                                timer[temperature] = false;  
                            }
                            try {
                                if (timer[temperature] && timeouts[temperature]._destroyed)
                                {
                                    log(temperature);
                                    timeouts[temperature] = setTimeout(function() {boolTimer(temperature)}, 14400000);
                                }            
                            }
                            catch(err) {
                                if(getState(temperature).val < temperatureMin)
                                {
                                    timer[temperature] = false;
                                }
                                if (timer[temperature])
                                {              
                                    log(temperature);
                                    timeouts[temperature] = setTimeout(function() {boolTimer(temperature)}, 14400000);
                                }  
                            }
                        }
                    
                        log(timer);
                        setState(timerState, {val: timer});
                    }
                    

                    Update: Hab leider festgestellt, dass ich einen kleinen Fehler beim Programmieren gemacht habt und leider manche Timer mehrfach gesetzt werden. Ich teste grade einen Fix dafür und update es, wenn es klappt.

                    Update2: Wies aussieht läuft es nun wohl richtig! Auf V2 geupdatet.

                    Update3: Nochmal ein paar kleine Fehler gefunden! Auf V2.1 geupdatet.

                    Update4: Auf V3 geupdatet.

                    T Offline
                    T Offline
                    Tictactoo
                    schrieb am zuletzt editiert von Tictactoo
                    #40

                    Abend zusammen,

                    hier noch ein zweites überarbeitetes Skript. Hier haben wir meinen Heizungswächter. Dieser sammelt sich selbst alle 30 Minuten alle Heizungen ("enum.functions.heating") und Fenster-/Türkontakte("enum.functions.window_door_sensor") per enum-Funktion zusammen. Anschließend frägt das Skript ab, ob einer der Kontakte geöffnet/geschlossen wurde.

                    Wird ein Fenster/Tür geöffnet, werden alle Thermostate im Raum (per enum-Raum ermittelt) auf 5 Grad gestellt und ihre letzte Temperatur in einem State gespeichert. Werden Türen/Fenster wieder geschlossen, prüft das Skript, ob alle Kontakte im Raum geschlossen sind. Ist das der Fall, werden alle Thermostate wieder auf ihre ursprüngliche Temperatur gestellt.

                    //State initalisieren
                    if(getState("javascript.0.lastValueThermostate").notExist)
                    {
                       createState("lastValueThermostate", {type: "object"});
                    }
                    
                    var lastValues = getState("javascript.0.lastValueThermostate").val;
                    if(lastValues == null)
                    {
                       lastValues = {};
                    }
                    
                    //Thermostate und Kontakte initalisieren
                    var heatingEnums;
                    var thermostate;
                    var contact;
                    var contactRoom;
                    
                    getHeatingsAndContacts();
                    
                    //OnChange Events
                    on({id: contact, val: true}, function (obj) {
                       var value = obj.state.val;
                       var oldValue= obj.oldState.val;
                    
                       if (value == oldValue)
                           return;
                    
                       var raum = getObject(obj.id, 'rooms').enumIds[0];
                       var raumName = getObject(obj.id, 'rooms').enumNames[0].de;
                       var devices = thermostate[raum];
                    
                       if(devices.length < 1)
                           return;
                    
                       for(let i = 0; i < devices.length; i++) {
                           var device = devices[i];
                    
                           if(!getState(device + '.heating_setpnt_current').notExist)
                           {
                               if(getState(device + '.heating_setpnt_current').val > 5)
                               {
                                   log ("Tür/Fenster geöffnet. Temperatur im " + raumName + " auf 5 Grad gestellt.");
                                   lastValues = getState("javascript.0.lastValueThermostate").val;
                                   lastValues[device] = getState(device + '.heating_setpnt_current').val;
                                   setState("javascript.0.lastValueThermostate", {val: lastValues});
                                   setState(device + '.heating_setpnt_current', 5); 
                               }
                               else
                               {
                                   log ("2. Tür/Fenster geöffnet. Temperatur im " + raumName + " ist bereits auf 5 Grad gestellt.");
                               }
                           }
                           else
                           {
                               if(getState(device + '.target_temperature').val > 5)
                               {
                                   log ("Tür/Fenster geöffnet. Temperatur im " + raumName + " auf 5 Grad gestellt.");
                                   lastValues = getState("javascript.0.lastValueThermostate").val;
                                   lastValues[device] = getState(device + '.target_temperature').val;
                                   setState("javascript.0.lastValueThermostate", {val: lastValues});
                                   setState(device + '.target_temperature', 5); 
                               }
                               else
                               {
                                   log ("2. Tür/Fenster geöffnet. Temperatur im " + raumName + " ist bereits auf 5 Grad gestellt.");
                               }
                           }
                       }
                    });
                    
                    on({id: contact, val: false}, function (obj) {
                       var value = obj.state.val;
                       var oldValue= obj.oldState.val;
                    
                       if (value == oldValue)
                           return;
                    
                       var raum = getObject(obj.id, 'rooms').enumIds[0];
                       var raumName = getObject(obj.id, 'rooms').enumNames[0].de;
                       var devices = thermostate[raum];
                    
                       if(devices < 1)
                           return;
                    
                       var tempOpen = false;
                       var tempContacts = contactRoom[raum];
                       for(let i = 0; i < tempContacts.length; i++) {
                           if(getState(tempContacts[i] + ".opened").val)
                               tempOpen = true;
                       }
                    
                       if(!tempOpen)
                       {
                           for(let i = 0; i < devices.length; i++) {
                               var device = devices[i];
                    
                               log ("Tür/Fenster geschlossen. Temperatur im " + raumName + " auf " + lastValues[device] + " Grad gestellt.");
                               if(!getState(device + '.heating_setpnt_current').notExist)
                               {
                                   setState(device + '.heating_setpnt_current', lastValues[device]);
                               }
                               else
                               {
                                   setState(device + '.target_temperature', lastValues[device]);
                               }
                           }
                       } 
                       else
                       {
                           log ("Ein weiteres Tür/Fenster ist noch geöffnet. Temperatur im " + raumName + " bleibt unverändert.");
                       }
                    });
                    
                    //Schedule für neue Geräte alle 30 Minuten
                    
                    schedule("*/30 * * * *", function()
                    {
                       getHeatingsAndContacts();
                    });
                    
                    //Functions
                    
                    function getHeatingsAndContacts()
                    {
                       heatingEnums = getObject("enum.functions.heating").common.members;
                       thermostate = {};
                       for(let i = 0; i < heatingEnums.length; i++) {
                           
                           if(thermostate[getObject(heatingEnums[i], 'rooms').enumIds[0]] == null)
                           {
                               thermostate[getObject(heatingEnums[i], 'rooms').enumIds[0]] = [];   
                           }
                    
                           thermostate[getObject(heatingEnums[i], 'rooms').enumIds[0]].push(heatingEnums[i]);
                       }
                    
                       contact = getObject("enum.functions.window_door_sensor").common.members;
                       contactRoom = {};
                       for(let i = 0; i < contact.length; i++) {
                    
                           if(contactRoom[getObject(contact[i], 'rooms').enumIds[0]] == null)
                           {
                               contactRoom[getObject(contact[i], 'rooms').enumIds[0]] = [];   
                           }
                           contactRoom[getObject(contact[i], 'rooms').enumIds[0]].push(contact[i]);
                           contact[i] = contact[i] + ".opened";
                       }
                    }
                    

                    Da ich zuvor für jeden Raum ein eigenes Skript hatte, ist der Vorteil für ich hier, die Übersichtlichkeit des einen Skripts. Dadurch, dass der Schedule variabel die neuen Geräte hinzugefügt werden, ist natürlich auch schön, dass man nichts weiter tun muss als sie in Zigbee zu adden. In meinem Fall benutze ich ein Tuya TS0601 und vier Spirit SPZB0001. Entsprechend ist das Skirpt für deren States eingestellt. Per Anpassung des else if Blocks lassen sich theoretisch allerdings noch andere Thermostate ergänzen.

                    1 Antwort Letzte Antwort
                    0
                    • agreenA Offline
                      agreenA Offline
                      agreen
                      schrieb am zuletzt editiert von agreen
                      #41

                      Da mir dieser Post sehr gut gefällt, dachte ich trage etwas bei.
                      Hier ein Script von mir ... ich denke das ist sehr einfach zu verstehen.
                      Folgendes wird realisiert: Kombination Xiaomi Türkontake und Homematic Heizungsthermostate.
                      Sobald ein Fenster im Raus geöffnet wird, werden alle Heizkörper auf 5 Grad gesetzt ... siehe Script :-)

                      
                      //Balkontür
                      //mihome.0.devices.magnet_158d0001c1f0f0
                      //zigbee.0.00158d0001c1ccd4
                      
                      function WohnzimmerKuecheHeizung() {
                      
                         var FensterKontaktBalkon = getState('zigbee.0.00158d0001c1ccd4.opened'/*Is open*/).val;
                         var FensterKontaktKueche = getState('zigbee.0.00158d0003f1baec.opened'/*Is open*/).val;
                         var FensterKontaktEsstisch = getState('zigbee.0.00158d0001de7841.opened'/*Is open*/).val;
                      
                         if ((FensterKontaktBalkon == true) || (FensterKontaktEsstisch == true) || (FensterKontaktKueche == true))
                         {
                            
                             log ('Balkontür oder Fenster im Wohnraum wurde geöffnet');
                        
                             setState('hm-rpc.0.MEQ0450661.4.MANU_MODE'/*Hm-cc-rt-dn meq0450661:4 manu mode*/,5);
                             setState('hm-rpc.0.PEQ1312400.4.MANU_MODE'/*Hm-cc-rt-dn peq1312400:4 manu mode*/,5);
                             
                         }
                         else 
                         {
                             log('Alle Fenster im Wohnraum geschlosssen, Heizung auf Auto gestellt');
                         
                             setState('hm-rpc.0.PEQ1312400.4.AUTO_MODE'/*Hm-cc-rt-dn peq1312400:4 auto mode*/,true);
                             setState('hm-rpc.0.MEQ0450661.4.AUTO_MODE'/*Hm-cc-rt-dn meq0450661:4 auto mode*/,true);
                             
                         }
                      
                      }
                      
                      //Balkontür
                      on({id: 'zigbee.0.00158d0001c1ccd4.opened'/*Is open*/, change: "ne"}, function (obj) {
                            
                      var value = obj.state.val;
                      var oldValue = obj.oldState.val;
                       
                       WohnzimmerKuecheHeizung();
                       
                      });
                      
                      //Küchenfenster
                      on({id: 'zigbee.0.00158d0003f1baec.opened'/*Is open*/, change: "ne"}, function (obj) {
                            
                      var value = obj.state.val;
                      var oldValue = obj.oldState.val;
                       
                       WohnzimmerKuecheHeizung();
                       
                      });
                      
                      //EsstischFenster
                      on({id: 'zigbee.0.00158d0001de7841.opened'/*Is open*/, change: "ne"}, function (obj) {
                            
                      var value = obj.state.val;
                      var oldValue = obj.oldState.val;
                       
                       WohnzimmerKuecheHeizung();
                       
                      });
                      
                      

                      1 Antwort Letzte Antwort
                      0
                      • agreenA Offline
                        agreenA Offline
                        agreen
                        schrieb am zuletzt editiert von
                        #42

                        Hier noch eins ... Harmony Multimedia Steuerung
                        Das Script fängt den geänderten Status ab und führt verschiedene Funktionen aus (z.b. Nach Sonnenuntergang Ambilight einschalten, Subwoofer beim TV schauen ausschalten, etc.)

                        
                        //Dreambox ausschalten
                        function dreamaus () {
                           //wget -O - -q http://192.168.200.162/web/powerstate?newstate=1 | grep "\(<\|</\)e2instandby" | tr -d '\n' | sed "s/.*<e2instandby>\(.*\)<\/e2instandby.*/\\1\n/"
                           exec('/home/iobroker/scripte/dreamboxoff.sh');    
                        }
                        
                        //Subwoofer Netzteil
                        function subon () {
                           setState('sonoff.0.DVES_Subwoofer.POWER'/*DVES Subwoofer POWER*/, true);
                           
                           log('Subwoofer aktiviert');
                        }
                        
                        function suboff () {
                           setState("sonoff.0.DVES_Subwoofer.POWER"/*DVES_Subwoofer POWER*/, false);
                           log('Subwoofer deaktiviert');
                        }
                        
                        
                        //Ambilight Netzteil
                        function ambiS20on () {
                          
                           setState('sonoff.0.DVES_AmbiNetzteil.POWER'/*DVES AmbiNetzteil POWER*/, true);
                           log('Ambilight Netzteil eingeschaltet');
                        }
                        
                        function ambiS20off () {
                        
                           setState('sonoff.0.DVES_AmbiNetzteil.POWER'/*DVES AmbiNetzteil POWER*/, false);
                           log('Ambilight Netzteil ausgeschaltet');
                        }
                        
                        //Raspberry PI Kodi
                        function PiOn () {
                           setState('sonoff.0.DVES_Pi.POWER'/*DVES Pi POWER*/, true);
                           log('Raspberry Pi eingeschaltet');
                        }
                        
                        function PiOff () {
                           setState('sonoff.0.DVES_Pi.POWER'/*DVES Pi POWER*/, false);
                           log('Raspberry Pi ausgeschaltet');
                        }
                        
                        function ambian (){
                        
                        }
                        
                        function ambioff (){
                        
                        }
                        
                        on({id: "harmony.0.Wohnzimmer.activities.currentActivity"/*activity:currentActivity*/, change: "ne"}, function (obj) {
                         
                        var state=getState("harmony.0.Wohnzimmer.activities.currentActivity").val;
                        var heute = new Date();
                        var ZeitAktuel = getAstroDate("sunset", undefined, 0);
                        
                        log('Sonne geht unter um '+ZeitAktuel);
                        log('Aktueller Status lautet: '+state);
                        log('Aktuelle Zeit lautet: '+heute);
                        
                        switch (state) {
                           case 'Kodi':
                               PiOn();
                               if (heute > ZeitAktuel) {
                                   ambian ();
                               }
                               log('Kodi wurde aktiviert !!!');
                               subon ();
                           break;
                           
                           case 'Fernsehen':
                            
                               log('Fernsehen wurde aktiviert !');
                               suboff();
                         
                           break;
                        
                            case 'Smart_TV_wiedergeben':
                               log('TV Android gestartet');
                               suboff ();
                           break;        
                        
                            case 'Kodi':
                               log('Raspberry Netzteil eingeschaltet');
                               subon ();
                               ambian();
                           break;   
                        
                           case 'Spielen':
                               log('Xbox wurde eingeschaltet');
                               subon ();
                           break;
                        
                            case 'Wiedergabe_PS':
                               log('PS4 wurde eingeschaltet');
                               subon ();
                           break;
                        
                           case 'PowerOff':
                               ambioff ();
                               dreamaus ();
                               suboff();
                               PiOff();
                              
                           break;
                                 
                        }
                        

                        1 Antwort Letzte Antwort
                        1
                        • Z Offline
                          Z Offline
                          Zuki
                          schrieb am zuletzt editiert von
                          #43

                          Ich hab mir was gebastelt um per einfachem button Datenpunkt Harmony Aktivitäten über den Harmony Adapter zu triggern.
                          Weil ich faul bin mit möglichst wenig Code. Sieht jemand noch Optimierungspotential? Oder hat jemand der den Adapter kennt einfach ne bessere Idee?

                          var triggerButtonList = [
                             "0_userdata.0.harmony.PowerOff",
                             "0_userdata.0.harmony.Fernsehen",
                             "0_userdata.0.harmony.Radio",
                             "0_userdata.0.harmony.TVFilm",
                             "0_userdata.0.harmony.TVBeamer",
                             "0_userdata.0.harmony.BluRayTV",
                             "0_userdata.0.harmony.BluRayBeamer",
                             "0_userdata.0.harmony.ShieldTV",
                             "0_userdata.0.harmony.ShieldBeamer",
                             "0_userdata.0.harmony.SwitchTV",
                             "0_userdata.0.harmony.SwitchBeamer"
                          ];
                          
                          var dpMapping = {
                             "0_userdata.0.harmony.Fernsehen":"harmony.0.Harmony_Hub.activities.Fernsehen",
                             "0_userdata.0.harmony.Radio":"harmony.0.Harmony_Hub.activities.Radio",
                             "0_userdata.0.harmony.TVFilm":"harmony.0.Harmony_Hub.activities.TVFilm",
                             "0_userdata.0.harmony.TVBeamer":"harmony.0.Harmony_Hub.activities.TV_Beamer",
                             "0_userdata.0.harmony.BluRayTV":"harmony.0.Harmony_Hub.activities.BluRay_TV",
                             "0_userdata.0.harmony.BluRayBeamer":"harmony.0.Harmony_Hub.activities.BluRay_Beamer",
                             "0_userdata.0.harmony.ShieldTV":"harmony.0.Harmony_Hub.activities.MediaPlayer",
                             "0_userdata.0.harmony.ShieldBeamer":"harmony.0.Harmony_Hub.activities.MediaPlayer_Beamer",
                             "0_userdata.0.harmony.SwitchTV":"harmony.0.Harmony_Hub.activities.Switch_TV",
                             "0_userdata.0.harmony.SwitchBeamer":"harmony.0.Harmony_Hub.activities.Switch_Beamer"
                          }
                          
                          on({id: triggerButtonList, change: "any"}, function (dp)
                          {
                             if (dp.id == "0_userdata.0.harmony.PowerOff") {
                                 console.log(" === HarmonyScript: send Poweroff");
                                 setState("harmony.0.Harmony_Hub.activities.currentStatus", 0)
                             }
                             else {
                                 var harmonyActivity = dpMapping[dp.id];
                                 console.log(" === HarmonyScript: send trigger to " + harmonyActivity);
                                 setState(dpMapping[dp.id], 2)
                             }
                          });
                          

                          1 Antwort Letzte Antwort
                          0
                          • KusselinK Offline
                            KusselinK Offline
                            Kusselin
                            schrieb am zuletzt editiert von
                            #44

                            Hallo Zusammen,

                            ich möchte einfach mal fragen..weil ich mit Scripten nicht soviel am Hut habe....

                            kopier eich das ganze einfach als "Javascript" in meinen iobroker unter Scripts??

                            Oder kann ich diese auch mit dem Button "Importieren" einfügen....?

                            Natürlich muss der script dann noch an meien Geräte angepasst werden...

                            Über ne Info herzlichen Dank.

                            Gruss

                            wendy2702W 1 Antwort Letzte Antwort
                            -1
                            • KusselinK Kusselin

                              Hallo Zusammen,

                              ich möchte einfach mal fragen..weil ich mit Scripten nicht soviel am Hut habe....

                              kopier eich das ganze einfach als "Javascript" in meinen iobroker unter Scripts??

                              Oder kann ich diese auch mit dem Button "Importieren" einfügen....?

                              Natürlich muss der script dann noch an meien Geräte angepasst werden...

                              Über ne Info herzlichen Dank.

                              Gruss

                              wendy2702W Online
                              wendy2702W Online
                              wendy2702
                              schrieb am zuletzt editiert von
                              #45

                              @Kusselin
                              JavaScript kopieren
                              Blockly importieren

                              Bitte keine Fragen per PN, die gehören ins Forum!

                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              KusselinK 1 Antwort Letzte Antwort
                              0
                              • wendy2702W wendy2702

                                @Kusselin
                                JavaScript kopieren
                                Blockly importieren

                                KusselinK Offline
                                KusselinK Offline
                                Kusselin
                                schrieb am zuletzt editiert von
                                #46

                                @wendy2702 thank you

                                1 Antwort Letzte Antwort
                                0
                                • MicM Mic

                                  Hi,

                                  wie wäre es, wenn wir die hier in der ioBroker-Community enstandenen JavaScripts entsprechend sammeln und die Liste entsprechend pflegen?

                                  Voraussetzung für die Aufnahme in dieser Liste: Einfach verwendbar, auch ohne wirklicher JavaScript-Kenntnisse. Und entsprechender Use-Case vorhanden, der nicht allzu individuell ist.

                                  Nun seid ihr dran:
                                  Bitte postet Links zu Scripts, die hier aufgenommen werden sollten. Eine Begründung dazu, also warum aufnehmen, wäre auch noch gut. Danke!
                                  Bitte am besten immer Link zum Original-Script hier im Forum, falls ihr Scripts hier direkt postet.


                                  P.S. Weitere interessante Links

                                  • ioBroker JavaScript-Functions: Dokumentation
                                  • Hilfreiche ioBroker JavaScript-Funktionen
                                  • javascript.info: Gutes JavaScript-Tutorial

                                  Zu den Kategorien

                                  Scripts der Kategorie A erfüllen Folgendes:

                                  1. Der Ersteller pflegt regelmäßig das Script
                                  2. Es gibt einen Forum-Thread für User-Feedback, der verlinkt ist.
                                  3. Optional, jedoch gewünscht :-) : das Script ist auf Github veröffentlicht und versioniert.

                                  Gerade Scripts der Kategorie A sind auch potentielle Kandidaten für die Umwandlung in einen neuen Adapter.

                                  Scripts der Kategorie B sind alle restlichen Scripts, die diese Kriterien nicht erfüllen. Diese sind dennoch einfach verwendbar ohne tiefer JavaScript-Kenntnisse und es ist ebenso ein entsprechender Use-Case vorhanden, der nicht allzu individuell ist.
                                  Achtung: Scripts der Kategorie B sind nicht unbedingt durch mehrere Anwender getestet worden, sondern wurden teils einfach ohne näherer Prüfung hier übernommen!

                                  :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign:

                                  Scripts Kategorie A

                                  :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign:

                                  Anwesenheit

                                  Aktuelles Script: Github
                                  ioBroker-Forum-Thread: Anwesenheitssteuerung mit TR-064-Community-Adapter

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Geofency-Skript: über PHP-Webspace an ioBroker

                                  Bewegungsmelder

                                  Javascript, mit dem die mittels Mihome-Adapter eingebundenen Xiaomi Aqara Sensoren entsprechend Geräte steuern, z.B.:

                                  • Gerät/Licht an bei Bewegung
                                  • Dabei: optional Gerät/Licht wieder ausschalten, falls nach X Minuten keine Bewegung mehr
                                  • Dabei: optional nur zwischen bestimmten Zeiten schalten (z.B. nur zwischen 7:00-9:00 und 18:-23:00)
                                  • Dabei: optional nur schalten, falls gemessene Lichtstärke in Lux nicht über Schwellwert (damit z.B. bei ausreichender Helligkeit kein Licht eingeschaltet wird).

                                  Die Konfiguration sollte selbsterklärend sein. Es können beliebig viele Bewegungsmelder damit gesteuert werden, die jeweils unterschiedlich konfiguriert werden können.

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Bewegungsmelder Xiaomi Aqara: Geräte/Lichter steuern

                                  Heizung

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Homematic IP Thermostate mit CCU: Externe Temperatursensoren (z.B. Xiaomi, etc.) einbinden mittels Offset-Setzen

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Homematic IP Thermostate: Urlaubssteuerung über VIS

                                  ioBroker-Forum-Thread: Vorlage: Ventilsteuerung mit PWM-Ansatz für Fussbodenheizungen/IR-Panele o.ä.

                                  Multimedia

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Philips-TV-Adapter

                                  Benötigt den Sonos-Adapter.

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Script für Sonos-Adapter

                                  System

                                  ioBroker-Forum-Thread: Script - Info über Datenpunkte sammeln


                                  Der ioBroker loggt alle Aktionen der Adapter und Scripte entsprechend mit, einzusehen in der ioBroker-Administration, linke Seite Menüpunkt "Log".
                                  Dieses Script bietet folgendes:

                                  • Log im VIS darstellen: Entsprechend gefiltert, also etwa nur Warnungen und Fehler, nur Ausgaben eines bestimmten Adapters, usw.
                                  • Auf Log-Ereignisse agieren
                                    Dabei nimmt das Script jeden neuen Logeintrag des ioBrokers und wendet entsprechend gesetzte Filter an,
                                    um den Eintrag dann in den entsprechenden Datenpunkten dieses Scripts abzulegen.
                                    Es stehen auch JSON-Datenpunkte zur Verfügung, mit diesen kann im vis eine Tabelle ausgegeben werden (z.B. über das Widget 'basic - Table').

                                  Aktuelles Script: ioBroker Log-Script
                                  ioBroker-Forum-Thread: Vorlage: Log-Datei aufbereiten für VIS

                                  Visualisierung

                                  ioBroker-Forum-Thread: Material Design Widgets: Adapter Status
                                  Material Design Widgets Adapter: https://github.com/Scrounger/ioBroker.vis-materialdesign

                                  Neu:
                                  Das Log-Script bietet eine Alexa-History-Integration. Hier veröffentlicht: https://forum.iobroker.net/post/386960

                                  Log-Script: Installation und Einrichtung (Github)
                                  Zusätzliches Script für Alexa: Erklärung im Forum und auf Github

                                  Alt:
                                  Aktuelles Script: Github
                                  ioBroker-Forum-Thread: Vorlage: Alexa-History-Befehle in VIS anzeigen

                                  ioBroker-Forum-Thread: Script: Alexa Listen pflegen und Anzeigen

                                  ioBroker-Forum-Thread: HTML Tabelle für BackItUp Adapter

                                  ioBroker-Forum-Thread: Script für Tabelle der Batterie-Zustände

                                  ioBroker-Forum-Thread: Vorlage: Zeit herunterzählen bis Google-Termin eintritt

                                  ioBroker-Forum-Thread: Script: Eieruhr

                                  Script: Google Charts

                                  ioBroker-Forum-Thread: Vorlage: Google Charts Beispiel

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Google Tabelle in ioBroker-Datenpunkte

                                  Script: ioB-Lebensmittelwarnung

                                  ioBroker-Forum-Thread: Javascript für Warnungen von Lebensmittelwarnung


                                  Der ioBroker loggt alle Aktionen der Adapter und Scripte entsprechend mit, einzusehen in der ioBroker-Administration, linke Seite Menüpunkt "Log".
                                  Dieses Script bietet folgendes:

                                  • Log im VIS darstellen: Entsprechend gefiltert, also etwa nur Warnungen und Fehler, nur Ausgaben eines bestimmten Adapters, usw.
                                  • Auf Log-Ereignisse agieren
                                    Dabei nimmt das Script jeden neuen Logeintrag des ioBrokers und wendet entsprechend gesetzte Filter an,
                                    um den Eintrag dann in den entsprechenden Datenpunkten dieses Scripts abzulegen.
                                    Es stehen auch JSON-Datenpunkte zur Verfügung, mit diesen kann im vis eine Tabelle ausgegeben werden (z.B. über das Widget 'basic - Table').

                                  Aktuelles Script: ioBroker Log-Script
                                  ioBroker-Forum-Thread: Vorlage: Log-Datei aufbereiten für VIS

                                  ioBroker-Forum-Thread: https://forum.iobroker.net/topic/30885/vorlage-mdcss-v2-iobroker-log-in-vis-anzeigen

                                  Es wird das Material Design CSS benötigt.

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: Pflanzen gießen - Erinnerung (für VIS, keine Hardware erforderlich)

                                  ioBroker-Forum-Thread: Material Design Widgets: Skript Status

                                  Von @Negalein hier in diesem Thread gepostet: https://forum.iobroker.net/post/381494

                                  Aktuelles Script (hier im Thread): https://forum.iobroker.net/post/373292

                                  Link zum Thema: Skripten des E-Control Spritpreisrechners

                                  Aktuelles Script: Github

                                  ioBroker-Forum-Thread: Vorlage: VIS: View durch Pin schützen

                                  ioBroker-Forum-Thread: Variable Zeitsteuerung mit VIS Editor

                                  ioBroker-Forum-Thread: Vorlage: Zeitschaltuhr mit 4 Zyklen ein aus einstellbar in vis inkl. Astro und manuell auto umschaltung

                                  Windows


                                  Script: Github
                                  ioBroker-Forum-Thread: Windows-Steuerung
                                  Software GetAdmin: Software GetAdmin (credits to Vladimir Vilisov)


                                  :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign:

                                  Scripts Kategorie B

                                  :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign: :heavy_minus_sign:
                                  Im Gegensatz zu Scripts der Kategorie A sind diese Scripts hier teils nur einmalig veröffentlicht worden, nicht unbedingt regelmäßig vom Ersteller gepflegt/aktualisiert und es gibt nicht unbedingt einen Forum-Thread für User-Feedback für das Script.
                                  Achtung: Diese Scripts sind teils auch ungetestet bzw. nur vom Ersteller getestet worden.


                                  Alexa

                                  (Weitere Alexa-Scripts siehe auch unter "Kategorie A - Visualisierung")

                                  ioBroker-Forum-Thread: Script "LichtAn": Erkennt von welchem Echo-Gerät Befehl kommt

                                  Von Tictactoo hier in diesem Thread gepostet: https://forum.iobroker.net/post/376463

                                  Bewegungsmelder

                                  Von @Tictactoo hier in diesem Thread gepostet.

                                  1. Aqara/Xiaomi-Bewegungssensor schaltet Zigbee-Device mit .state
                                  2. Aqara/Xiaomi-Bewegungssensor schaltet Zigbee-Lampe mit .brightness

                                  Hardware generell

                                  ioBroker-Forum-Thread: Vorlage: Script und VIS: Druckerpatronen Zustand

                                  Basierend auf Vorlage: Script und VIS: Druckerpatronen Zustand

                                  Aktuelles Script (hier im Thread): https://forum.iobroker.net/post/373292

                                  Ursprünglich hier gepostet: https://forum.iobroker.net/topic/669/vorlage-script-und-vis-druckerpatronen-zustand/5

                                  Von @BoBeRzE hier in diesem Thread gepostet: https://forum.iobroker.net/post/383430

                                  Von @charakterkopf in diesem Thread gepostet.

                                  Link: https://forum.iobroker.net/post/373269

                                  Von @Chaot hier in diesem Thread gepostet: https://forum.iobroker.net/post/392751

                                  Von @Tictactoo hier in diesem Thread gepostet.
                                  MiFlora Pflanzensensor mit Telegram Benachrichtigung

                                  Von @charakterkopf in diesem Thread gepostet.

                                  Link: https://forum.iobroker.net/post/373275

                                  System

                                  Hier im Thread veröffentlicht: Dieses Skript Räumt in den Räumen und Funktionen auf
                                  Script auf Github: https://github.com/xCruziX/ioBroker-Clean-Enums

                                  Telegram, Alarm

                                  Von @Nahasapee - Link: https://github.com/Nahasapeemapetilon/MyTelegramMenu

                                  Von Tictactoo hier in diesem Thread gepostet: https://forum.iobroker.net/post/376463

                                  Von Tictactoo hier in diesem Thread gepostet: https://forum.iobroker.net/post/376463

                                  Visualisierung

                                  ioBroker-Forum-Posting: Sidebar in VIS

                                  Zeitschaltuhr

                                  ioBroker-Forum-Thread: Time Of Day - Design Pattern

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

                                  @mic
                                  Ich habe vor langer Zeit mal ein Script geschrieben, das mir zum einen nach Zeit X auf die HomeView zurück springt und eine Slideshow der views ermöglicht.
                                  Vielleicht magst du es mit aufnehmen, verwende ich heute noch.
                                  [ https://forum.iobroker.net/topic/20876/vorlage-automatischer-view-wechsel-u-slideshow ] (https://forum.iobroker.net/topic/20876/vorlage-automatischer-view-wechsel-u-slideshow)

                                  Ich beantworte keine Fragen zu Themen via PN

                                  1 Antwort Letzte Antwort
                                  0
                                  • Sven SchumacherS Offline
                                    Sven SchumacherS Offline
                                    Sven Schumacher
                                    schrieb am zuletzt editiert von Sven Schumacher
                                    #48

                                    LetsEncrypt Zertifikate für z.B. Grafana oder andere auf dem gleichen Host nutzbar machen.

                                    IOBROKER verweist auf den ACME-Adapter um Zertifikate für ADMIN zu erzeugen.
                                    Allerdings hat man regelmäßig z.B. Grafana oder andere Adapter/Dienste laufen, die auch ein Zertifikat brauchen und das über den Weg nicht können.

                                    ACME legt die Zertifikate in einem JSON unter system.certificates ab. Sogar im Klartext.
                                    Also habe ich Script erzeugt, welches diese dort extrahiert und unter /opt/iobroker/certificates ablegt. Benannt nach dem Schema
                                    [collection]_key.pem
                                    [collection]_cert.pem
                                    [collection]_chain.pem

                                    Von dem Ort aus kann man das nun weiter verwenden.

                                    Das Script erzeugt die Keys beim Start und danach läuft es alle 24h. Nicht übermäßig kompliziert, aber nützlich.

                                    const fs = require('fs');
                                    const path = '/opt/iobroker/certificates/';  // Übliches Verzeichnis für Zertifikate
                                    
                                    // Funktion zum Speichern der Zertifikatsdateien
                                    function speichereZertifikate(collectionName, privateKey, publicCert, chainCert) {
                                        // Erstellen des Verzeichnisses, falls es nicht existiert
                                        if (!fs.existsSync(path)) {
                                            fs.mkdirSync(path, { recursive: true });
                                        }
                                    
                                        // Dateien mit dem Collection-Namen speichern
                                        const privateKeyPath = `${path}${collectionName}_key.pem`;
                                        const publicCertPath = `${path}${collectionName}_cert.pem`;
                                        const chainCertPath = `${path}${collectionName}_chain.pem`;
                                    
                                        // Speichern des privaten Schlüssels
                                        fs.writeFileSync(privateKeyPath, privateKey);
                                        console.log(`Privater Schlüssel gespeichert unter: ${privateKeyPath}`);
                                    
                                        // Speichern des Zertifikats
                                        fs.writeFileSync(publicCertPath, publicCert);
                                        console.log(`Zertifikat gespeichert unter: ${publicCertPath}`);
                                    
                                        // Falls eine Zertifikatskette vorhanden ist, diese speichern
                                        if (chainCert) {
                                            fs.writeFileSync(chainCertPath, chainCert);
                                            console.log(`Zertifikatskette gespeichert unter: ${chainCertPath}`);
                                        } else {
                                            console.log('Keine Zertifikatskette für die Collection: ' + collectionName + ' gefunden.');
                                        }
                                    }
                                    
                                    // Funktion zum Abrufen und Speichern der Zertifikate aus allen Collections
                                    function verarbeiteZertifikate() {
                                        getObject('system.certificates', function (err, obj) {
                                            if (err || !obj || !obj.native || !obj.native.collections) {
                                                console.log('Fehler: Zertifikatssammlungen konnten nicht abgerufen werden.');
                                                return;
                                            }
                                    
                                            const collections = obj.native.collections;
                                    
                                            // Alle Collections durchlaufen
                                            Object.keys(collections).forEach(function (collectionName) {
                                                const collection = collections[collectionName];
                                    
                                                if (collection.key && collection.cert) {
                                                    // Privater Schlüssel und Zertifikat aus der Collection extrahieren
                                                    const privateKey = collection.key;
                                                    const publicCert = collection.cert;
                                    
                                                    // Zertifikatskette extrahieren, falls vorhanden
                                                    const chainCert = collection.chain ? collection.chain.join('\n') : null;
                                    
                                                    // Zertifikate mit dem dynamischen Collection-Namen speichern
                                                    speichereZertifikate(collectionName, privateKey, publicCert, chainCert);
                                                } else {
                                                    console.log(`Keine gültigen Zertifikate für die Collection: ${collectionName} gefunden.`);
                                                }
                                            });
                                        });
                                    }
                                    
                                    // Beim Start einmalig die Zertifikate verarbeiten
                                    verarbeiteZertifikate();
                                    
                                    // Alle 24 Stunden (86400000 ms) das Skript erneut ausführen
                                    schedule("0 0 * * *", function () {
                                        verarbeiteZertifikate();
                                    });
                                    
                                    
                                    javascript.0	18:28:09.851	info	Start JavaScript script.js.common.System.ACME_Letsencrypt_export (Javascript/js)
                                    javascript.0	18:28:09.925	info	script.js.common.System.ACME_Letsencrypt_export: registered 0 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
                                    javascript.0	18:28:09.940	info	script.js.common.System.ACME_Letsencrypt_export: Privater Schlüssel gespeichert unter: /opt/iobroker/certificates/home_key.pem
                                    javascript.0	18:28:09.947	info	script.js.common.System.ACME_Letsencrypt_export: Zertifikat gespeichert unter: /opt/iobroker/certificates/home_cert.pem
                                    javascript.0	18:28:09.949	info	script.js.common.System.ACME_Letsencrypt_export: Zertifikatskette gespeichert unter: /opt/iobroker/certificates/home_chain.pem
                                    
                                    mcm1957M 1 Antwort Letzte Antwort
                                    0
                                    • Sven SchumacherS Sven Schumacher

                                      LetsEncrypt Zertifikate für z.B. Grafana oder andere auf dem gleichen Host nutzbar machen.

                                      IOBROKER verweist auf den ACME-Adapter um Zertifikate für ADMIN zu erzeugen.
                                      Allerdings hat man regelmäßig z.B. Grafana oder andere Adapter/Dienste laufen, die auch ein Zertifikat brauchen und das über den Weg nicht können.

                                      ACME legt die Zertifikate in einem JSON unter system.certificates ab. Sogar im Klartext.
                                      Also habe ich Script erzeugt, welches diese dort extrahiert und unter /opt/iobroker/certificates ablegt. Benannt nach dem Schema
                                      [collection]_key.pem
                                      [collection]_cert.pem
                                      [collection]_chain.pem

                                      Von dem Ort aus kann man das nun weiter verwenden.

                                      Das Script erzeugt die Keys beim Start und danach läuft es alle 24h. Nicht übermäßig kompliziert, aber nützlich.

                                      const fs = require('fs');
                                      const path = '/opt/iobroker/certificates/';  // Übliches Verzeichnis für Zertifikate
                                      
                                      // Funktion zum Speichern der Zertifikatsdateien
                                      function speichereZertifikate(collectionName, privateKey, publicCert, chainCert) {
                                          // Erstellen des Verzeichnisses, falls es nicht existiert
                                          if (!fs.existsSync(path)) {
                                              fs.mkdirSync(path, { recursive: true });
                                          }
                                      
                                          // Dateien mit dem Collection-Namen speichern
                                          const privateKeyPath = `${path}${collectionName}_key.pem`;
                                          const publicCertPath = `${path}${collectionName}_cert.pem`;
                                          const chainCertPath = `${path}${collectionName}_chain.pem`;
                                      
                                          // Speichern des privaten Schlüssels
                                          fs.writeFileSync(privateKeyPath, privateKey);
                                          console.log(`Privater Schlüssel gespeichert unter: ${privateKeyPath}`);
                                      
                                          // Speichern des Zertifikats
                                          fs.writeFileSync(publicCertPath, publicCert);
                                          console.log(`Zertifikat gespeichert unter: ${publicCertPath}`);
                                      
                                          // Falls eine Zertifikatskette vorhanden ist, diese speichern
                                          if (chainCert) {
                                              fs.writeFileSync(chainCertPath, chainCert);
                                              console.log(`Zertifikatskette gespeichert unter: ${chainCertPath}`);
                                          } else {
                                              console.log('Keine Zertifikatskette für die Collection: ' + collectionName + ' gefunden.');
                                          }
                                      }
                                      
                                      // Funktion zum Abrufen und Speichern der Zertifikate aus allen Collections
                                      function verarbeiteZertifikate() {
                                          getObject('system.certificates', function (err, obj) {
                                              if (err || !obj || !obj.native || !obj.native.collections) {
                                                  console.log('Fehler: Zertifikatssammlungen konnten nicht abgerufen werden.');
                                                  return;
                                              }
                                      
                                              const collections = obj.native.collections;
                                      
                                              // Alle Collections durchlaufen
                                              Object.keys(collections).forEach(function (collectionName) {
                                                  const collection = collections[collectionName];
                                      
                                                  if (collection.key && collection.cert) {
                                                      // Privater Schlüssel und Zertifikat aus der Collection extrahieren
                                                      const privateKey = collection.key;
                                                      const publicCert = collection.cert;
                                      
                                                      // Zertifikatskette extrahieren, falls vorhanden
                                                      const chainCert = collection.chain ? collection.chain.join('\n') : null;
                                      
                                                      // Zertifikate mit dem dynamischen Collection-Namen speichern
                                                      speichereZertifikate(collectionName, privateKey, publicCert, chainCert);
                                                  } else {
                                                      console.log(`Keine gültigen Zertifikate für die Collection: ${collectionName} gefunden.`);
                                                  }
                                              });
                                          });
                                      }
                                      
                                      // Beim Start einmalig die Zertifikate verarbeiten
                                      verarbeiteZertifikate();
                                      
                                      // Alle 24 Stunden (86400000 ms) das Skript erneut ausführen
                                      schedule("0 0 * * *", function () {
                                          verarbeiteZertifikate();
                                      });
                                      
                                      
                                      javascript.0	18:28:09.851	info	Start JavaScript script.js.common.System.ACME_Letsencrypt_export (Javascript/js)
                                      javascript.0	18:28:09.925	info	script.js.common.System.ACME_Letsencrypt_export: registered 0 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
                                      javascript.0	18:28:09.940	info	script.js.common.System.ACME_Letsencrypt_export: Privater Schlüssel gespeichert unter: /opt/iobroker/certificates/home_key.pem
                                      javascript.0	18:28:09.947	info	script.js.common.System.ACME_Letsencrypt_export: Zertifikat gespeichert unter: /opt/iobroker/certificates/home_cert.pem
                                      javascript.0	18:28:09.949	info	script.js.common.System.ACME_Letsencrypt_export: Zertifikatskette gespeichert unter: /opt/iobroker/certificates/home_chain.pem
                                      
                                      mcm1957M Online
                                      mcm1957M Online
                                      mcm1957
                                      schrieb am zuletzt editiert von
                                      #49

                                      @sven-schumacher said in [Aufruf] Welche guten JavaScripts setzt ihr ein?:

                                      /opt/iobroker/certificates/

                                      Danke f.d. Skript.

                                      @apollon77
                                      @Thomas-Braun

                                      const path = '/opt/iobroker/certificates/'; // Übliches Verzeichnis für Zertifikate

                                      Frage:
                                      Ist das Anlegen eines neuen privaten Ordners in /opt/iobroker "zulässig" oder eher davon abzuraten? Auch wenn es derzeit funktioniert, kann es da zukünftig zu Problemen kommen oder ist der Platz explizit für private Daten vorgesehen?

                                      Entwicklung u Betreuung: envertech-pv, hoymiles-ms, ns-client, pid, snmp Adapter;
                                      Support Repositoryverwaltung.

                                      Wer Danke sagen will, kann nen Kaffee spendieren: https://paypal.me/mcm1957atiobroker

                                      LESEN - gute Forenbeitrage

                                      Sven SchumacherS sigi234S Thomas BraunT apollon77A 4 Antworten Letzte Antwort
                                      0
                                      • mcm1957M mcm1957

                                        @sven-schumacher said in [Aufruf] Welche guten JavaScripts setzt ihr ein?:

                                        /opt/iobroker/certificates/

                                        Danke f.d. Skript.

                                        @apollon77
                                        @Thomas-Braun

                                        const path = '/opt/iobroker/certificates/'; // Übliches Verzeichnis für Zertifikate

                                        Frage:
                                        Ist das Anlegen eines neuen privaten Ordners in /opt/iobroker "zulässig" oder eher davon abzuraten? Auch wenn es derzeit funktioniert, kann es da zukünftig zu Problemen kommen oder ist der Platz explizit für private Daten vorgesehen?

                                        Sven SchumacherS Offline
                                        Sven SchumacherS Offline
                                        Sven Schumacher
                                        schrieb am zuletzt editiert von
                                        #50

                                        @mcm1957 Ich weiß es nicht sicher. Allerdings ist das /opt/iobroker eben eh da und früher hat letsencrypt dort seine Zertifikate abgelegt.
                                        Es ist im Zweifel kein Problem ein anderes Verzeichnis zu nutzen. Das ist ja im Quelltext leicht zu ändern.

                                        const path = '/opt/iobroker/certificates/';  // Übliches Verzeichnis für Zertifikate
                                        

                                        Da könnte man auch /etc/eigenezertifikate/ eintragen oder so. Ist vermutlich egal.

                                        mcm1957M 1 Antwort Letzte Antwort
                                        0
                                        • mcm1957M mcm1957

                                          @sven-schumacher said in [Aufruf] Welche guten JavaScripts setzt ihr ein?:

                                          /opt/iobroker/certificates/

                                          Danke f.d. Skript.

                                          @apollon77
                                          @Thomas-Braun

                                          const path = '/opt/iobroker/certificates/'; // Übliches Verzeichnis für Zertifikate

                                          Frage:
                                          Ist das Anlegen eines neuen privaten Ordners in /opt/iobroker "zulässig" oder eher davon abzuraten? Auch wenn es derzeit funktioniert, kann es da zukünftig zu Problemen kommen oder ist der Platz explizit für private Daten vorgesehen?

                                          sigi234S Online
                                          sigi234S Online
                                          sigi234
                                          Forum Testing Most Active
                                          schrieb am zuletzt editiert von sigi234
                                          #51

                                          @mcm1957
                                          Muss das für Windows Systeme auch angepasst werden?

                                          Wäre für das Meeting interessant.

                                          Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                          Immer Daten sichern!

                                          Sven SchumacherS mcm1957M 2 Antworten Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          818

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          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