Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Adapter für VELUX KLF-200 Interface

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Adapter für VELUX KLF-200 Interface

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

      Hallo paulkerl,

      Sorry für die späte Nachricht, kam einfach nicht zum testen.
      Vielen Dank für das Skript, funktioniert perfekt. Ist auf jeden Fall ein Start, ich freue mich auf den neuen Adapter...

      VG Joe

      madle 1 Reply Last reply Reply Quote 0
      • madle
        madle @joefarm last edited by

        @joefarm

        Hallo, habe ich das richtig verstanden, wenn ich Velux Fenster mit einer Fernbedienung habe wo io home control drauf steht, brauche ich ein klf200 Modul und dann könnte ich die Fenster mit io-broker oder fhem steuern.

        Vielen Dank für die Info!

        1 Reply Last reply Reply Quote 0
        • P
          paulkerl last edited by

          Hallo Joe,
          hast Du richtig verstanden.
          Allerdings mit den aktuell genannten "einschränkungen" wie oben benannt.
          Sbald es wieder einen "richtigen" iobroker adapter gibt, wird das ganze wohl wieder deutlich komfortabler.

          Vg Paulkerl

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

            @MiSchroe sagte in Adapter für VELUX KLF-200 Interface:

            Ja, da hilft leider nur warten, bis ich fertig bin.

            Hi,

            Da ich in kürze eine Nachrüstung der Rollladen plane würde mich interessieren wie es mit dem Update aussieht?

            Benötige ich eigentlich das KLF200 bei Solar oder der 230V Version oder bei beiden?

            Danke und Gruß

            1 Reply Last reply Reply Quote 0
            • S
              Singular75 last edited by

              Hallo zusammen,

              ich habe begonnen, ebenfalls dem "Umweg" über die KLF-API (npm-Paket) zu implementieren. In der Shell (bei mir Debian auf Proxmox) funktioniert das auch problemlos über den entsprechenden node <script>-Aufruf und dann auch über exec im iobroker.

              Da die Scripte ja in JavaScript sind frage ich mich, warum sie nicht auch "innerhalb" von iobroker in der JavaScript-Engine direkt laufen...? Leider bekomme ich die Fehlermeldung nicht weg, dass das Paket im Require-Block (const velux = require('velux-klf200-api')) nicht gefunden wird, obwohl ich es in der Instanz als zusätzliches Paket angegeben habe.

              Hast jemand eine Idee, wie sich das ggf. realisieren lassen würde bzw. was ich hier ggf. vergesse?

              BG
              Alex

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

                Hallo,

                Bei mir sind jetzt Rollläden und KLF im Zulauf.

                Welche Möglichkeiten habe ich aktuell um das in ioBroker und/oder HM einzubinden?

                Gibt es eventuell schon ein Update des Adapters das ich nicht mitbekommen habe?

                Danke und Gruß

                1 Reply Last reply Reply Quote 0
                • S
                  Singular75 @Singular75 last edited by

                  @Singular75 said in Adapter für VELUX KLF-200 Interface:

                  Hallo zusammen,

                  ich habe begonnen, ebenfalls dem "Umweg" über die KLF-API (npm-Paket) zu implementieren. In der Shell (bei mir Debian auf Proxmox) funktioniert das auch problemlos über den entsprechenden node <script>-Aufruf und dann auch über exec im iobroker.

                  Da die Scripte ja in JavaScript sind frage ich mich, warum sie nicht auch "innerhalb" von iobroker in der JavaScript-Engine direkt laufen...? Leider bekomme ich die Fehlermeldung nicht weg, dass das Paket im Require-Block (const velux = require('velux-klf200-api')) nicht gefunden wird, obwohl ich es in der Instanz als zusätzliches Paket angegeben habe.

                  Hast jemand eine Idee, wie sich das ggf. realisieren lassen würde bzw. was ich hier ggf. vergesse?

                  BG
                  Alex

                  OK, gelöst -> Fehlermeldung ignorieren reicht aus 🙂 Läuft augenscheinlich trotzdem.

                  1 Reply Last reply Reply Quote 0
                  • R
                    Rolli100 last edited by

                    Hallo zusammen,
                    der zuvor genannte Tipp mit der velux-klf200-api war klasse und hat mir sehr geholfen und die Einbindung in iobroker klappt nach einigem Probieren tatsächlich einwandfrei.
                    Falls sich jemand damit schwer tut, anbei zwei Beispiele.

                    1. Blockly-Code mit JavaScript-Funktion "activateScene" (einfach in Zwischenablage kopieren und importieren). Das Beispiel aktiviert eine Szene, die Scene-ID wird als Parameter (hier: 0) übergeben.
                    2. node-red-Beispiel, ebenfalls zum Importieren aus der Zwischenablage. Das Beispiel aktiviert eine Szene, die Scene-ID wird im Button als Payload hinterlegt (hier: 0)

                    Velux KLF-200-Beispiel.zip

                    Hinweis: In beiden Fällen muss das Modul zuerst installiert und dann in iobroker bekannt gemacht werden.
                    Im falle von Blockly genügte es, der Javascript-Instanz unter "Zusätzliche NPM-Module" das "velux-klf200-api" hinzuzufügen.
                    Im Falle von node-red kann dazu z.B. das "required('velux-klf200-api')" in den global context verschoben werden. Hierzu die Datei /opt/iobroker/node_modules/iobroker.node-red/settings.js editieren und ganz unten im Block functionGlobalContext{ ... } einbauen: velux:require('velux-klf200-api')

                    Grundsätzlich funktionieren neben dem Aktivieren von Szenen auch andere Kommandos, wie z.B. das Schließen eines Rollladens zu x%. Da die KLF200 jedoch nach einigen Anweisungen den Betrieb vorübergehend einzustellen scheint, war mir das Steuern einzelner Fenster zu unzuverlässig. Stattdessen habe ich mir in der KLF200 Szenen für alle benötigten Zustände erstellt.

                    Das obige Blockly-Script läuft jetzt seit einer Woche zuverlässig, ohne dass die KLF200 einen Neustart benötigt hat.

                    1 Reply Last reply Reply Quote 0
                    • P
                      paulkerl last edited by

                      Hallo Rolli100.

                      danke für die Beispiele. Werde ich am WE mal testen.
                      Als Tipp sei noch erwähnt, dass man an den KLF keine Befehle senden darf, solange nicht der vorherige abgearbeitet ist - tut man dies doch hilft oftmals nur ein Neustart. (Abgearbeitet = "Zeit zw. Befehl an KLF übergeben und bekommen der Bestätigung, dass der Rolladen die Endposition erreicht hat."(bei meinen Velux Akku-Dachfenstern, kann das schon mal 30s sein)). Deshalb setzte ich bei jedem Befehl eine Variable auf "working" die abgefragt wird, bevor ein weiterer Befehl abgearbeitet wird. Der nächste Befehl wird erst an die KLF gesendet sobald Working=false ist. Seitdem steigt der KLF nciht mehr aus. Zusätzlich farge ich per Cron alle 10 min. den Status der KLF ab, da nach ca. 15 Minuten ohne Verbindung keine weitere mehr hergestellt werden kann.

                      VG Paulkerl

                      R 1 Reply Last reply Reply Quote 0
                      • R
                        Rolli100 @paulkerl last edited by

                        @paulkerl Hi paulkerl,
                        das sind gute Tipps. Es kann gut sein, dass das bei mir auch an zu früh abgesetzten Befehlen gelegen hat. Werde mal versuchen, ob sich die Statusabfrage mit in die Funktion einbauen lässt. Blöd ist nur, dass das die ohnehin schon langsame Befehlsausführung der KLF 200 noch mehr verlangsamen wird.
                        VG

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

                          Hallo zusammen,

                          auch bei mir läuft nun seit 3 knapp Wochen ein Javacript unter ioBroker zum Ansteuern meiner 5 Solarrolladen unter Benutzung der "VELUX-KLF200-API". Das funktioniert zwischenzeitlich auch fast fehlerfrei.
                          Ich sende alle 3 Minuten mittels Cronjob einen Befehl (Idle-Telegramm) „GW_GET_STATE_REQ“ zur Aufrechterhaltung der Verbindung.
                          Einmal am Tag gibt’s dann einen Reset „GW_REBOOT_REQ“ (Zurücksetzen des Interfaces) auf die Mütze…
                          Das Ansteuern der Rolladen mittels „GW_COMMAND_SEND_REQ“ (einzeln bzw. eine beliebige Kombinationen) mit der gewünschten Absolutposition sowie Stopp während der Fahrt funktioniert nun auch.
                          Ich würde nun gerne noch die Rückmeldungen zu den Befehlen auswerten.
                          Leider erhalte ich hier generell nur eine Ausgabe der Form

                          07:41:30.056 info javascript.0 script.js.Velux: [object Object]

                          Zur Ansteuerung der Rolladen verwende ich Aufrufe der Form:

                             return velux.sendCommand({ api: velux.API.GW_COMMAND_SEND_REQ,
                                  commandOriginator: 1,
                                  priorityLevel: 2,
                                  parameterActive: 1,
                                  functionalParameterMP:  {rawValue : Val}, 
                                  indexArrayCount: Count,
                                  indexArray : [Rollos[0], Rollos[1], Rollos[2], Rollos[3], Rollos[4]] ,
                                  priorityLevelLock: false,
                                  })
                              .then((data)=>{
                                  console.log(data)
                              })
                          

                          Hat hier jemand von Euch Erfahrung? Was läuft hier schief bzw. was mache ich hier falsch?

                          Danke und viele Grüße
                          Jürgen

                          arteck S 2 Replies Last reply Reply Quote 0
                          • arteck
                            arteck Developer Most Active @loehrj1 last edited by

                            @loehrj1 sagte in Adapter für VELUX KLF-200 Interface:

                            object Object

                            das ist ein Object was du zurück bekommst und keine flache Struktur..

                            JSON.parse(xxxxxx);
                            

                            kannst du eine flache Struktur zur Ansicht erzeugen

                            L 1 Reply Last reply Reply Quote 0
                            • L
                              loehrj1 @arteck last edited by

                              @arteck
                              Danke, dein Tipp hat mich auf die richtige Spur geführt - manchmal hat man eben Tomaten auf den Augen....
                              JSON.parse liefert mir allerdings einen Fehler zurück.
                              Die Ausgabe console.log(typeof data) liefert mir object zurück. Ich habe hier doch bereits ein Javascript Objekt vorliegen und muss folglich nicht parsen. Richtig?

                              Der Zugriff erfolgt mit einfach mit dem Punktoperator auf die jeweiligen Eigenschaften des Objektes....

                              1 Reply Last reply Reply Quote 0
                              • S
                                Singular75 @MiSchroe last edited by

                                @MiSchroe Gibt es hier ggf. schon ein Update? Der Umweg über die KLF200-API geht zwar rudimentär, ein "echter" Adapter wäre aber deutlich angenehmer in der Nutzung 🙂

                                Homoran 1 Reply Last reply Reply Quote 0
                                • Homoran
                                  Homoran Global Moderator Administrators @Singular75 last edited by

                                  @Singular75 sagte in Adapter für VELUX KLF-200 Interface:

                                  ein "echter" Adapter

                                  Wie meinst du das?

                                  https://github.com/MiSchroe/ioBroker.klf200/blob/master/README.md

                                  Das ist ein Adapter

                                  S 1 Reply Last reply Reply Quote 0
                                  • S
                                    Singular75 @Homoran last edited by

                                    @Homoran Ja, aber der funktioniert seit dem Firmwareupdate des KLF200 nicht mehr, da die API sich komplett geändert hat. @MiSchroe wollte ihn dahingehend anpassen. In der Zwischenzeit nutzen einige die Umweg über die KLF200-API, was allerdings anteilig suboptimal funktioniert (Verbindungsabbrüche, etc.)

                                    1 Reply Last reply Reply Quote 0
                                    • S
                                      Singular75 @loehrj1 last edited by

                                      @loehrj1 said in Adapter für VELUX KLF-200 Interface:

                                      7:41:30.056 info javascript.0 script.js.Velux: [object

                                      Kannst Du Deine Scripte in diesem Kontext (Reset, Detailansteuerung inkl. Stop, Verbindungsaufrechterhaltung) bitte hier alle geeignet posten? Das wäre sehr hilfreich 🙂

                                      lg
                                      Alex

                                      L 1 Reply Last reply Reply Quote 0
                                      • L
                                        loehrj1 @Singular75 last edited by loehrj1

                                        Hallo Alex,

                                        ich steuere aktuell 5 Solarroladen (Az..., Sz, Wz...) über dieses Script in Verbindung mit der KLF-200 API.
                                        Die Ansteuerung der einzelnen Rolladen erfolgt über die Logitech Harmony und über Apple Homekit.

                                        Eine kurze Beschreibung der verwendeten Funktionen:

                                        function ConnectKlf()
                                        Aufbau der Vebindung zum KLF200

                                        function Rollo( Num, Val)
                                        Ansteuerung der Rolladen. Num ist NodeId des zu steuernden Rollos. Num entspricht einem Wert zwischen 0 und 0xc700, 0xD200 entspricht dem Wert für Stop

                                        function GetState()
                                        Holt den Öffnungswert aller 5 Rolladen. Verwende ich zyklisch als Idle-Telegramm zur Aufrechterhaltung der Verbindung

                                        function Status(data)
                                        Callbackfunktion zur Auswertung der Öffnungswerte der Rolladen aus data.parameterData[0].parameter (Highbyte) und data.parameterData[0].parameterValue (Lowbyte)

                                        function JobFinished(data)
                                        Callback fuer Ende der Befehlsausfuehrung

                                        onStop(function skriptStop () {....
                                        Beenden des scripts mit Verbindungsabbau und Aufräumen

                                        schedule('/1 * * * ', function () {...
                                        Lebenszeichentelegramm und Statusabfrage jede Minute

                                        *schedule('5 23 * * ', function () {....
                                        Reboot des KLF200 einmal am Tag

                                        Viele Grüße
                                        Jürgen

                                        Hier das Script:

                                        'use strict' ; 
                                        // Netzwerk
                                        const Ip       = '192.168.178.5'
                                        const Passwort = '0123456789' // WLAN Passwort
                                         
                                        // nodeIDs der einzelnen Rollos
                                        const AzWest = 0 // nodeId Arbeitzimmer Fenster Westseite
                                        const AzOst  = 1 // nodeId Arbeitzimmer Fenster Ostseite
                                        const SzSued = 2 // nodeId Schlafzimmer Fenster Suedseite
                                        const WzSued = 3 // nodeId Wohnzimmer Fenster Suedseite
                                        const WzNord = 4 // nodeId Wohnzimmer Fenster Nordseite
                                        
                                        const MaxNodeIdx = 5;  // 5 Rollos..
                                        
                                        const Z = ["AzWest","AzOst","Sz","WzSued","WzNord"] // Name fuer Zuugriff azf Statevariable
                                         
                                        // Gruppen
                                        const All   = 5 // Alles Dachrolladen
                                        const Wz    = 6 // Wohnzimmer
                                        const Az    = 7 // Arbeitszimmer
                                        const Sz    = 2 // Schlafzimmer
                                          
                                        const Up    = 0      // Rollo oben
                                        const Down  = 0xc800 // Rollo unten
                                        const Stop  = 0xD200 // Stopkommando
                                          
                                        // Variable
                                        var velux  = require('velux-klf200-api')
                                        var Connected = false
                                        
                                        var SessionId = 1
                                        
                                        // Zustand der 5 Rollos holen  
                                         function GetState()
                                         {
                                            velux.sendCommand({ api: velux.API.GW_STATUS_REQUEST_REQ,
                                                            sessionID: 0,
                                                            indexArrayCount: 5,
                                                            indexArray : [AzOst, AzWest, SzSued, WzSued, WzNord],
                                                            statusType : 3 // Main Info
                                                            })  
                                         }
                                            
                                        
                                         
                                        // Callback fuer Positionsrueckmeldung 
                                        velux.on('GW_STATUS_REQUEST_NTF', Status)     
                                        function Status(data)
                                        {
                                            var Target     = Math.round(100 - data.targetPosition.value)
                                            var Current    = Math.round(100 - data.currentPosition.value) // aktuelle Position
                                            var Time       = data.remainingTime // Restlaufzeit
                                            var Index      = data.index         // Node index
                                            var StatusType = data.statusType    // Status Typ "Main Info" = 3 erwartet
                                        
                                            //  console.log(JSON.stringify(data))
                                            console.log(Z[data.index] + ',Ziel:' +Target + ' Aktuell:' + data.currentPosition.value + ' Restlaufzeit:' + Time)
                                        
                                            if ( (StatusType == 3) && 
                                                 (Time == 0) && 
                                                 (Index >= 0) && 
                                                 (Index < MaxNodeIdx))
                                            {
                                                var IdStr    = "javascript.0.Var.DG.Dach.Soll." + Z[data.index] 
                                                var IdStrIst = "javascript.0.Var.DG.Dach.Ist."  + Z[data.index] 
                                                setState(IdStr,    Current)
                                                setState(IdStrIst, Current)
                                            }
                                        }
                                          
                                        // Callback Ende Job
                                        velux.on('GW_SESSION_FINISHED_NTF',JobFinished)
                                        function JobFinished(data){
                                            if ( SessionId == data.sessionID )  // Ende letztes Kommando
                                            {
                                                console.log("EndCmd (" + SessionId+')')
                                                GetState()    // bei Befehlsende Position der fenster abfragen
                                            }
                                        }
                                          
                                        // Verbindung aufbauen
                                        function ConnectKlf() { 
                                            if (! Connected)
                                            {
                                                Connected = true;
                                                velux.connect( Ip, {} )
                                                .then(()=>{
                                                    velux.login( Passwort ).then(()=>{
                                                    sendMsg("KLF: Connected")
                                                    console.log("Klf connected!")
                                                    Connected = true
                                                    GetState();
                                                    })
                                                })
                                                .catch((err)=>{
                                                    console.log(err)
                                                    Connected = false
                                                    velux.end()
                                                })
                                            }
                                        } 
                                           
                                        // Rollos ansteuern
                                        var Rollos = [0,1,2,3,4]
                                        var Count  = 5 
                                        function Rollo( Num, Val) {
                                            if ( Connected )
                                            {
                                                if (Num == All)
                                                {
                                                    Rollos[0] = WzSued
                                                    Rollos[1] = WzNord
                                                    Rollos[2] = AzOst
                                                    Rollos[3] = AzWest
                                                    Rollos[4] = SzSued
                                                    Count = 5
                                                }
                                                else if (Num == Wz)
                                                {
                                                    Rollos[0] = WzSued
                                                    Rollos[1] = WzNord
                                                    Count = 2
                                                }
                                                else if (Num == Az)
                                                {
                                                    Rollos[0] = AzOst
                                                    Rollos[1] = AzWest
                                                    Count = 2
                                                }
                                                else
                                                {
                                                    Rollos[0] = Num
                                                    Count = 1
                                                }
                                                return velux.sendCommand({ api: velux.API.GW_COMMAND_SEND_REQ,
                                                    sessionID : ++SessionId,
                                                    commandOriginator: 1,
                                                    priorityLevel:     2,
                                                    parameterActive:   1,
                                                    functionalParameterMP:  {rawValue : Val}, 
                                                    indexArrayCount: Count,
                                                    indexArray : [Rollos[0], Rollos[1], Rollos[2], Rollos[3], Rollos[4]] ,
                                                    priorityLevelLock: false,
                                                    })
                                                .then((data)=>{
                                                        console.log("StartCmd (" + data.sessionID+')')
                                                })
                                                .catch((err)=>{
                                                    console.log(err)
                                            })
                                            }
                                        } 
                                        
                                        // Restart einmal pro Tag um 22 Uhr 
                                        schedule('5 20 * * *', function () {
                                            velux.sendCommand({ api: velux.API.GW_REBOOT_REQ})
                                            Connected = false
                                        });
                                        
                                        // zyklisches Senden Idle Telegramm und Rolladenstatus holen 
                                        schedule('*/1 * * * *', function () {
                                            velux.sendCommand({ api: velux.API.GW_GET_STATE_REQ})
                                            .then((data)=>{
                                                Connected = true
                                                GetState()       // Rolladenpostionen holen
                                            })
                                            .catch((err)=>{
                                                Connected = false
                                                sendMsg("KLF: Connection lost")
                                                console.log("Connection lost...")       
                                                ConnectKlf() 
                                            })
                                        }); 
                                          
                                        // Verbinden zu klf200
                                        ConnectKlf()
                                        
                                         
                                        // Verbindung abbauen und aufraeumen bei Stop
                                        onStop(function skriptStop () {
                                            Connected = false
                                            console.log("Disconnect")
                                            velux.off('GW_STATUS_REQUEST_NTF',  Status)
                                            velux.off('GW_SESSION_FINISHED_NTF',JobFinished)
                                            velux.end()
                                        });
                                         
                                         
                                        
                                        
                                        
                                        //*******************************************************************************
                                        //    Befehle aus Homekit
                                        //*******************************************************************************
                                        on({id: 'javascript.0.Var.DG.Dach.Alle', change: 'ne' }, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(All, State)
                                        });
                                        on({id: 'javascript.0.Var.DG.Dach.Soll.WzSued', change: 'ne'}, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(WzSued, State)
                                        });
                                        on({id: 'javascript.0.Var.DG.Dach.Soll.WzNord', change: 'ne' }, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(WzNord, State)
                                        });
                                        on({id: 'javascript.0.Var.DG.Dach.Soll.AzOst', change: 'ne' }, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(AzOst, State)
                                        });  
                                        on({id: 'javascript.0.Var.DG.Dach.Soll.AzWest', change: 'ne' }, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(AzWest, State)
                                        });
                                        on({id: 'javascript.0.Var.DG.Dach.Soll.Sz', change: 'ne' }, function (obj) {
                                            var State = Down - Down / 100 * obj.state.val
                                            Rollo(Sz, State)
                                        });   
                                        
                                        //*******************************************************************************
                                        //    Mapping fuer Logitech Harmony
                                        //*******************************************************************************
                                        // Dach zu
                                        subscribe({id: 'fakeroku.0.Rolladen.keys.Left', val : true, ack :true}, function (obj) {
                                            Rollo(Wz, Down)
                                        });
                                        // Dach auf
                                        subscribe({id: 'fakeroku.0.Rolladen.keys.Down', val : true, ack :true}, function (obj) {
                                            Rollo(Wz, Up)
                                        });
                                        // Dach Stop
                                        subscribe({id: 'fakeroku.0.Rolladen.keys.Info', val : true, ack :true}, function (obj) {
                                            Rollo(Wz, Stop)
                                        });
                                        // Alles zu
                                        subscribe({id: 'fakeroku.0.Rolladen.keys.Home', change :'ne', ack :true}, function (obj) {
                                            Rollo(Wz, Down)
                                            setStateDelayed("hm-rpc.1.OEQ1312460.1.LEVEL", 0,  100, true)
                                            setStateDelayed('hm-rpc.1.KEQ0157348.1.LEVEL', 0,  100, true)
                                        });
                                        
                                        S 2 Replies Last reply Reply Quote 0
                                        • S
                                          Singular75 @loehrj1 last edited by

                                          @loehrj1 said in Adapter für VELUX KLF-200 Interface:

                                          e Ansteuerung der einzelnen Rolladen erfolgt über die Logitech Harmony und über Apple Homekit.

                                          Danke! 🙂

                                          1 Reply Last reply Reply Quote 0
                                          • P
                                            paulkerl last edited by

                                            Hallo zusammen,
                                            habe das Script von loehrj1 mal auf meine Bedürfnisse angepasst. Funktioniert super und vor allem schön schnell gegenüber meiner oberen Lösung per CMD einzelne Scripts aufzurufen.

                                            Leider scheine ich einen Fehler im Script zu haben, welchen ich nicht finden kann.

                                            Wenn ich über die Iobroker Objekte die Rollläden steuere funktioniert dies wie es soll bis auf in einem Fall. Ändere ich den Wert von KuNord werden drei der SZ*****-Rolläden ebenfalls gesteuert mit Ausnahme von SzOstRechts. Bedeutet, dass wenn ich z.B. den Wert von KuNord auf 80 setze wird dies ausgeführt. Bei der nächsten Statusabfrage des Scripts werden die o.g. Rollläden ebenfalls auf diesen Wert gesetzt. Dies passiert nur bei KuNord.

                                            Wer hat eine Idee?

                                            Danke euch.

                                            VG P.

                                            'use strict' ; 
                                            // Netzwerk 
                                            const Ip        = '192.168.98.145'
                                            const Passwort = 'XXXXXXXXXXXX' // WLAN Passwort
                                             
                                            // nodeIDs der einzelnen Rollos
                                            const SzSudLinks = 0 
                                            const SzSudRechts = 1 
                                            const KuNord = 2
                                            const SzOstLinks = 3
                                            const SzOstRechts = 4 
                                             
                                            const MaxNodeIdx = 5;  // 5 Rollos..
                                             
                                            const Z = ["SzSudLinks","SzSudRechts","KuNord","SzOstLinks","SzOstRechts"] // Name fuer Zuugriff azf Statevariable
                                             
                                            // Gruppen
                                            const All   = 5 // Alles Dachrolladen
                                            // const Ku    = 6 // Kueche
                                            const Sz    = 2 // Schlafzimmer
                                            // const Az    = 7 // Arbeitszimmer
                                            
                                            const Up    = 0      // Rollo oben
                                            const Down  = 0xc800 // Rollo unten
                                            const Stop  = 0xD200 // Stopkommando
                                              
                                            // Variable
                                            var velux  = require('velux-klf200-api')
                                            var Connected = false
                                             
                                            var SessionId = 1
                                             
                                            // Zustand der 5 Rollos holen  
                                             function GetState()
                                             {
                                                velux.sendCommand({ api: velux.API.GW_STATUS_REQUEST_REQ,
                                                                sessionID: 0,
                                                                indexArrayCount: 5,
                                                                indexArray : [SzSudLinks, SzSudRechts, KuNord, SzOstLinks, SzOstRechts],
                                                                statusType : 3 // Main Info
                                                                })  
                                             }
                                                
                                             
                                             
                                            // Callback fuer Positionsrueckmeldung 
                                            velux.on('GW_STATUS_REQUEST_NTF', Status)     
                                            function Status(data)
                                            {
                                                var Target     = Math.round(100 - data.targetPosition.value)
                                                var Current    = Math.round(100 - data.currentPosition.value) // aktuelle Position
                                                var Time       = data.remainingTime // Restlaufzeit
                                                var Index      = data.index         // Node index
                                                var StatusType = data.statusType    // Status Typ "Main Info" = 3 erwartet
                                             
                                                //  console.log(JSON.stringify(data))
                                                console.log(Z[data.index] + ',Ziel:' +Target + ' Aktuell:' + data.currentPosition.value + ' Restlaufzeit:' + Time)
                                             
                                                if ( (StatusType == 3) && 
                                                     (Time == 0) && 
                                                     (Index >= 0) && 
                                                     (Index < MaxNodeIdx))
                                                {
                                                    var IdStr    = "javascript.1.shutter.soll." + Z[data.index] 
                                                    var IdStrIst = "javascript.1.shutter.ist."  + Z[data.index] 
                                                    setState(IdStr,    Current)
                                                    setState(IdStrIst, Current)
                                                }
                                            }
                                              
                                            // Callback Ende Job
                                            velux.on('GW_SESSION_FINISHED_NTF',JobFinished)
                                            function JobFinished(data){
                                                if ( SessionId == data.sessionID )  // Ende letztes Kommando
                                                {
                                                    console.log("EndCmd (" + SessionId+')')
                                                    GetState()    // bei Befehlsende Position der fenster abfragen
                                                }
                                            }
                                              
                                            // Verbindung aufbauen
                                            function ConnectKlf() { 
                                                if (! Connected)
                                                {
                                                    Connected = true;
                                                    velux.connect( Ip, {} )
                                                    .then(()=>{
                                                        velux.login( Passwort ).then(()=>{
                                                        sendMsg("KLF: Connected")
                                                        console.log("Klf connected!")
                                                        Connected = true
                                                        GetState();
                                                        })
                                                    })
                                                    .catch((err)=>{
                                                        console.log(err)
                                                        Connected = false
                                                        velux.end()
                                                    })
                                                }
                                            } 
                                               
                                            // Rollos ansteuern
                                            var Rollos = [0,1,2,3,4]
                                            var Count  = 5 
                                            function Rollo( Num, Val) {
                                                if ( Connected )
                                                {
                                                    if (Num == All)
                                                    {
                                                        Rollos[0] = SzSudLinks
                                                        Rollos[1] = SzSudRechts
                                                        Rollos[2] = KuNord
                                                        Rollos[3] = SzOstLinks
                                                        Rollos[4] = SzOstRechts
                                                        Count = 5
                                                    }
                                                    else if (Num == Sz)
                                                    {
                                                        Rollos[0] = SzSudLinks
                                                        Rollos[1] = SzSudRechts
                                                        Rollos[3] = SzOstLinks
                                                        Rollos[4] = SzOstRechts
                                                        Count = 4
                                                    }
                                                    else
                                                    {
                                                        Rollos[0] = Num
                                                        Count = 1
                                                    }
                                                    return velux.sendCommand({ api: velux.API.GW_COMMAND_SEND_REQ,
                                                        sessionID : ++SessionId,
                                                        commandOriginator: 1,
                                                        priorityLevel:     2,
                                                        parameterActive:   1,
                                                        functionalParameterMP:  {rawValue : Val}, 
                                                        indexArrayCount: Count,
                                                        indexArray : [Rollos[0], Rollos[1], Rollos[2], Rollos[3], Rollos[4]] ,
                                                        priorityLevelLock: false,
                                                        })
                                                    .then((data)=>{
                                                            console.log("StartCmd (" + data.sessionID+')')
                                                    })
                                                    .catch((err)=>{
                                                        console.log(err)
                                                })
                                                }
                                            } 
                                             
                                            // Restart einmal pro Tag um 04 Uhr 
                                            schedule('0 4 * * *', function () {
                                                velux.sendCommand({ api: velux.API.GW_REBOOT_REQ})
                                                Connected = false
                                            });
                                             
                                            // zyklisches Senden Idle Telegramm und Rolladenstatus holen 
                                            schedule('*/1 * * * *', function () {
                                                velux.sendCommand({ api: velux.API.GW_GET_STATE_REQ})
                                                .then((data)=>{
                                                    Connected = true
                                                    GetState()       // Rolladenpostionen holen
                                                })
                                                .catch((err)=>{
                                                    Connected = false
                                                    sendMsg("KLF: Connection lost")
                                                    console.log("Connection lost...")       
                                                    ConnectKlf() 
                                                })
                                            }); 
                                              
                                            // Verbinden zu klf200
                                            ConnectKlf()
                                             
                                             
                                            // Verbindung abbauen und aufraeumen bei Stop
                                            onStop(function skriptStop () {
                                                Connected = false
                                                console.log("Disconnect")
                                                velux.off('GW_STATUS_REQUEST_NTF',  Status)
                                                velux.off('GW_SESSION_FINISHED_NTF',JobFinished)
                                                velux.end()
                                            });
                                             
                                             
                                             
                                             
                                             
                                            //*******************************************************************************
                                            //    Befehle aus Homekit
                                            //*******************************************************************************
                                            on({id: 'javascript.1.shutter.Alle', change: 'ne' }, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(All, State)
                                            });
                                            on({id: 'javascript.1.shutter.soll.KuNord', change: 'ne'}, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(KuNord, State)
                                            });
                                            on({id: 'javascript.1.shutter.soll.SzOstLinks', change: 'ne' }, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(SzOstLinks, State)
                                            });
                                            on({id: 'javascript.1.shutter.soll.SzOstRechts', change: 'ne' }, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(SzOstRechts, State)
                                            });  
                                            on({id: 'javascript.1.shutter.soll.SzSudLinks', change: 'ne' }, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(SzSudLinks, State)
                                            });
                                            on({id: 'javascript.1.shutter.soll.SzSudRechts', change: 'ne' }, function (obj) {
                                                var State = Down - Down / 100 * obj.state.val
                                                Rollo(SzSudRechts, State)
                                            });   
                                            
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            853
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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