Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. [Neuer Adapter] LinkedDevices

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

[Neuer Adapter] LinkedDevices

Scheduled Pinned Locked Moved Tester
adapter
464 Posts 68 Posters 114.0k Views 57 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • ScroungerS Scrounger

    Ja und das ist genau richtig, weil das linkedObjekt ja ein Spiegelbild des parentObjects ist und immer den gleichen Zustand wie das parentObjekt abbilden muss.

    vis/skript -> write -> parentObject -> write -> linkedObject & Hardware.

    paul53P Offline
    paul53P Offline
    paul53
    wrote on last edited by
    #31

    @Scrounger sagte:

    immer den gleichen Zustand wie das parentObjekt abbilden muss.

    Das ist Ansichtssache. Wenn Du es so dokumentierst, wird es sicherlich akzeptiert und Nachfragen vermieden.

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    1 Reply Last reply
    0
    • ScroungerS Scrounger

      Ja und das ist genau richtig, weil das linkedObjekt ja ein Spiegelbild des parentObjects ist und immer den gleichen Zustand wie das parentObjekt abbilden muss.

      vis/skript -> write -> parentObject -> write -> linkedObject & Hardware.

      paul53P Offline
      paul53P Offline
      paul53
      wrote on last edited by paul53
      #32

      @Scrounger Der Zustand eines Datenpunktes beinhaltet auch den Zeitstempel. Jetzt erfolgt die Übertragung nur bei einer Wertänderung, nicht jedoch, wenn nur der Zeitstempel aktualisiert wird - wie es bei Tasten (z.B. PRESS_SHORT) der Fall ist.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      ScroungerS 1 Reply Last reply
      0
      • paul53P Offline
        paul53P Offline
        paul53
        wrote on last edited by
        #33

        Nach 2 Tagen nochmal getestet und es reagiert kein Datenpunkt mehr auf ein Veränderung der anderen Seite (parent / linked). Im Log finde ich nur noch das:

        linkeddevices.0	2019-05-09 17:00:32.774	debug	[createLinkedObject] keep custom settings '{"linkeddevices.0":{"enabled":true,"parentId":"hm-rpc.0.NEQ1234567.1.STATE","isLinked":false}}' for linkedObject 'linkeddevices.0.Bad.Licht.Aktor'
        linkeddevices.0	2019-05-09 17:00:32.772	debug	[createLinkedObject] using custom name 'Bad Lampe' for: 'linkeddevices.0.Bad.Licht.Aktor' (parentObj: 'hm-rpc.0.NEQ1234567.1.STATE')
        linkeddevices.0	2019-05-09 17:00:32.630	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 6
        linkeddevices.0	2019-05-09 17:00:32.630	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Auto_Mode'
        linkeddevices.0	2019-05-09 17:00:32.630	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Control_Mode'
        linkeddevices.0	2019-05-09 17:00:32.630	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Manu_Sollwert'
        linkeddevices.0	2019-05-09 17:00:32.614	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Aktor'
        linkeddevices.0	2019-05-09 17:00:32.614	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Fenster'
        linkeddevices.0	2019-05-09 17:00:32.614	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Taste_kurz'
        linkeddevices.0	2019-05-09 17:00:32.599	info	[initialObjects] started...
        linkeddevices.0	2019-05-09 17:00:32.599	debug	[onReady] notDeleteDeadLinkedObjects: 'true'
        linkeddevices.0	2019-05-09 17:00:32.552	info	starting. Version 0.0.1 in C:/Program Files/ioBroker/node_modules/iobroker.linkeddevices, node: v8.15.1
        linkeddevices.0	2019-05-09 17:00:32.498	debug	statesDB connected
        linkeddevices.0	2019-05-09 17:00:32.444	debug	objectDB connected
        
        

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        1 Reply Last reply
        0
        • paul53P paul53

          @Scrounger Der Zustand eines Datenpunktes beinhaltet auch den Zeitstempel. Jetzt erfolgt die Übertragung nur bei einer Wertänderung, nicht jedoch, wenn nur der Zeitstempel aktualisiert wird - wie es bei Tasten (z.B. PRESS_SHORT) der Fall ist.

          ScroungerS Offline
          ScroungerS Offline
          Scrounger
          Developer
          wrote on last edited by Scrounger
          #34

          @paul53 sagte in [Neuer Adapter] LinkedDevices:

          @Scrounger Der Zustand eines Datenpunktes beinhaltet auch den Zeitstempel. Jetzt erfolgt die Übertragung nur bei einer Wertänderung, nicht jedoch, wenn nur der Zeitstempel aktualisiert wird - wie es bei Tasten (z.B. PRESS_SHORT) der Fall ist.

          Stimmt bei buttons macht der Zeitstempel natürlich sinn. Bitte schick mir mal die raw Daten des buttons.

          @paul53 sagte in [Neuer Adapter] LinkedDevices:

          Nach 2 Tagen nochmal getestet und es reagiert kein Datenpunkt mehr auf ein Veränderung der anderen Seite (parent / linked). Im Log finde ich nur noch das:

          Laut log bleibt der adapter beim initializieren hängen. Hast du den neu gestartet oder komplett zwei Tage am Stück durchlaufen lassen? Restart hilft auch nicht?

          <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

          <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

          paul53P 1 Reply Last reply
          0
          • ScroungerS Scrounger

            @paul53 sagte in [Neuer Adapter] LinkedDevices:

            @Scrounger Der Zustand eines Datenpunktes beinhaltet auch den Zeitstempel. Jetzt erfolgt die Übertragung nur bei einer Wertänderung, nicht jedoch, wenn nur der Zeitstempel aktualisiert wird - wie es bei Tasten (z.B. PRESS_SHORT) der Fall ist.

            Stimmt bei buttons macht der Zeitstempel natürlich sinn. Bitte schick mir mal die raw Daten des buttons.

            @paul53 sagte in [Neuer Adapter] LinkedDevices:

            Nach 2 Tagen nochmal getestet und es reagiert kein Datenpunkt mehr auf ein Veränderung der anderen Seite (parent / linked). Im Log finde ich nur noch das:

            Laut log bleibt der adapter beim initializieren hängen. Hast du den neu gestartet oder komplett zwei Tage am Stück durchlaufen lassen? Restart hilft auch nicht?

            paul53P Offline
            paul53P Offline
            paul53
            wrote on last edited by paul53
            #35

            @Scrounger sagte:

            die raw Daten des buttons

            {
              "type": "state",
              "common": {
                "def": false,
                "type": "boolean",
                "read": false,
                "write": true,
                "role": "button",
                "name": "Taste 2 kurz"
              },
              "native": {
                "CONTROL": "BUTTON.SHORT",
                "DEFAULT": false,
                "FLAGS": 1,
                "ID": "PRESS_SHORT",
                "MAX": true,
                "MIN": false,
                "OPERATIONS": 6,
                "TAB_ORDER": 0,
                "TYPE": "ACTION",
                "UNIT": ""
              },
              "from": "system.adapter.hm-rpc.0",
              "ts": 1556192106793,
              "_id": "hm-rpc.0.PEQ0371234.1.PRESS_SHORT",
              "acl": {
                "object": 1636,
                "state": 1636,
                "owner": "system.user.admin",
                "ownerGroup": "system.group.administrator"
              }
            }
            

            Trotz common.def: false ist der Wert immer true.

            @Scrounger sagte in [Neuer Adapter] LinkedDevices:

            Hast du den neu gestartet

            Ja.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            ScroungerS 1 Reply Last reply
            0
            • paul53P paul53

              @Scrounger sagte:

              die raw Daten des buttons

              {
                "type": "state",
                "common": {
                  "def": false,
                  "type": "boolean",
                  "read": false,
                  "write": true,
                  "role": "button",
                  "name": "Taste 2 kurz"
                },
                "native": {
                  "CONTROL": "BUTTON.SHORT",
                  "DEFAULT": false,
                  "FLAGS": 1,
                  "ID": "PRESS_SHORT",
                  "MAX": true,
                  "MIN": false,
                  "OPERATIONS": 6,
                  "TAB_ORDER": 0,
                  "TYPE": "ACTION",
                  "UNIT": ""
                },
                "from": "system.adapter.hm-rpc.0",
                "ts": 1556192106793,
                "_id": "hm-rpc.0.PEQ0371234.1.PRESS_SHORT",
                "acl": {
                  "object": 1636,
                  "state": 1636,
                  "owner": "system.user.admin",
                  "ownerGroup": "system.group.administrator"
                }
              }
              

              Trotz common.def: false ist der Wert immer true.

              @Scrounger sagte in [Neuer Adapter] LinkedDevices:

              Hast du den neu gestartet

              Ja.

              ScroungerS Offline
              ScroungerS Offline
              Scrounger
              Developer
              wrote on last edited by
              #36

              @paul53
              Stell mal den adapter auf silly und mach nen neustart. Wenn er dann auch nicht komplett durchläuft, d.h. am Ende muss '[initialObjects] finished' im log stehen, dann deaktivere 'Nicht mehr verlinkte Objekte nicht löschen' und nochmal neustarten und logs posten, danke!

              <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

              <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

              1 Reply Last reply
              0
              • paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by
                #37

                Ergebnis:

                linkeddevices.0	2019-05-09 19:20:56.711	debug	[createLinkedObject] keep custom settings '{"linkeddevices.0":{"enabled":true,"parentId":"hm-rpc.0.NEQ1234567.1.STATE","isLinked":false}}' for linkedObject 'linkeddevices.0.Bad.Licht.Aktor'
                linkeddevices.0	2019-05-09 19:20:56.710	debug	[createLinkedObject] using custom name 'Bad Lampe' for: 'linkeddevices.0.Bad.Licht.Aktor' (parentObj: 'hm-rpc.0.NEQ1234567.1.STATE')
                linkeddevices.0	2019-05-09 19:20:56.622	silly	[resetAllLinkedObjectsStatus] linkedObjects status {"linkeddevices.0.Bad.Licht.Taste_kurz":false,"linkeddevices.0.Bad.Fenster":false,"linkeddevices.0.Bad.Licht.Aktor":false,"linkeddevices.0.Bad.HKT.M
                linkeddevices.0	2019-05-09 19:20:56.622	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 6
                linkeddevices.0	2019-05-09 19:20:56.622	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Auto_Mode'
                linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Control_Mode'
                linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Manu_Sollwert'
                linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Aktor'
                linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Fenster'
                linkeddevices.0	2019-05-09 19:20:56.591	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Taste_kurz'
                linkeddevices.0	2019-05-09 19:20:56.575	info	[initialObjects] started...
                linkeddevices.0	2019-05-09 19:20:56.575	debug	[onReady] notDeleteDeadLinkedObjects: 'false'
                linkeddevices.0	2019-05-09 19:20:56.544	info	starting. Version 0.0.1 in C:/Program Files/ioBroker/node_modules/iobroker.linkeddevices, node: v8.15.1
                linkeddevices.0	2019-05-09 19:20:56.544	debug	statesDB connected
                linkeddevices.0	2019-05-09 19:20:56.528	debug	objectDB connected
                

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                ScroungerS 1 Reply Last reply
                0
                • paul53P paul53

                  Ergebnis:

                  linkeddevices.0	2019-05-09 19:20:56.711	debug	[createLinkedObject] keep custom settings '{"linkeddevices.0":{"enabled":true,"parentId":"hm-rpc.0.NEQ1234567.1.STATE","isLinked":false}}' for linkedObject 'linkeddevices.0.Bad.Licht.Aktor'
                  linkeddevices.0	2019-05-09 19:20:56.710	debug	[createLinkedObject] using custom name 'Bad Lampe' for: 'linkeddevices.0.Bad.Licht.Aktor' (parentObj: 'hm-rpc.0.NEQ1234567.1.STATE')
                  linkeddevices.0	2019-05-09 19:20:56.622	silly	[resetAllLinkedObjectsStatus] linkedObjects status {"linkeddevices.0.Bad.Licht.Taste_kurz":false,"linkeddevices.0.Bad.Fenster":false,"linkeddevices.0.Bad.Licht.Aktor":false,"linkeddevices.0.Bad.HKT.M
                  linkeddevices.0	2019-05-09 19:20:56.622	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 6
                  linkeddevices.0	2019-05-09 19:20:56.622	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Auto_Mode'
                  linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Control_Mode'
                  linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Manu_Sollwert'
                  linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Aktor'
                  linkeddevices.0	2019-05-09 19:20:56.606	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Fenster'
                  linkeddevices.0	2019-05-09 19:20:56.591	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Taste_kurz'
                  linkeddevices.0	2019-05-09 19:20:56.575	info	[initialObjects] started...
                  linkeddevices.0	2019-05-09 19:20:56.575	debug	[onReady] notDeleteDeadLinkedObjects: 'false'
                  linkeddevices.0	2019-05-09 19:20:56.544	info	starting. Version 0.0.1 in C:/Program Files/ioBroker/node_modules/iobroker.linkeddevices, node: v8.15.1
                  linkeddevices.0	2019-05-09 19:20:56.544	debug	statesDB connected
                  linkeddevices.0	2019-05-09 19:20:56.528	debug	objectDB connected
                  
                  ScroungerS Offline
                  ScroungerS Offline
                  Scrounger
                  Developer
                  wrote on last edited by
                  #38

                  @paul53
                  Ok hängt genau an der gleichen Stelle und schlauer werd ich daraus auch nicht.
                  Versuch mal nen 'iobroker update linkeddevices' durchzuführen und adapter neu starten. Wenn das nicht hilft, dann mal iobroker komplett neu starten.

                  <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                  <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                  paul53P 1 Reply Last reply
                  0
                  • ScroungerS Scrounger

                    @paul53
                    Ok hängt genau an der gleichen Stelle und schlauer werd ich daraus auch nicht.
                    Versuch mal nen 'iobroker update linkeddevices' durchzuführen und adapter neu starten. Wenn das nicht hilft, dann mal iobroker komplett neu starten.

                    paul53P Offline
                    paul53P Offline
                    paul53
                    wrote on last edited by
                    #39

                    @Scrounger sagte:

                    'iobroker update linkeddevices' durchzuführen und adapter neu starten.

                    Gemacht und anschließend PC neu gestartet: Keine Änderung.

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    ScroungerS 1 Reply Last reply
                    0
                    • paul53P paul53

                      @Scrounger sagte:

                      'iobroker update linkeddevices' durchzuführen und adapter neu starten.

                      Gemacht und anschließend PC neu gestartet: Keine Änderung.

                      ScroungerS Offline
                      ScroungerS Offline
                      Scrounger
                      Developer
                      wrote on last edited by
                      #40

                      @paul53
                      ok dann lösch mal die Verlinkung mit 'hm-rpc.0.NEQ1234567.1.STATE', wenn er weiter da hängen bleibt, die nächste Verlinkung usw.
                      Stell mir mal die raw daten des 'hm-rpc.0.NEQ1234567.1.STATE' zur Verfügung.

                      <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                      <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                      paul53P 1 Reply Last reply
                      0
                      • ScroungerS Scrounger

                        @paul53
                        ok dann lösch mal die Verlinkung mit 'hm-rpc.0.NEQ1234567.1.STATE', wenn er weiter da hängen bleibt, die nächste Verlinkung usw.
                        Stell mir mal die raw daten des 'hm-rpc.0.NEQ1234567.1.STATE' zur Verfügung.

                        paul53P Offline
                        paul53P Offline
                        paul53
                        wrote on last edited by paul53
                        #41

                        @Scrounger Raw data

                        {
                          "_id": "hm-rpc.0.NEQ1234567.1.STATE",
                          "type": "state",
                          "common": {
                            "name": "NEQ1234567.1.STATE",
                            "role": "switch",
                            "type": "boolean",
                            "read": true,
                            "write": true,
                            "desc": "Manuell erzeugt",
                            "def": false
                          },
                          "native": {},
                          "acl": {
                            "object": 1638,
                            "state": 1638
                          },
                          "from": "system.adapter.admin.1",
                          "user": "system.user.admin",
                          "ts": 1557243244184
                        }
                        

                        Log nach Deaktivierung Link für STATE

                        linkeddevices.0	2019-05-09 20:07:49.471	debug	[createLinkedObject] keep custom settings '{"linkeddevices.0":{"enabled":true,"parentId":"hm-rpc.0.NEQ1234567.1.AUTO_MODE","isLinked":false}}' for linkedObject 'linkeddevices.0.Bad.HKT.Auto_Mode'
                        linkeddevices.0	2019-05-09 20:07:49.470	debug	[createLinkedObject] using custom name 'Bad HKT Auto' for: 'linkeddevices.0.Bad.HKT.Auto_Mode' (parentObj: 'hm-rpc.0.NEQ1234567.1.AUTO_MODE')
                        linkeddevices.0	2019-05-09 20:07:49.371	silly	[resetAllLinkedObjectsStatus] linkedObjects status {"linkeddevices.0.Bad.Licht.Taste_kurz":false,"linkeddevices.0.Bad.Fenster":false,"linkeddevices.0.Bad.Licht.Aktor":false,"linkeddevices.0.Bad.HKT.M
                        linkeddevices.0	2019-05-09 20:07:49.371	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 6
                        linkeddevices.0	2019-05-09 20:07:49.371	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Auto_Mode'
                        linkeddevices.0	2019-05-09 20:07:49.371	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Control_Mode'
                        linkeddevices.0	2019-05-09 20:07:49.371	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.HKT.Manu_Sollwert'
                        linkeddevices.0	2019-05-09 20:07:49.371	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Aktor'
                        linkeddevices.0	2019-05-09 20:07:49.355	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Fenster'
                        linkeddevices.0	2019-05-09 20:07:49.355	debug	[resetLinkedObjectStatus] 'isLinked' status reseted for 'linkeddevices.0.Bad.Licht.Taste_kurz'
                        linkeddevices.0	2019-05-09 20:07:49.339	info	[initialObjects] started...
                        

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        1 Reply Last reply
                        0
                        • ScroungerS Offline
                          ScroungerS Offline
                          Scrounger
                          Developer
                          wrote on last edited by
                          #42

                          Mhhh, ok dann muss ich da mal noch bissle mehr error handling einbauen. Bei mir funktioniert des einwandfrei.
                          Hast du inzwischen mal auf die Node v8.16.0 geupdatet, kann mir zwar nicht vorstellen das es daran liegt, aber sicher ist sicher.

                          <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                          <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                          paul53P 1 Reply Last reply
                          0
                          • ScroungerS Scrounger

                            Mhhh, ok dann muss ich da mal noch bissle mehr error handling einbauen. Bei mir funktioniert des einwandfrei.
                            Hast du inzwischen mal auf die Node v8.16.0 geupdatet, kann mir zwar nicht vorstellen das es daran liegt, aber sicher ist sicher.

                            paul53P Offline
                            paul53P Offline
                            paul53
                            wrote on last edited by paul53
                            #43

                            @Scrounger Habe mal den Adapter deinstalliert, wieder installiert, Links angelegt, ioBroker (PC) neu gestartet: Es werden keine Datenpunkte unter linkeddevices.0 erstellt. Log:

                            linkeddevices.0	2019-05-09 21:01:38.864	debug	[createLinkedObject] using custom name 'Bad HKT Auto' for: 'linkeddevices.0.Bad.HKT.Auto' (parentObj: 'hm-rpc.0.NEQ1234567.1.AUTO_MODE')
                            linkeddevices.0	2019-05-09 21:01:38.763	silly	[resetAllLinkedObjectsStatus] linkedObjects status {}
                            linkeddevices.0	2019-05-09 21:01:38.763	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 0
                            linkeddevices.0	2019-05-09 21:01:38.747	info	[initialObjects] started...
                            linkeddevices.0	2019-05-09 21:01:38.747	debug	[onReady] notDeleteDeadLinkedObjects: 'true'
                            linkeddevices.0	2019-05-09 21:01:38.732	info	starting. Version 0.0.1 in C:/Program Files/ioBroker/node_modules/iobroker.linkeddevices, node: v8.15.1
                            
                            

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            ScroungerS 1 Reply Last reply
                            0
                            • paul53P paul53

                              @Scrounger Habe mal den Adapter deinstalliert, wieder installiert, Links angelegt, ioBroker (PC) neu gestartet: Es werden keine Datenpunkte unter linkeddevices.0 erstellt. Log:

                              linkeddevices.0	2019-05-09 21:01:38.864	debug	[createLinkedObject] using custom name 'Bad HKT Auto' for: 'linkeddevices.0.Bad.HKT.Auto' (parentObj: 'hm-rpc.0.NEQ1234567.1.AUTO_MODE')
                              linkeddevices.0	2019-05-09 21:01:38.763	silly	[resetAllLinkedObjectsStatus] linkedObjects status {}
                              linkeddevices.0	2019-05-09 21:01:38.763	debug	[resetAllLinkedObjectsStatus] 'dicLinkedObjectsStatus' items count: 0
                              linkeddevices.0	2019-05-09 21:01:38.747	info	[initialObjects] started...
                              linkeddevices.0	2019-05-09 21:01:38.747	debug	[onReady] notDeleteDeadLinkedObjects: 'true'
                              linkeddevices.0	2019-05-09 21:01:38.732	info	starting. Version 0.0.1 in C:/Program Files/ioBroker/node_modules/iobroker.linkeddevices, node: v8.15.1
                              
                              
                              ScroungerS Offline
                              ScroungerS Offline
                              Scrounger
                              Developer
                              wrote on last edited by Scrounger
                              #44

                              So hab nochmal bissle was angepasst:

                              • timestamp changes werden berücksichtig
                              • weiteres debugging und error logging

                              Bitte den aktuellen branch ziehen

                              <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                              <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                              paul53P 3 Replies Last reply
                              0
                              • ScroungerS Scrounger

                                So hab nochmal bissle was angepasst:

                                • timestamp changes werden berücksichtig
                                • weiteres debugging und error logging

                                Bitte den aktuellen branch ziehen

                                paul53P Offline
                                paul53P Offline
                                paul53
                                wrote on last edited by
                                #45

                                @Scrounger sagte:

                                Bitte den aktuellen branch ziehen

                                Gemacht und es funktioniert auch, wenn nur der Zeitstempel aktualisiert wird :+1:

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                1 Reply Last reply
                                0
                                • ScroungerS Scrounger

                                  So hab nochmal bissle was angepasst:

                                  • timestamp changes werden berücksichtig
                                  • weiteres debugging und error logging

                                  Bitte den aktuellen branch ziehen

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by paul53
                                  #46

                                  @Scrounger schrieb:

                                  } else if (tsDifference > 250) {
                                  

                                  Weshalb > 250 ms ? HomeMatic PRESS_CONT aktualisiert den Zeitstempel alle ca. 250 ms. Damit kann es ein Problem geben.

                                  Was hälst Du davon, anstelle von state.val, state.ack und state.ts für das Vermeiden einer Dauerschleife state.from auszuwerten ? Etwa so:

                                  async onStateChange(id, state) {
                                         if (state && state.from != 'system.adapter.' + this.namespace) {
                                  		// parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                  

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  ScroungerS 1 Reply Last reply
                                  0
                                  • ScroungerS Scrounger

                                    So hab nochmal bissle was angepasst:

                                    • timestamp changes werden berücksichtig
                                    • weiteres debugging und error logging

                                    Bitte den aktuellen branch ziehen

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by paul53
                                    #47

                                    @Scrounger Habe mal folgende Änderung an main.js vorgenommen und erfolgreich getestet:

                                       async onStateChange(id, state) {
                                          if (state && state.from != 'system.adapter.' + this.namespace) {
                                             let changedValue = state.val;
                                             // parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                             if (this.dicLinkedParentObjects && id in this.dicLinkedParentObjects) {
                                                let linkedObjId = this.dicLinkedParentObjects[id];
                                    
                                                // let linkedObj = await this.getForeignObjectAsync(linkedObjId);
                                                // var linkedObjState = await this.getForeignStateAsync(linkedObjId);
                                                // if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                                // 	this.log.debug(`[onStateChange] linkedObject state changed ${linkedObj.common.custom[this.namespace].conversion}`)
                                                // 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}`)  
                                                // 	this.log.debug(`[onStateChange] parentObject state changed ${changedValue}`)
                                                // }
                                    
                                    	    await this.setForeignStateChanged(linkedObjId, changedValue, state.ack);
                                    	    this.log.debug(`[onStateChange] parentObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set linkedObject state '${linkedObjId}'`)
                                             }
                                    
                                             // linkedObject 'state' hat sich geändert -> parentObject 'state' ändern
                                             else if (this.dicLinkedObjectsStatus && id in this.dicLinkedObjectsStatus) {
                                                // @ts-ignore
                                                let parentObjId = Object.keys(this.dicLinkedParentObjects).find(key => this.dicLinkedParentObjects[key] === id);
                                                
                                                // let parentObjState = await this.getForeignStateAsync(parentObjId);
                                                // let linkedObj = await this.getForeignObjectAsync(id);
                                                // if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                                // 	let conversion = this.reverseMathString(linkedObj.common.custom[this.namespace].conversion)
                                                // 	this.log.debug(`[onStateChange] linkedObject state changed ${conversion}`)
                                                // 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}*-1`)
                                                // 	this.log.debug(`[onStateChange] linkedObject state changed ${changedValue}`)
                                                // }
                                    
                                                // 'custom.isLinked = true'
                                                if (this.dicLinkedObjectsStatus[id] === true) {
                                    		await this.setForeignStateChangedAsync(parentObjId, changedValue, state.ack);
                                    		this.log.debug(`[onStateChange] linkedObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set parentObject state '${parentObjId}'`)
                                                }
                                             }
                                          }
                                       }
                                    

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    ScroungerS 1 Reply Last reply
                                    0
                                    • paul53P paul53

                                      @Scrounger schrieb:

                                      } else if (tsDifference > 250) {
                                      

                                      Weshalb > 250 ms ? HomeMatic PRESS_CONT aktualisiert den Zeitstempel alle ca. 250 ms. Damit kann es ein Problem geben.

                                      Was hälst Du davon, anstelle von state.val, state.ack und state.ts für das Vermeiden einer Dauerschleife state.from auszuwerten ? Etwa so:

                                      async onStateChange(id, state) {
                                             if (state && state.from != 'system.adapter.' + this.namespace) {
                                      		// parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                      
                                      ScroungerS Offline
                                      ScroungerS Offline
                                      Scrounger
                                      Developer
                                      wrote on last edited by Scrounger
                                      #48

                                      @paul53

                                      @paul53 sagte in [Neuer Adapter] LinkedDevices:

                                      @Scrounger schrieb:

                                      } else if (tsDifference > 250) {
                                      

                                      Weshalb > 250 ms ? HomeMatic PRESS_CONT aktualisiert den Zeitstempel alle ca. 250 ms. Damit kann es ein Problem geben.

                                      Die Entprellzeit von 250ms hab ich gewählt, weil der timestamp ja nur bei Buttons oder zyklischen Statusmeldung geändert wird. Das ein Button innerhalb von 250ms zweimal gedrückt wird erscheint mir unrealistisch, genauso das zyklische Statusmeldungen <250ms überhaupt sinnvoll sind.

                                      @paul53 sagte in [Neuer Adapter] LinkedDevices:

                                      Was hälst Du davon, anstelle von state.val, state.ack und state.ts für das Vermeiden einer Dauerschleife state.from auszuwerten ? Etwa so:

                                      Damit hab ich es auch schon mal probiert, werd aber nochmal testen.

                                      @paul53 sagte in [Neuer Adapter] LinkedDevices:

                                      @Scrounger Habe mal folgende Änderung an main.js vorgenommen und erfolgreich getestet:

                                      Werd ich testen.

                                      <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                      <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                      1 Reply Last reply
                                      0
                                      • paul53P paul53

                                        @Scrounger Habe mal folgende Änderung an main.js vorgenommen und erfolgreich getestet:

                                           async onStateChange(id, state) {
                                              if (state && state.from != 'system.adapter.' + this.namespace) {
                                                 let changedValue = state.val;
                                                 // parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                                 if (this.dicLinkedParentObjects && id in this.dicLinkedParentObjects) {
                                                    let linkedObjId = this.dicLinkedParentObjects[id];
                                        
                                                    // let linkedObj = await this.getForeignObjectAsync(linkedObjId);
                                                    // var linkedObjState = await this.getForeignStateAsync(linkedObjId);
                                                    // if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                                    // 	this.log.debug(`[onStateChange] linkedObject state changed ${linkedObj.common.custom[this.namespace].conversion}`)
                                                    // 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}`)  
                                                    // 	this.log.debug(`[onStateChange] parentObject state changed ${changedValue}`)
                                                    // }
                                        
                                        	    await this.setForeignStateChanged(linkedObjId, changedValue, state.ack);
                                        	    this.log.debug(`[onStateChange] parentObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set linkedObject state '${linkedObjId}'`)
                                                 }
                                        
                                                 // linkedObject 'state' hat sich geändert -> parentObject 'state' ändern
                                                 else if (this.dicLinkedObjectsStatus && id in this.dicLinkedObjectsStatus) {
                                                    // @ts-ignore
                                                    let parentObjId = Object.keys(this.dicLinkedParentObjects).find(key => this.dicLinkedParentObjects[key] === id);
                                                    
                                                    // let parentObjState = await this.getForeignStateAsync(parentObjId);
                                                    // let linkedObj = await this.getForeignObjectAsync(id);
                                                    // if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                                    // 	let conversion = this.reverseMathString(linkedObj.common.custom[this.namespace].conversion)
                                                    // 	this.log.debug(`[onStateChange] linkedObject state changed ${conversion}`)
                                                    // 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}*-1`)
                                                    // 	this.log.debug(`[onStateChange] linkedObject state changed ${changedValue}`)
                                                    // }
                                        
                                                    // 'custom.isLinked = true'
                                                    if (this.dicLinkedObjectsStatus[id] === true) {
                                        		await this.setForeignStateChangedAsync(parentObjId, changedValue, state.ack);
                                        		this.log.debug(`[onStateChange] linkedObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set parentObject state '${parentObjId}'`)
                                                    }
                                                 }
                                              }
                                           }
                                        
                                        ScroungerS Offline
                                        ScroungerS Offline
                                        Scrounger
                                        Developer
                                        wrote on last edited by
                                        #49

                                        @paul53 sagte in [Neuer Adapter] LinkedDevices:

                                        @Scrounger Habe mal folgende Änderung an main.js vorgenommen und erfolgreich getestet:

                                        Fast perfekt ;)
                                        Damit Timestamp Änderungen am linkedObject auch übertragen werden, hab ich es noch etwas modifiziert, 'setForeignStateChangedAsync' in 'setForeignStateAsync' geändert:

                                        	async onStateChange(id, state) {
                                        		if (state && state.from != 'system.adapter.' + this.namespace) {
                                        			let changedValue = state.val;
                                        			// parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                        			if (this.dicLinkedParentObjects && id in this.dicLinkedParentObjects) {
                                        				let linkedObjId = this.dicLinkedParentObjects[id];
                                        
                                        				// let linkedObj = await this.getForeignObjectAsync(linkedObjId);
                                        				// var linkedObjState = await this.getForeignStateAsync(linkedObjId);
                                        				// if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                        				// 	this.log.debug(`[onStateChange] linkedObject state changed ${linkedObj.common.custom[this.namespace].conversion}`)
                                        				// 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}`)  
                                        				// 	this.log.debug(`[onStateChange] parentObject state changed ${changedValue}`)
                                        				// }
                                        
                                        				await this.setForeignStateAsync(linkedObjId, changedValue, state.ack);
                                        				this.log.debug(`[onStateChange] parentObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set linkedObject state '${linkedObjId}'`)
                                        			}
                                        
                                        			// linkedObject 'state' hat sich geändert -> parentObject 'state' ändern
                                        			else if (this.dicLinkedObjectsStatus && id in this.dicLinkedObjectsStatus) {
                                        				// @ts-ignore
                                        				let parentObjId = Object.keys(this.dicLinkedParentObjects).find(key => this.dicLinkedParentObjects[key] === id);
                                        
                                        				// let parentObjState = await this.getForeignStateAsync(parentObjId);
                                        				// let linkedObj = await this.getForeignObjectAsync(id);
                                        				// if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                        				// 	let conversion = this.reverseMathString(linkedObj.common.custom[this.namespace].conversion)
                                        				// 	this.log.debug(`[onStateChange] linkedObject state changed ${conversion}`)
                                        				// 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}*-1`)
                                        				// 	this.log.debug(`[onStateChange] linkedObject state changed ${changedValue}`)
                                        				// }
                                        
                                        				// 'custom.isLinked = true'
                                        				if (this.dicLinkedObjectsStatus[id] === true) {
                                        					await this.setForeignStateAsync(parentObjId, changedValue, state.ack);
                                        					this.log.debug(`[onStateChange] linkedObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set parentObject state '${parentObjId}'`)
                                        				}
                                        			}
                                        		}
                                        	}
                                        

                                        Wenn deine Test erfolgreich sind, dann pack ich es nachher in den branch

                                        <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                        <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                        paul53P 1 Reply Last reply
                                        0
                                        • ScroungerS Scrounger

                                          @paul53 sagte in [Neuer Adapter] LinkedDevices:

                                          @Scrounger Habe mal folgende Änderung an main.js vorgenommen und erfolgreich getestet:

                                          Fast perfekt ;)
                                          Damit Timestamp Änderungen am linkedObject auch übertragen werden, hab ich es noch etwas modifiziert, 'setForeignStateChangedAsync' in 'setForeignStateAsync' geändert:

                                          	async onStateChange(id, state) {
                                          		if (state && state.from != 'system.adapter.' + this.namespace) {
                                          			let changedValue = state.val;
                                          			// parentObject 'state' hat sich geändert -> linkedObject 'state' ändern
                                          			if (this.dicLinkedParentObjects && id in this.dicLinkedParentObjects) {
                                          				let linkedObjId = this.dicLinkedParentObjects[id];
                                          
                                          				// let linkedObj = await this.getForeignObjectAsync(linkedObjId);
                                          				// var linkedObjState = await this.getForeignStateAsync(linkedObjId);
                                          				// if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                          				// 	this.log.debug(`[onStateChange] linkedObject state changed ${linkedObj.common.custom[this.namespace].conversion}`)
                                          				// 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}`)  
                                          				// 	this.log.debug(`[onStateChange] parentObject state changed ${changedValue}`)
                                          				// }
                                          
                                          				await this.setForeignStateAsync(linkedObjId, changedValue, state.ack);
                                          				this.log.debug(`[onStateChange] parentObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set linkedObject state '${linkedObjId}'`)
                                          			}
                                          
                                          			// linkedObject 'state' hat sich geändert -> parentObject 'state' ändern
                                          			else if (this.dicLinkedObjectsStatus && id in this.dicLinkedObjectsStatus) {
                                          				// @ts-ignore
                                          				let parentObjId = Object.keys(this.dicLinkedParentObjects).find(key => this.dicLinkedParentObjects[key] === id);
                                          
                                          				// let parentObjState = await this.getForeignStateAsync(parentObjId);
                                          				// let linkedObj = await this.getForeignObjectAsync(id);
                                          				// if (linkedObj && linkedObj.common && linkedObj.common.custom && linkedObj.common.custom[this.namespace] && linkedObj.common.custom[this.namespace].conversion) {
                                          				// 	let conversion = this.reverseMathString(linkedObj.common.custom[this.namespace].conversion)
                                          				// 	this.log.debug(`[onStateChange] linkedObject state changed ${conversion}`)
                                          				// 	changedValue = eval(`${changedValue}${linkedObj.common.custom[this.namespace].conversion}*-1`)
                                          				// 	this.log.debug(`[onStateChange] linkedObject state changed ${changedValue}`)
                                          				// }
                                          
                                          				// 'custom.isLinked = true'
                                          				if (this.dicLinkedObjectsStatus[id] === true) {
                                          					await this.setForeignStateAsync(parentObjId, changedValue, state.ack);
                                          					this.log.debug(`[onStateChange] linkedObject state '${id}' changed to '${state.val}' (ack = ${state.ack}) --> set parentObject state '${parentObjId}'`)
                                          				}
                                          			}
                                          		}
                                          	}
                                          

                                          Wenn deine Test erfolgreich sind, dann pack ich es nachher in den branch

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by
                                          #50

                                          @Scrounger sagte:

                                          'setForeignStateChangedAsync' in 'setForeignStateAsync' geändert:

                                          Habe die Änderungen übernommen und anschließend alle möglichen Richtungen getestet: Es sieht gut aus !

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          818

                                          Online

                                          32.4k

                                          Users

                                          81.5k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe