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. ioBroker Allgemein
  4. Harmony hub local Nutzung wird eingestellt.

NEWS

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

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

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

Harmony hub local Nutzung wird eingestellt.

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
246 Beiträge 66 Kommentatoren 44.3k Aufrufe
  • Ä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.
  • S Offline
    S Offline
    Seber65
    schrieb am zuletzt editiert von
    #81

    Hi,

    nutze das Python Script von EScape was hier schon im Umlauf war. Also:

    `#!/usr/bin/python3
    #
    # Logitech Harmony Class using websocket instead of old (removed) api
    # Credit for finding/sharing knowledge about the api goes to:
    #       https://github.com/jlynch630/Harmony.NET
    #       https://github.com/chadcb/harmonyhub
    #
    # This is a very early version. Consider it Alpha
    #
    # Written by: EScape 2018
    
    import json
    import time
    import requests
    import websocket
    from websocket import create_connection
    
    class harmonysock:
    
            def __init__(self, host, port='8088', protocol='http', hubid='', timeout=30):
                    self.hub_ip = host
                    self.hub_port = port
                    self.harmony_api = 'http://'+self.hub_ip+":"+self.hub_port
                    self.timeout = timeout
                    if hubid != '':
                            self.hub_id = hubid
                    else:
                            self.hub_id = self.gethubid()
                    #print('hubid:', self.hub_id)
                    self.hubsocket = create_connection('ws://' + self.hub_ip + ':' + self.hub_port + '/?domain=svcs.myharmony.com&hubId=' + self.hub_id)
                    self.cacheconfig=''
    
            def hubconfig(self, refresh=False):
                    if self.cacheconfig=='' or refresh:
                            self.cacheconfig = self.getconfig()
                    return self.cacheconfig
    
            def startactivity(self, activity):
                    headers = {'Content-type': 'application/json', 'Accept': 'text/plain', 'Origin': 'http//:localhost.nebula.myharmony.com'}
                    response = ''
                    try:
                            response = requests.post(self.harmony_api, json={"cmd": "harmony.activityengine?runactivity", "params":{"activityId":activity}}, headers=headers)
                            print(response.text)
                    except:
                            return False
                    if response.status_code == 200:
                            return True
                    else:
                            return False
    
            def gethubid(self):
                    headers = {'Content-type': 'application/json', 'Accept': 'text/plain', 'Origin': 'http//:localhost.nebula.myharmony.com'}
                    r = requests.post(self.harmony_api, json={"id": 111, "cmd": "connect.discoveryinfo?get", "params": {}}, headers=headers)
                    hub_data = json.loads(r.text)
                    hub_id = hub_data['data']['remoteId']
                    return hub_id
    
            def getconfig(self):
                    payload={}
                    #payload['hubId']=self.hub_id #Doesn't even need the hubid?
                    payload['timeout']=self.timeout
                    payload['hbus']={}
                    payload['hbus']['cmd']='vnd.logitech.harmony/vnd.logitech.harmony.engine?config'
                    payload['hbus']['id']='0'
                    payload['hbus']['params']='{"verb":"get"}'
                    self.hubsocket.send(json.dumps(payload))
                    hubsocket_data = self.hubsocket.recv()
                    hub_data = json.loads(hubsocket_data)
                    return hub_data['data']
    
            def getstate(self):
                    payload={}
                    #payload['hubId']=self.hub_id #Doesn't even need the hubid?
                    payload['timeout']=self.timeout
                    payload['hbus']={}
                    payload['hbus']['cmd']='vnd.logitech.connect/vnd.logitech.statedigest?get'
                    payload['hbus']['id']='0'
                    payload['hbus']['params']='{"verb":"get","format":"json"}'
                    self.hubsocket.send(json.dumps(payload))
                    hubsocket_data = self.hubsocket.recv()
                    hub_data=json.loads(hubsocket_data)
                    return hub_data['data']
    
            def currentactivity(self):
                    state = self.getstate()
                    return state['activityId']
    
            def listactivities(self):
                    base=self.hubconfig()['activity']
                    list={}
                    for item in base:
                            list[item['label']]=item['id']
                    return list
    
            def listdevices(self):
                    base=self.hubconfig()['device']
                    list={}
                    for item in base:
                            list[item['label']]=item['id']
                    return list
    
            def getactivitybyname(self, name):
                    all = self.listactivities()
                    if name in all:
                            return all[name]
                    else:
                            return None
    
            def startactivity(self, activity):
                    #If the activity is a number it is assumed to be an ID, otherwise a label (name)
                    if activity.isdigit():
                            activityid=activity
                    else:
                            activityid=self.getactivitybyname(activity)
                    headers = {'Content-type': 'application/json', 'Accept': 'text/plain', 'Origin': 'http//:localhost.nebula.myharmony.com'}
                    try:
                            response = requests.post(self.harmony_api, json={"cmd": "harmony.activityengine?runactivity", "params":{"activityId":activityid}}, headers=headers)
                    except:
                            return False
                    if response.status_code == 200:
                            return True
                    else:
                            return False
    
            def sendkey(self, device='', key='', hold=False):
                    stroke={}
                    stroke['deviceId']=device
                    stroke['command']=key
                    stroke['type']='IRCommand'
                    payload={}
                    #payload['hubId']=self.hub_id #Doesn't even need the hubid?
                    payload['timeout']=self.timeout
                    payload['hbus']={}
                    payload['hbus']['cmd']='vnd.logitech.harmony/vnd.logitech.harmony.engine?holdAction'
                    payload['hbus']['id']='222'
                    payload['hbus']['params']={}
                    payload['hbus']['params']['action']=json.dumps(stroke)
                    if hold:
                            payload['hbus']['params']['status']='hold'
                    else:
                            payload['hbus']['params']['status']='press'
                    payload['hbus']['params']['timestamp']="0"
                    self.hubsocket.send(json.dumps(payload))
                    return True
    
    harmony = harmonysock('192.168.2.119')
    
    #current = harmony.getstate()
    all_activitydata = harmony.listactivities()
    activity = harmony.currentactivity()
    #print(all_activitydata)
    
    for i in all_activitydata:
     if activity == all_activitydata[i]:
            print(i)` 
    
    Das liegt bei mir unter /opt/iobroker/scripts.
    
    Wenn nicht schon passiert muss vorher noch Phyton und der Websocket-Client installiert werden:
    
    apt-get install phyton3-pip
    
    pip3 install websocket-client
    
    Dann kannst du das Script in der Konsole testen. Das sollte dir dann die aktuelle Activity zurück geben.
    
    Bei mir kam noch ein Fehler und ich musste das Modul requests nach installieren:
    
    pip3 install requests
    
    Mein Javascript Code schaut dann fast 1:1 so aus, wie der von JohGre:
    
    `~~[code]~~var cronStr       = '*/5 * * * * *';
    
    function getActivity() {
        exec("./iobroker/scripts/harmony.py", function(err, stdout, stderr) {
            if (err) {
                log(stderr,'error');
                log('Harmony Aktivitistatus konnten nicht abgefragt werden', 'error');
                return;
            }
            //log(stdout);
            if (getState("javascript.3.Harmony-Activity").val != stdout.trim()) {
                log("set new HarmonyActivityState: " + stdout.trim() + " oldVal: " + getState("javascript.3.Harmony-Activity").val);
                setState("javascript.3.Harmony-Activity", stdout.trim());
            }
        });
    }
    
    //setTimeout(getActivity,1000);
    
    schedule(cronStr, getActivity);
    
    on("javascript.3.Harmony-Activity"/*Harmony-Activity*/, function (obj) {
        log("HarmonyActivityState changed: " + obj.state.val);
        if (getState("javascript.3.Harmony-Activity").val==="PowerOff"){
            setState("javascript.3.Harmony-Activity-ID",0);}
        else {setState("javascript.3.Harmony-Activity-ID",2);
        }
    }); [/code]`
    
    Habe nur noch eine If-Abfrage eingebaut um eine zusätzliche Variable mit Werten für an und aus zu füttern.[/i]
    
    1 Antwort Letzte Antwort
    0
    • BarnyXXB Offline
      BarnyXXB Offline
      BarnyXX
      schrieb am zuletzt editiert von
      #82

      Wollte nochmal kurz die Info geben, dass es bei mir aktuell so funktioniert:

      Downgrade auf die 4.15.193

      Ich habe per PiHole nur diese Adresse deaktiviert.

      sus.dhg.myharmony.com

      Ich kann weiterhin komplett mit Alexa arbeiten und auch die App bedienen. Das einzige, was nicht geht, ist neue Geräte hinzufügen. Ich habe versucht manuell die Software über die Fernbedienung zu aktualisieren. Er hat eine 3 minütige Synchronsation gemacht, aber die FW ist weiterhin bei 4.15.193. Ich bin mal gespannt, ob das so hält. Hat vielleicht irgendwer schon genauere Untersuchungen getätigt, über welche Adresse die Updates gezogen werden? Also mit diesem Zustand kann nich sehr gut leben.

      1 Antwort Letzte Antwort
      0
      • BarnyXXB Offline
        BarnyXXB Offline
        BarnyXX
        schrieb am zuletzt editiert von
        #83

        Ok, leider doch nicht so richtig. Jetzt ist die FB auf 206 und kann nicht mehr mit dem Hub sprechen. Ich werde es dann doch mit dem Skript machen. Ist halt nur etwas nervig. Da ich recht viele Aktionen haben, wo ich einzelne Tasten per Skript betätige.

        1 Antwort Letzte Antwort
        0
        • K Offline
          K Offline
          Kunibert
          schrieb am zuletzt editiert von
          #84

          Mich hat es heute auch getroffen, das Update wurde automatisch eingespielt ohne zutun. Habe schon bei Logitech via Supportformular eine entsprechende Nachricht hinterlassen aber ich bezweifle aktuell, dass das irgendetwas bringt.

          Wollte nun das Phyton-Skript einmal testen, bekomme aber beim Installieren von Phyton via Putty bringt folgenden Fehler:
          > Paket phyton3-pip kann nicht gefunden werden.

          Hat jemand eine Idee warum?

          –----- EDIT

          mit apt-get install python-pip und dann

          pip install websocket-client

          pip install requests

          hat die Installation jetzt funktioniert.

          Allerdings bekomme ich die Activity nicht ausgelesen. wenn ich den Befehl direkt auf der Commandline eingebe erhalte ich ebenfalls einen Fehler. Bin mir auch nicht sicher, ob ich den Aufruf mit phyton oder mit phyton3 beginnen muss, allerdings klappt beides nicht :-(
          1129_unbenannt.png

          –-----EDIT 2

          Okay, jetzt geht alles, fragt bitte nicht was ich noch geändert habe :-)

          Tausend Dank für eure Skripte und Anleitungen!

          Blöd genug das dieser ganze Ärger ohne Vorankündigung so ad-hoc entstanden ist.

          Gäbe es denn überhaupt sinnvolle Alternativen zu Logitech? Das Broadlink hat so wie ich das sehe keine Fernbedienung dabei und keine abgesetzten IR-Module oder übersehe ich da etwas? Habt ihr sonst noch von anderen gut steuerbaren IR-Lösungen gehört?

          1 Antwort Letzte Antwort
          0
          • M Offline
            M Offline
            marcdo70
            schrieb am zuletzt editiert von
            #85

            Mich hat es auch erwischt.

            Gestern ging es noch und heute nicht mehr.

            Auch still und heimlich würde der Hub geupdatet.

            Werde mich Morgen mal ans zurück setzten machen.

            Wenn es nicht mehr geändert wird, dann muss halt ne Alternative her.

            Hab ich noch Garantie drauf :lol:

            1 Antwort Letzte Antwort
            0
            • eric2905E Offline
              eric2905E Offline
              eric2905
              schrieb am zuletzt editiert von
              #86

              Hi,

              @marcdo70:

              Wenn es nicht mehr geändert wird, dann muss halt ne Alternative her.

              Hab ich noch Garantie drauf :lol: `
              ob das durch die Garantie abgedeckt ist, wage ich zu bezweifeln. ;)

              Zumindest habe ich zu meinem Hub keine Eigenschaft "integrierbar in ioBroker" oder "Bereitstellung einer API für eigene Zwecke" gesehen.

              Das was zugesichert wird, funktioniert auch.

              Gruß,

              Eric

              Roses are red, violets are blue,

              if I listen to metal, my neighbours do too

              1 Antwort Letzte Antwort
              0
              • D Offline
                D Offline
                denjo
                schrieb am zuletzt editiert von
                #87

                Also ich habe auch den Internet Zugang gesperrt von mein hub, und alles funktioniert tadellos ist aber natürlich keine Dauer Lösung. Weil ich irgendwann mal bestimmt ein neues Gerät hinzufügen möchte. Ich habe auch eine Nachricht an logitech verfasst.

                Kann mir einer die Funktion des script erklären, wird nur das Update dadurch geblockt oder wie?

                Kann man mit dem Script wieder geräte hinzufügen?

                1 Antwort Letzte Antwort
                0
                • D Offline
                  D Offline
                  davincino
                  schrieb am zuletzt editiert von
                  #88

                  Mit dem Script, so wie es hier auf dieser Seite dargestellt ist, kannst du die aktuelle Activity des Hubs abrufen.

                  Als Rückmeldung vom Script bekommst du also sowas wie "Fernsehen", "PowerOff", usw.

                  Mir persönlich würde das fast sogar reichen. Nutze nur PowerOff als Trigger, müsste es aber auch setzen. Und das geht glaube nicht mit diesem Skript

                  1 Antwort Letzte Antwort
                  0
                  • D Offline
                    D Offline
                    denjo
                    schrieb am zuletzt editiert von
                    #89

                    Achso, ja ich nutze den hub für so vieles. Um sender umzuschalten, mein Beamer, av Receiver, tv und receiver. Also muss ich wohl abwarten und hoffen das logi wieder zurück rudert

                    1 Antwort Letzte Antwort
                    0
                    • P Offline
                      P Offline
                      Pman
                      schrieb am zuletzt editiert von
                      #90

                      Bitte die neue Version testen. Dazu in ioBroker auf das GitHub-Symbol klicken und bei beliebig eingeben:

                      https://github.com/Pmant/ioBroker.harmony/tarball/WS

                      1 Antwort Letzte Antwort
                      0
                      • M Offline
                        M Offline
                        MarkusP
                        schrieb am zuletzt editiert von
                        #91

                        Hallo,

                        leider nutzt es nichts den Zugriff auf die erwähnten Internetadressen zu blocken. Die neue Firmware hat sich auf meinen Hamrony Hub trotdem wieder aufgespielt. Gesperrt habe ich über eine Blacklist in meiner Fritzbox. Gibt es noch ne andere Möglichkeit?

                        Gruß Markus

                        1 Antwort Letzte Antwort
                        0
                        • M Offline
                          M Offline
                          mamoel
                          schrieb am zuletzt editiert von
                          #92

                          @Pman:

                          Bitte die neue Version testen. Dazu in ioBroker auf das GitHub-Symbol klicken und bei beliebig eingeben:

                          https://github.com/Pmant/ioBroker.harmony/tarball/WS `
                          Ich habe zwar noch nicht ausgiebig getestet, aber das scheint mit der neuen Version zu funktionieren. Grandiose Arbeit!

                          Nach dem Neustart des Adapters kommt zwar immer folgendes im Log:

                          harmony.0	2018-12-21 06:45:59.030	info	[PROCESS] Synced hub config for Harmony Hub (x.x.x.x)
                          harmony.0	2018-12-21 06:45:55.810	warn	[SETACTIVITY] Unknown activityId: -1
                          harmony.0	2018-12-21 06:45:55.809	info	[CONNECT] Connected to Harmony Hub (x.x.x.x)
                          harmony.0	2018-12-21 06:45:51.097	info	[CONNECT] Connecting to Harmony Hub (x.x.x.x)
                          harmony.0	2018-12-21 06:45:51.027	info	[DISCOVER] Discovered Harmony Hub (x.x.x.x) and will try to connect
                          harmony.0	2018-12-21 06:45:49.151	info	[DISCOVER] Searching for Harmony Hubs on 255.255.255.255
                          harmony.0	2018-12-21 06:45:49.112	info	starting. Version 1.1.0 in /opt/iobroker/node_modules/iobroker.harmony, node: v8.14.0
                          

                          aber solange das mit "warn [SETACTIVITY] Unknown activityId: -1" keine Nebenwirkungen hat, kann ich damit leben.

                          Vielen Dank!

                          <size size="85">ioBroker (docker) auf Synology DS418play

                          Alexa2, cloud, fritzdect, g-homa, harmony, hm-rega, hm-rpc, hs100, hue, javascript, nuki, ring, sayit, sonos, sql, viessmannapi</size>

                          1 Antwort Letzte Antwort
                          0
                          • T Offline
                            T Offline
                            Turbo
                            schrieb am zuletzt editiert von
                            #93

                            @Pman:

                            Bitte die neue Version testen. Dazu in ioBroker auf das GitHub-Symbol klicken und bei beliebig eingeben:

                            https://github.com/Pmant/ioBroker.harmony/tarball/WS `

                            Jep, neue Version läuft, vielen Dank.

                            Jetzt muss ich nur noch alle scripte ändern, da die Objekte jetzt im Ordner Harmony_Hub liegen, vorher Harmony Hub ohne Unterlänge.

                            1 Antwort Letzte Antwort
                            0
                            • D Offline
                              D Offline
                              denjo
                              schrieb am zuletzt editiert von
                              #94

                              Was bedeutet version läuft? Kann der adapter jetzt mit den neuen Update um oder nur mit der alten Firmware?

                              1 Antwort Letzte Antwort
                              0
                              • K Offline
                                K Offline
                                Kuddel
                                schrieb am zuletzt editiert von
                                #95

                                Habe mal eben meine ioBroker VM geklont und die neue Version getestet.

                                Der Hub (mit alter Firmware) wird mit der neuen Version des Adapters korrekt ausgelesen.

                                3467_harmony.jpg

                                Dein Eintrag im Log habe ich auch.

                                3467_harmony_log.jpg

                                Ist jetzt die Frage, ob mich traue den Hub wieder upzudaten, sprich ihn wieder ins Internet zu lassen und die neue Version des Adapter auch auf meinem produktiven ioBroker verwende….

                                1 Antwort Letzte Antwort
                                0
                                • D Offline
                                  D Offline
                                  denjo
                                  schrieb am zuletzt editiert von
                                  #96

                                  Das ist ja meine Frage gewesen, wäre ja interressant wenn man sich den Hub neu kaufen möchte

                                  1 Antwort Letzte Antwort
                                  0
                                  • K Offline
                                    K Offline
                                    Kuddel
                                    schrieb am zuletzt editiert von
                                    #97

                                    @denjo:

                                    Das ist ja meine Frage gewesen, wäre ja interressant wenn man sich den Hub neu kaufen möchte `

                                    Heute und morgen komme ich leider nicht dazu.

                                    Vllt. schaffe ich es Sonntag den HUB zu aktualisieren und dann mit der neuen Adapter-Version zu testen

                                    1 Antwort Letzte Antwort
                                    0
                                    • M Offline
                                      M Offline
                                      mamoel
                                      schrieb am zuletzt editiert von
                                      #98

                                      Ich habe die neue Firmware auf dem Hub und kann mit dem neuen Adapter arbeiten wie vor dem Update. Zumindest sieht es nach meinem 5-Minuten-Test (bevor ich zur Arbeit musste) danach aus. Ich kann Activities schalten und abfragen. Auch Einzeltasten können wieder ausgelöst werden.

                                      <size size="85">ioBroker (docker) auf Synology DS418play

                                      Alexa2, cloud, fritzdect, g-homa, harmony, hm-rega, hm-rpc, hs100, hue, javascript, nuki, ring, sayit, sonos, sql, viessmannapi</size>

                                      1 Antwort Letzte Antwort
                                      0
                                      • D Offline
                                        D Offline
                                        denjo
                                        schrieb am zuletzt editiert von
                                        #99

                                        okay, habe ihn jetzt auch wieder freigegeben. hast du das update selber aufgespielt oder hat der Hub sich das sofort gezogen??

                                        1 Antwort Letzte Antwort
                                        0
                                        • M Offline
                                          M Offline
                                          mamoel
                                          schrieb am zuletzt editiert von
                                          #100

                                          Der Hub hat sich selbst aktualisiert.

                                          <size size="85">ioBroker (docker) auf Synology DS418play

                                          Alexa2, cloud, fritzdect, g-homa, harmony, hm-rega, hm-rpc, hs100, hue, javascript, nuki, ring, sayit, sonos, sql, viessmannapi</size>

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          365

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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